VirtualBox

source: vbox/trunk/src/VBox/VMM/Makefile.kmk@ 103131

Last change on this file since 103131 was 102663, checked in by vboxsync, 9 months ago

VMM/IEM: Working on BODY_CHECK_PC_AFTER_BRANCH and sideeffects of it. Fixed bug in 8-bit register stores (AMD64). Fixed bug in iemNativeEmitBltInCheckOpcodes (AMD64). Added a way to inject state logging between each instruction, currently only really implemented for AMD64. Relaxed the heave flushing code, no need to set the buffer pointer to NULL. Started looking at avoiding code TLB flushing when allocating memory to replace zero pages. bugref:10371

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 39.6 KB
Line 
1# $Id: Makefile.kmk 102663 2023-12-21 01:55:07Z vboxsync $
2## @file
3# Top-level makefile for the VMM.
4#
5
6#
7# Copyright (C) 2006-2023 Oracle and/or its affiliates.
8#
9# This file is part of VirtualBox base platform packages, as
10# available from https://www.virtualbox.org.
11#
12# This program is free software; you can redistribute it and/or
13# modify it under the terms of the GNU General Public License
14# as published by the Free Software Foundation, in version 3 of the
15# License.
16#
17# This program is distributed in the hope that it will be useful, but
18# WITHOUT ANY WARRANTY; without even the implied warranty of
19# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20# General Public License for more details.
21#
22# You should have received a copy of the GNU General Public License
23# along with this program; if not, see <https://www.gnu.org/licenses>.
24#
25# SPDX-License-Identifier: GPL-3.0-only
26#
27
28SUB_DEPTH = ../../..
29include $(KBUILD_PATH)/subheader.kmk
30
31# Include our Config.kmk if kmk is invoked from a parent directory.
32ifndef VBOX_VMM_CONFIG_KMK_INCLUDED
33 include $(PATH_SUB_CURRENT)/Config.kmk
34endif
35
36# Include sub-makefiles.
37ifndef VBOX_ONLY_EXTPACKS
38 include $(PATH_SUB_CURRENT)/tools/Makefile.kmk
39 include $(PATH_SUB_CURRENT)/testcase/Makefile.kmk
40endif
41
42
43# Fail on unsupported hosts.
44ifeq ($(KBUILD_TARGET_ARCH),x86)
45 ifeq ($(KBUILD_TARGET),darwin)
46 $(error 32-bit darwin is no longer a supported VirtualBox host. Go back to 4.3 or older for 32-bit host support.)
47 else ifeq ($(KBUILD_TARGET),solaris)
48 $(error 32-bit solaris is no longer a supported VirtualBox host. Go back to 4.2 or older for 32-bit host support.)
49 else ifn1of ($(KBUILD_TARGET_ARCH), $(VBOX_SUPPORTED_HOST_ARCHS))
50 $(error 32-bit builds of the VirtualBox host are no longer supported. Go back to 6.0 or older for 32-bit host support.)
51 endif
52endif
53
54
55#
56# The VMM DLL.
57#
58ifndef VBOX_ONLY_EXTPACKS_USE_IMPLIBS
59 DLLS += VBoxVMM
60endif
61VBoxVMM_TEMPLATE = VBoxR3DllNoPic
62VBoxVMM_SONAME.linux = VBoxVMM.so
63
64VBoxVMM_DEFS = VBOX_IN_VMM IN_VMM_R3 IN_DIS IN_GMM_R3 IN_DBG $(VMM_COMMON_DEFS)
65## @todo eliminate IN_GMM_R3
66ifdef VBOX_WITH_PREALLOC_RAM_BY_DEFAULT
67 VBoxVMM_DEFS += VBOX_WITH_PREALLOC_RAM_BY_DEFAULT
68endif
69ifdef VBOX_WITH_VUSB
70 VBoxVMM_DEFS += VBOX_WITH_USB
71endif
72ifdef VBOX_WITH_PDM_ASYNC_COMPLETION
73 VBoxVMM_DEFS += VBOX_WITH_PDM_ASYNC_COMPLETION
74endif
75ifdef VBOX_WITH_NETSHAPER
76 VBoxVMM_DEFS += VBOX_WITH_NETSHAPER
77endif
78ifdef VBOX_WITH_IOMMU_AMD
79 VBoxVMM_DEFS += VBOX_WITH_IOMMU_AMD
80endif
81ifdef VBOX_WITH_IOMMU_INTEL
82 VBoxVMM_DEFS += VBOX_WITH_IOMMU_INTEL
83endif
84ifdef VBOX_WITH_DBGF_TRACING
85 VBoxVMM_DEFS += VBOX_WITH_DBGF_TRACING
86endif
87ifdef VBOX_WITH_DBGF_FLOW_TRACING
88 VBoxVMM_DEFS += VBOX_WITH_DBGF_FLOW_TRACING
89endif
90if "$(KBUILD_TYPE)" == "debug" && "$(USERNAME)" == "bird" && 0
91 VBoxVMM_DEFS += RTMEM_WRAP_TO_EF_APIS
92endif
93
94VBoxVMM_SDKS = VBoxSoftFloatR3Shared
95
96VBoxVMM_INCS = \
97 include \
98 $(VBoxVMM_0_OUTDIR)/CommonGenIncs
99VBoxVMM_ASINCS = .
100VBoxVMM_ASFLAGS.amd64 = -Werror
101VBoxVMM_ASFLAGS.x86 = -Werror
102
103VBoxVMM_SOURCES = \
104 VBoxVMM.d \
105 VMMR3/VMMR3VTable.cpp \
106 VMMR3/APIC.cpp \
107 VMMR3/CFGM.cpp \
108 VMMR3/CPUM.cpp \
109 VMMR3/CPUMR3CpuId.cpp \
110 VMMR3/CPUMR3Db.cpp \
111 VMMR3/CPUMDbg.cpp \
112 VMMR3/DBGF.cpp \
113 VMMR3/DBGFAddr.cpp \
114 VMMR3/DBGFAddrSpace.cpp \
115 VMMR3/DBGFR3Bp.cpp \
116 VMMR3/DBGFR3BugCheck.cpp \
117 VMMR3/DBGFCoreWrite.cpp \
118 VMMR3/DBGFCpu.cpp \
119 VMMR3/DBGFDisas.cpp \
120 VMMR3/DBGFInfo.cpp \
121 VMMR3/DBGFLog.cpp \
122 VMMR3/DBGFMem.cpp \
123 VMMR3/DBGFR3ModInMem.cpp \
124 VMMR3/DBGFOS.cpp \
125 VMMR3/DBGFR3PlugIn.cpp \
126 VMMR3/DBGFReg.cpp \
127 VMMR3/DBGFStack.cpp \
128 VMMR3/DBGFR3Flow.cpp \
129 $(if-expr defined(VBOX_WITH_DBGF_FLOW_TRACING), VMMR3/DBGFR3FlowTrace.cpp,) \
130 VMMR3/DBGFR3Trace.cpp \
131 $(if-expr defined(VBOX_WITH_DBGF_TRACING), VMMR3/DBGFR3Tracer.cpp,) \
132 VMMR3/DBGFR3SampleReport.cpp \
133 VMMR3/DBGFR3Type.cpp \
134 VMMR3/EM.cpp \
135 VMMR3/EMR3Dbg.cpp \
136 VMMR3/EMHM.cpp \
137 VMMR3/EMR3Nem.cpp \
138 VMMR3/GCM.cpp \
139 VMMR3/GIM.cpp \
140 VMMR3/GIMHv.cpp \
141 VMMR3/GIMKvm.cpp \
142 VMMR3/GIMMinimal.cpp \
143 VMMR3/IEMR3.cpp \
144 VMMR3/IOM.cpp \
145 VMMR3/IOMR3IoPort.cpp \
146 VMMR3/IOMR3Mmio.cpp \
147 VMMR3/GMM.cpp \
148 VMMR3/GVMMR3.cpp \
149 VMMR3/MM.cpp \
150 VMMR3/MMHeap.cpp \
151 VMMR3/NEMR3.cpp \
152 VMMR3/PDM.cpp \
153 VMMR3/PDMBlkCache.cpp \
154 VMMR3/PDMDevice.cpp \
155 VMMR3/PDMDevHlp.cpp \
156 $(if-expr defined(VBOX_WITH_DBGF_TRACING), VMMR3/PDMDevHlpTracing.cpp,) \
157 VMMR3/PDMDevMiscHlp.cpp \
158 VMMR3/PDMDriver.cpp \
159 VMMR3/PDMLdr.cpp \
160 VMMR3/PDMCritSect.cpp \
161 VMMR3/PDMQueue.cpp \
162 VMMR3/PDMR3Task.cpp \
163 VMMR3/PDMThread.cpp \
164 VMMR3/PGM.cpp \
165 VMMR3/PGMDbg.cpp \
166 VMMR3/PGMHandler.cpp \
167 VMMR3/PGMPhys.cpp \
168 VMMR3/PGMPool.cpp \
169 VMMR3/PGMSavedState.cpp \
170 VMMR3/PGMSharedPage.cpp \
171 VMMR3/SELM.cpp \
172 VMMR3/SSM.cpp \
173 VMMR3/STAM.cpp \
174 VMMR3/TM.cpp \
175 VMMR3/TRPM.cpp \
176 VMMR3/VM.cpp \
177 VMMR3/VMEmt.cpp \
178 VMMR3/VMReq.cpp \
179 VMMR3/VMM.cpp \
180 VMMR3/VMMGuruMeditation.cpp \
181 VMMR3/VMMTests.cpp \
182 VMMR3/HM.cpp \
183 VMMAll/APICAll.cpp \
184 VMMAll/CPUMAllCpuId.cpp \
185 VMMAll/CPUMAllRegs.cpp \
186 VMMAll/CPUMAllMsrs.cpp \
187 VMMAll/DBGFAll.cpp \
188 VMMAll/DBGFAllBp.cpp \
189 $(if-expr defined(VBOX_WITH_DBGF_TRACING), VMMAll/DBGFAllTracer.cpp,) \
190 VMMAll/HMAll.cpp \
191 VMMAll/HMSVMAll.cpp \
192 VMMAll/HMVMXAll.cpp \
193 VMMAll/IEMAll.cpp \
194 VMMAll/IEMAllIntprTables1.cpp \
195 VMMAll/IEMAllIntprTables2.cpp \
196 VMMAll/IEMAllIntprTables3.cpp \
197 VMMAll/IEMAllIntprTables4.cpp \
198 VMMAll/IEMAllAImplC.cpp \
199 VMMAll/IEMAllCImpl.cpp \
200 VMMAll/IEMAllCImplSvmInstr.cpp \
201 VMMAll/IEMAllCImplVmxInstr.cpp \
202 VMMAll/IEMAllDbg.cpp \
203 VMMAll/IOMAll.cpp \
204 VMMAll/IOMAllMmioNew.cpp \
205 VMMAll/MMAll.cpp \
206 VMMAll/NEMAll.cpp \
207 VMMAll/PDMAll.cpp \
208 VMMAll/PDMAllCritSect.cpp \
209 VMMAll/PDMAllCritSectRw.cpp \
210 VMMAll/PDMAllCritSectBoth.cpp \
211 $(if-expr defined(VBOX_WITH_IOMMU_AMD) || defined(VBOX_WITH_IOMMU_INTEL), VMMAll/PDMAllIommu.cpp,) \
212 VMMAll/PDMAllQueue.cpp \
213 VMMAll/PDMAllTask.cpp \
214 VMMAll/PGMAll.cpp \
215 VMMAll/PGMAllHandler.cpp \
216 VMMAll/PGMAllPhys.cpp \
217 VMMAll/PGMAllPool.cpp \
218 VMMAll/SELMAll.cpp \
219 VMMAll/EMAll.cpp \
220 VMMAll/GCMAll.cpp \
221 VMMAll/GIMAll.cpp \
222 VMMAll/GIMAllHv.cpp \
223 VMMAll/GIMAllKvm.cpp \
224 VMMAll/TMAll.cpp \
225 VMMAll/TMAllCpu.cpp \
226 VMMAll/TMAllReal.cpp \
227 VMMAll/TMAllVirtual.cpp \
228 VMMAll/TRPMAll.cpp \
229 VMMAll/VMAll.cpp \
230 VMMAll/VMMAll.cpp
231VBoxVMM_SOURCES.amd64 += \
232 VMMR3/PGMR3DbgA.asm \
233 $(if-expr !defined(IEM_WITHOUT_ASSEMBLY),VMMAll/IEMAllAImpl.asm,) \
234 VMMAll/VMMAllA.asm
235VBoxVMM_SOURCES.arm64 += \
236 VMMAll/IEMAllAImpl-arm64.S
237ifdef VBOX_WITH_VUSB
238 VBoxVMM_SOURCES += VMMR3/PDMUsb.cpp
239endif
240ifdef VBOX_WITH_PDM_ASYNC_COMPLETION
241 VBoxVMM_SOURCES += \
242 VMMR3/PDMAsyncCompletion.cpp \
243 VMMR3/PDMAsyncCompletionFile.cpp \
244 VMMR3/PDMAsyncCompletionFileFailsafe.cpp \
245 VMMR3/PDMAsyncCompletionFileNormal.cpp
246endif
247ifdef VBOX_WITH_NETSHAPER
248 VBoxVMM_SOURCES += \
249 VMMR3/PDMNetShaper.cpp \
250 VMMAll/PDMAllNetShaper.cpp
251endif
252
253ifdef VBOX_WITH_IEM_RECOMPILER
254 VBoxVMM_SOURCES += \
255 VMMAll/IEMAllThrdRecompiler.cpp \
256 VMMAll/IEMAllThrdTables1.cpp \
257 VMMAll/IEMAllThrdTables2.cpp \
258 VMMAll/IEMAllThrdTables3.cpp \
259 VMMAll/IEMAllThrdTables4.cpp \
260 VMMAll/IEMAllThrdFuncs.cpp \
261 VMMAll/IEMAllThrdFuncsBltIn.cpp
262 ifdef VBOX_WITH_IEM_NATIVE_RECOMPILER
263 VBoxVMM_SOURCES += \
264 VMMAll/IEMAllN8veRecompiler.cpp \
265 VMMAll/IEMAllN8veRecompBltIn.cpp
266 VBoxVMM_SOURCES.amd64 += \
267 VMMAll/IEMAllN8veHlpA.asm
268 if "$(KBUILD_TARGET_ARCH)" == "arm64" && defined(VBOX_WITH_IEM_USING_CAPSTONE_DISASSEMBLER) # temp hack
269 VBoxVMM_DEFS += VBOX_WITH_IEM_USING_CAPSTONE_DISASSEMBLER
270 VBoxVMM_LIBS.darwin += /opt/local/lib/libcapstone.dylib
271 endif
272 VMMAll/IEMAllN8veRecompiler.cpp_CXXFLAGS.win = /bigobj
273 endif
274 VMMAll/IEMAllThrdFuncs.cpp_CXXFLAGS.win = /bigobj
275endif
276
277ifdef VBOX_WITH_NATIVE_NEM
278 VBoxVMM_SOURCES.linux.amd64 += VMMR3/NEMR3Native-linux.cpp
279
280 VBoxVMM_SOURCES.win.amd64 += VMMR3/NEMR3Native-win.cpp
281 VBoxVMM_DEFS.win.amd64 += VBOX_WITH_NATIVE_NEM
282 VBoxVMM_SDKS.win += VBoxNtDll
283 VMMR3/NEMR3Native-win.cpp_DEFS.amd64 = _AMD64_
284 VMMR3/NEMR3Native-win.cpp_INCS = \
285 $(KBUILD_DEVTOOLS)/win.x86/sdk/v10.0.17134.0/include/10.0.17134.0/um \
286 $(KBUILD_DEVTOOLS)/win.x86/sdk/v10.0.17134.0/include/10.0.17134.0/shared
287
288 VBoxVMM_SOURCES.darwin.amd64 += \
289 VMMR3/NEMR3Native-darwin.cpp
290 VBoxVMM_DEFS.darwin.amd64 += VBOX_WITH_NATIVE_NEM
291endif
292
293VBoxVMM_LIBS = \
294 $(PATH_STAGE_LIB)/DisasmR3$(VBOX_SUFF_LIB)
295ifdef VBOX_WITH_DEBUGGER
296 VBoxVMM_LIBS += \
297 $(PATH_STAGE_LIB)/Debugger$(VBOX_SUFF_LIB)
298endif
299VBoxVMM_LIBS += \
300 $(LIB_REM) \
301 $(LIB_RUNTIME)
302
303VBoxVMM_LIBS.win = $(PATH_TOOL_$(VBOX_VCC_TOOL)_LIB)/delayimp.lib
304VBoxVMM_LDFLAGS.linux = $(VBOX_GCC_NO_UNDEFINED)
305VBoxVMM_LDFLAGS.darwin = -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/VBoxVMM.dylib
306VBoxVMM_LDFLAGS.solaris = -mimpure-text
307
308# SSM wish to know the build type, host os and arch.
309ifdef VBOX_WITH_AUTOMATIC_DEFS_QUOTING
310 VMMR3/SSM.cpp_DEFS += \
311 KBUILD_TYPE="$(KBUILD_TYPE)" \
312 KBUILD_TARGET="$(KBUILD_TARGET)" \
313 KBUILD_TARGET_ARCH="$(KBUILD_TARGET_ARCH)"
314else
315 VMMR3/SSM.cpp_DEFS += \
316 KBUILD_TYPE=\"$(KBUILD_TYPE)\" \
317 KBUILD_TARGET=\"$(KBUILD_TARGET)\" \
318 KBUILD_TARGET_ARCH=\"$(KBUILD_TARGET_ARCH)\"
319endif
320
321ifdef VBOX_WITH_GCC_SANITIZER
322 VMMR3/PGMPool.cpp_CXXFLAGS.linux += -fno-sanitize=address
323endif
324
325#ifdef VBOX_WITH_PDM_ASYNC_COMPLETION
326# ifeq ($(KBUILD_HOST), linux)
327#VBoxVMM_LIBS += aio
328# endif
329#endif
330
331if "$(USERNAME)" == "bird" && "$(KBUILD_TARGET)" == "win"
332 VBoxVMM_VMMAll/IEMAll.cpp_CXXFLAGS = /FAcs /Fa$(subst /,\\,$(outbase).cod)
333 VBoxVMM_VMMAll/IEMAllIntprTables1.cpp_CXXFLAGS = /FAcs /Fa$(subst /,\\,$(outbase).cod)
334 VBoxVMM_VMMAll/IEMAllIntprTables2.cpp_CXXFLAGS = /FAcs /Fa$(subst /,\\,$(outbase).cod)
335 VBoxVMM_VMMAll/IEMAllIntprTables3.cpp_CXXFLAGS = /FAcs /Fa$(subst /,\\,$(outbase).cod)
336 VBoxVMM_VMMAll/IEMAllIntprTables4.cpp_CXXFLAGS = /FAcs /Fa$(subst /,\\,$(outbase).cod)
337 VBoxVMM_VMMAll/IEMAllAImplC.cpp_CXXFLAGS = /FAcs /Fa$(subst /,\\,$(outbase).cod)
338 VBoxVMM_VMMAll/PGMAll.cpp_CXXFLAGS = /FAcs /Fa$(subst /,\\,$(outbase).cod)
339 VBoxVMM_VMMAll/PDMAllCritSect.cpp_CXXFLAGS = /FAcs /Fa$(subst /,\\,$(outbase).cod)
340 VBoxVMM_CLEAN += $(addprefix $(VBoxVMM_0_OUTDIR)/VMMAll/, IEMAll.cod IEMAllAImplC.cod IEMAllInstInterpretOnly.cod PGMAll.cod PDMAllCritSect.cod)
341endif
342
343$(call VBOX_SET_VER_INFO_DLL,VBoxVMM,VirtualBox VMM) # Version info / description.
344
345ifdef VBOX_WITH_VIRT_ARMV8
346 #
347 # The VMM DLL - ARMv8 variant.
348 #
349 ifndef VBOX_ONLY_EXTPACKS_USE_IMPLIBS
350 DLLS += VBoxVMMArm
351 endif
352 VBoxVMMArm_TEMPLATE = VBoxR3DllNoPic
353 VBoxVMMArm_SONAME.linux = VBoxVMMArm.so
354
355 VBoxVMMArm_DEFS = VBOX_VMM_TARGET_ARMV8 VBOX_IN_VMM IN_VMM_R3 IN_DIS IN_DBG \
356 $(filter-out VBOX_WITH_IEM_RECOMPILER VBOX_WITH_IEM_NATIVE_RECOMPILER,$(VMM_COMMON_DEFS))
357 ifdef VBOX_WITH_VUSB
358 VBoxVMMArm_DEFS += VBOX_WITH_USB
359 endif
360 ifdef VBOX_WITH_PDM_ASYNC_COMPLETION
361 VBoxVMMArm_DEFS += VBOX_WITH_PDM_ASYNC_COMPLETION
362 endif
363 ifdef VBOX_WITH_NETSHAPER
364 VBoxVMMArm_DEFS += VBOX_WITH_NETSHAPER
365 endif
366 #ifdef VBOX_WITH_DBGF_TRACING
367 # VBoxVMMArm_DEFS += VBOX_WITH_DBGF_TRACING
368 #endif
369 #ifdef VBOX_WITH_DBGF_FLOW_TRACING @todo Later
370 # VBoxVMMArm_DEFS += VBOX_WITH_DBGF_FLOW_TRACING
371 #endif
372
373 VBoxVMMArm_INCS = \
374 include \
375 $(VBoxVMM_0_OUTDIR)/CommonGenIncs
376 VBoxVMMArm_SOURCES = \
377 VBoxVMM.d \
378 VMMR3/VMMR3VTable.cpp \
379 VMMR3/CFGM.cpp \
380 VMMR3/CPUM-armv8.cpp \
381 VMMR3/CPUMDbg-armv8.cpp \
382 VMMR3/CPUMR3CpuId-armv8.cpp \
383 VMMR3/CPUMR3Db-armv8.cpp \
384 VMMR3/DBGF.cpp \
385 VMMR3/DBGFAddr.cpp \
386 VMMR3/DBGFAddrSpace.cpp \
387 VMMR3/DBGFR3Bp.cpp \
388 VMMR3/DBGFR3BugCheck.cpp \
389 VMMR3/DBGFCoreWrite.cpp \
390 VMMR3/DBGFCpu.cpp \
391 VMMR3/DBGFDisas.cpp \
392 VMMR3/DBGFInfo.cpp \
393 VMMR3/DBGFLog.cpp \
394 VMMR3/DBGFMem.cpp \
395 VMMR3/DBGFR3ModInMem.cpp \
396 VMMR3/DBGFOS.cpp \
397 VMMR3/DBGFR3PlugIn.cpp \
398 VMMR3/DBGFReg.cpp \
399 VMMR3/DBGFStack.cpp \
400 VMMR3/DBGFR3Flow.cpp \
401 VMMR3/DBGFR3FlowTrace.cpp \
402 VMMR3/DBGFR3Trace.cpp \
403 VMMR3/DBGFR3SampleReport.cpp \
404 VMMR3/DBGFR3Type.cpp \
405 VMMR3/EM.cpp \
406 VMMR3/EMR3Dbg.cpp \
407 VMMR3/EMR3Nem.cpp \
408 VMMR3/GICR3.cpp \
409 VMMR3/GIM.cpp \
410 VMMR3/IEMR3.cpp \
411 VMMR3/IOM.cpp \
412 VMMR3/IOMR3IoPort.cpp \
413 VMMR3/IOMR3Mmio.cpp \
414 VMMR3/GMM.cpp \
415 VMMR3/GVMMR3.cpp \
416 VMMR3/MM.cpp \
417 VMMR3/MMHeap.cpp \
418 VMMR3/NEMR3.cpp \
419 VMMR3/PDM.cpp \
420 VMMR3/PDMBlkCache.cpp \
421 VMMR3/PDMDevice.cpp \
422 VMMR3/PDMDevHlp.cpp \
423 VMMR3/PDMDevMiscHlp.cpp \
424 VMMR3/PDMDriver.cpp \
425 VMMR3/PDMLdr.cpp \
426 VMMR3/PDMCritSect.cpp \
427 VMMR3/PDMQueue.cpp \
428 VMMR3/PDMR3Task.cpp \
429 VMMR3/PDMThread.cpp \
430 VMMR3/PGM-armv8.cpp \
431 VMMR3/PGMDbg.cpp \
432 VMMR3/PGMHandler.cpp \
433 VMMR3/PGMPhys.cpp \
434 VMMR3/PGMPool.cpp \
435 VMMR3/PGMSavedState.cpp \
436 VMMR3/PGMSharedPage.cpp \
437 VMMR3/SSM.cpp \
438 VMMR3/STAM.cpp \
439 VMMR3/TM.cpp \
440 VMMR3/TRPM.cpp \
441 VMMR3/VM.cpp \
442 VMMR3/VMEmt.cpp \
443 VMMR3/VMReq.cpp \
444 VMMR3/VMM.cpp \
445 VMMR3/VMMGuruMeditation.cpp \
446 VMMR3/VMMTests.cpp \
447 VMMR3/HM-armv8.cpp \
448 VMMAll/CPUMAllRegs-armv8.cpp \
449 VMMAll/CPUMAllSysRegs-armv8.cpp \
450 VMMAll/DBGFAll.cpp \
451 $(if-expr defined(VBOX_WITH_DBGF_TRACING), VMMAll/DBGFAllTracer.cpp,) \
452 VMMAll/IEMAll-armv8.cpp \
453 VMMAll/IOMAll.cpp \
454 VMMAll/IOMAllMmioNew.cpp \
455 VMMAll/MMAll.cpp \
456 VMMAll/NEMAll.cpp \
457 VMMAll/PDMAll.cpp \
458 VMMAll/PDMAllCritSect.cpp \
459 VMMAll/PDMAllCritSectRw.cpp \
460 VMMAll/PDMAllCritSectBoth.cpp \
461 VMMAll/PDMAllQueue.cpp \
462 VMMAll/PDMAllTask.cpp \
463 VMMAll/PGMAllHandler.cpp \
464 VMMAll/PGMAllPhys.cpp \
465 VMMAll/PGMAllPool.cpp \
466 VMMAll/EMAll.cpp \
467 VMMAll/GICAll.cpp \
468 VMMAll/GIMAll.cpp \
469 VMMAll/TMAll.cpp \
470 VMMAll/TMAllCpu.cpp \
471 VMMAll/TMAllReal.cpp \
472 VMMAll/TMAllVirtual.cpp \
473 VMMAll/TRPMAll.cpp \
474 VMMAll/VMAll.cpp \
475 VMMAll/VMMAll.cpp
476 ifdef VBOX_WITH_VUSB
477 VBoxVMMArm_SOURCES += VMMR3/PDMUsb.cpp
478 endif
479 ifdef VBOX_WITH_PDM_ASYNC_COMPLETION
480 VBoxVMMArm_SOURCES += \
481 VMMR3/PDMAsyncCompletion.cpp \
482 VMMR3/PDMAsyncCompletionFile.cpp \
483 VMMR3/PDMAsyncCompletionFileFailsafe.cpp \
484 VMMR3/PDMAsyncCompletionFileNormal.cpp
485 endif
486 ifdef VBOX_WITH_NETSHAPER
487 VBoxVMMArm_SOURCES += \
488 VMMR3/PDMNetShaper.cpp \
489 VMMAll/PDMAllNetShaper.cpp
490 endif
491
492 VBoxVMMArm_SOURCES.darwin.arm64 += \
493 VMMR3/NEMR3Native-darwin-armv8.cpp
494 VBoxVMMArm_DEFS.darwin.arm64 += VBOX_WITH_NATIVE_NEM
495 VBoxVMMArm_LDFLAGS.darwin.arm64 = -framework Hypervisor
496
497 VBoxVMMArm_LIBS = \
498 $(PATH_STAGE_LIB)/DisasmR3$(VBOX_SUFF_LIB)
499 ifdef VBOX_WITH_DEBUGGER
500 VBoxVMMArm_LIBS += \
501 $(PATH_STAGE_LIB)/Debugger-armv8$(VBOX_SUFF_LIB)
502 endif
503 VBoxVMMArm_LIBS += \
504 $(LIB_RUNTIME)
505
506 VBoxVMMArm_LDFLAGS.darwin = -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/VBoxVMMArm.dylib
507endif
508
509
510#
511# Generate macro template for IEM instruction statistics.
512#
513$(call KB_FN_DO_PASS0_ON_TARGET,VBoxVMM) # Set VBoxVMM_0_OUTDIR
514VBoxVMM_INTERMEDIATES += $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMInstructionStatisticsTmpl.h
515VBoxVMM_CLEAN += \
516 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMInstructionStatisticsTmpl.h.ts \
517 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMInstructionStatisticsTmpl.h
518$(call KB_FN_AUTO_CMD_DEPS,$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMInstructionStatisticsTmpl.h.ts)
519$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMInstructionStatisticsTmpl.h.ts \
520+| $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMInstructionStatisticsTmpl.h: \
521 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstCommon.cpp.h \
522 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstOneByte.cpp.h \
523 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstTwoByte0f.cpp.h \
524 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstThree0f38.cpp.h \
525 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstThree0f3a.cpp.h \
526 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstVexMap1.cpp.h \
527 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstVexMap2.cpp.h \
528 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstVexMap3.cpp.h \
529 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInst3DNow.cpp.h
530 $(QUIET)$(call MSG_GENERATE,VBoxVMM,$@,VMMAll/IEMAllInst*.cpp.h)
531 $(QUIET)$(RM) -f -- "$@.tmp" "$@.tmp" "$@.sorted"
532 $(QUIET)$(MKDIR) -p -- "$(dir $@)"
533 $(call KB_FN_AUTO_CMD_DEPS_COMMANDS)
534 $(QUIET)$(SED) \
535 -e '/IEMOP_MNEMONIC\(\|[01234]\|[01234]EX\)(/!d' \
536 -e '/^ *# *define *IEMOP_MNEMONIC/d' \
537 -e ':look-for-end-of-invocation' \
538 -e '/)/bend-of-invocation' \
539 -e 'N' \
540 -e 'blook-for-end-of-invocation' \
541 -e ':end-of-invocation' \
542 -e 's/\n/ /g' \
543 -e 's/ */ /g' \
544 -e 's/^.*IEMOP_MNEMONIC\(\|[01234]\|[01234]EX\)(/IEM_DO_INSTR_STAT\1(/' \
545 -e 's/;.*$(DOLLAR)//' \
546 --output "$@.tmp" $(filter %.cpp.h,$^)
547# Windows sort does some kind of seeking. So, we must use a temporary file and kmk_cat to define and undefine our macros.
548 $(QUIET)$(REDIRECT) -wto "$@.sorted" -- sort "$@.tmp"
549 $(QUIET)$(APPEND) -nt "$@" \
550 '/* Warning autogenerated by VMM/Makefile.kmk. */ ' \
551 '#define IEM_DO_INSTR_STAT0(f,u,l,fd,fi) IEM_DO_INSTR_STAT(l, #l)' \
552 '#define IEM_DO_INSTR_STAT1(f,u,l,o1,fd,fi) IEM_DO_INSTR_STAT(l ## _ ## o1, #l " " #o1)' \
553 '#define IEM_DO_INSTR_STAT2(f,u,l,o1,o2,fd,fi) IEM_DO_INSTR_STAT(l ## _ ## o1 ## _ ## o2, #l " " #o1 "," #o2)' \
554 '#define IEM_DO_INSTR_STAT3(f,u,l,o1,o2,o3,fd,fi) IEM_DO_INSTR_STAT(l ## _ ## o1 ## _ ## o2 ## _ ## o3, #l " " #o1 "," #o2 "," #o3)' \
555 '#define IEM_DO_INSTR_STAT4(f,u,l,o1,o2,o3,o4,fd,fi) IEM_DO_INSTR_STAT(l ## _ ## o1 ## _ ## o2 ## _ ## o3 ## _ ## o4, #l " " #o1 "," #o2 "," #o3 "," #o4)' \
556 '#define IEM_DO_INSTR_STAT0EX(s,m,f,u,l,fd,fi) IEM_DO_INSTR_STAT(s,m)' \
557 '#define IEM_DO_INSTR_STAT1EX(s,m,f,u,l,o1,fd,fi) IEM_DO_INSTR_STAT(s,m)' \
558 '#define IEM_DO_INSTR_STAT2EX(s,m,f,u,l,o1,o2,fd,fi) IEM_DO_INSTR_STAT(s,m)' \
559 '#define IEM_DO_INSTR_STAT3EX(s,m,f,u,l,o1,o2,o3,fd,fi) IEM_DO_INSTR_STAT(s,m)' \
560 '#define IEM_DO_INSTR_STAT4EX(s,m,f,u,l,o1,o2,o3,o4,fd,fi) IEM_DO_INSTR_STAT(s,m)' \
561 ''
562 $(QUIET)$(REDIRECT) -ato "$@" -- $(CAT_EXT) "$@.sorted"
563 $(QUIET)$(APPEND) -n "$@" \
564 '' \
565 '#undef IEM_DO_INSTR_STAT0' \
566 '#undef IEM_DO_INSTR_STAT1' \
567 '#undef IEM_DO_INSTR_STAT2' \
568 '#undef IEM_DO_INSTR_STAT3' \
569 '#undef IEM_DO_INSTR_STAT4' \
570 '#undef IEM_DO_INSTR_STAT0EX' \
571 '#undef IEM_DO_INSTR_STAT1EX' \
572 '#undef IEM_DO_INSTR_STAT2EX' \
573 '#undef IEM_DO_INSTR_STAT3EX' \
574 '#undef IEM_DO_INSTR_STAT4EX' \
575 ''
576 $(QUIET)$(RM) -f -- "$@.tmp" "$@.sorted"
577 $(QUIET)$(CP) -v -f --changed -- "$@" "$(patsubst %.ts,%,$@)"
578
579foobar: $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMInstructionStatisticsTmpl.h
580
581ifdef VBOX_WITH_IEM_RECOMPILER
582 #
583 # Generate functions for the threaded recompiler and a modified instruction decoded.
584 # Note! Dependency order matters!
585 #
586 VBoxVMM_INTERMEDIATES += \
587 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.h \
588 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions1.cpp.h \
589 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions2.cpp.h \
590 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions3.cpp.h \
591 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions4.cpp.h
592 ifdef VBOX_WITH_IEM_NATIVE_RECOMPILER
593 VBoxVMM_INTERMEDIATES += \
594 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.h \
595 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.cpp.h
596 endif
597 VBoxVMM_CLEAN += \
598 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.h.ts \
599 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.h \
600 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.cpp.h \
601 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions1.cpp.h \
602 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions2.cpp.h \
603 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions3.cpp.h \
604 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions4.cpp.h \
605 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.h \
606 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.cpp.h
607 $(call KB_FN_AUTO_CMD_DEPS,$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.h.ts)
608 $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.h.ts \
609 +| $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.h \
610 +| $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.cpp.h \
611 +| $(if-expr defined(VBOX_WITH_IEM_NATIVE_RECOMPILER), $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.h,) \
612 +| $(if-expr defined(VBOX_WITH_IEM_NATIVE_RECOMPILER), $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.cpp.h,) \
613 +| $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions1.cpp.h \
614 +| $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions2.cpp.h \
615 +| $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions3.cpp.h \
616 +| $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions4.cpp.h: \
617 $(PATH_SUB_CURRENT)/VMMAll/IEMAllThrdPython.py \
618 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstPython.py \
619 $(PATH_SUB_CURRENT)/VMMAll/IEMAllN8vePython.py \
620 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstCommon.cpp.h \
621 $(if-expr !defined(IEM_WITHOUT_3DNOW) ,$(PATH_SUB_CURRENT)/VMMAll/IEMAllInst3DNow.cpp.h,) \
622 $(if-expr !defined(IEM_WITHOUT_THREE_0F_38),$(PATH_SUB_CURRENT)/VMMAll/IEMAllInstThree0f38.cpp.h,) \
623 $(if-expr !defined(IEM_WITHOUT_THREE_0F_3A),$(PATH_SUB_CURRENT)/VMMAll/IEMAllInstThree0f3a.cpp.h,) \
624 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstTwoByte0f.cpp.h \
625 $(if-expr !defined(IEM_WITHOUT_VEX), \
626 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstVexMap1.cpp.h \
627 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstVexMap2.cpp.h \
628 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstVexMap3.cpp.h,) \
629 $(PATH_SUB_CURRENT)/VMMAll/IEMAllInstOneByte.cpp.h
630 $(QUIET)$(call MSG_GENERATE,VBoxVMM,$@,VMMAll/IEMAllInst*.cpp.h)
631 $(QUIET)$(RM) -f -- \
632 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions1.cpp.h.ts" \
633 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions2.cpp.h.ts" \
634 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions3.cpp.h.ts" \
635 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions4.cpp.h.ts" \
636 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.cpp.h.ts" \
637 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.h.ts"
638 $(QUIET)$(MKDIR) -p -- "$(dir $@)"
639 $(call KB_FN_AUTO_CMD_DEPS_COMMANDS)
640 $(REDIRECT) -0 /dev/null -- $(VBOX_BLD_PYTHON) $< $(filter %.cpp.h,$^) \
641 --host-arch "$(KBUILD_TARGET_ARCH)" \
642 --out-thrd-funcs-hdr "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.h.ts" \
643 --out-thrd-funcs-cpp "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.cpp.h.ts" \
644 --out-mod-input1 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions1.cpp.h.ts" \
645 --out-mod-input2 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions2.cpp.h.ts" \
646 --out-mod-input3 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions3.cpp.h.ts" \
647 --out-mod-input4 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions4.cpp.h.ts" \
648 $(if-expr defined(VBOX_WITH_IEM_NATIVE_RECOMPILER), \
649 --native \
650 --out-n8ve-funcs-hdr "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.h.ts" \
651 --out-n8ve-funcs-cpp "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.cpp.h.ts" \
652 ,)
653 $(QUIET)$(CP) -v -f --changed -- \
654 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions1.cpp.h.ts" \
655 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions1.cpp.h"
656 $(QUIET)$(CP) -v -f --changed -- \
657 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions2.cpp.h.ts" \
658 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions2.cpp.h"
659 $(QUIET)$(CP) -v -f --changed -- \
660 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions3.cpp.h.ts" \
661 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions3.cpp.h"
662 $(QUIET)$(CP) -v -f --changed -- \
663 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions4.cpp.h.ts" \
664 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions4.cpp.h"
665 $(QUIET)$(CP) -v -f --changed -- \
666 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.cpp.h.ts" \
667 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.cpp.h"
668 $(QUIET)$(CP) -v -f --changed -- \
669 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.h.ts" \
670 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.h"
671 ifdef VBOX_WITH_IEM_NATIVE_RECOMPILER
672 $(QUIET)$(CP) -v -f --changed -- \
673 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.h.ts" \
674 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.h"
675 $(QUIET)$(CP) -v -f --changed -- \
676 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.cpp.h.ts" \
677 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.cpp.h"
678 endif
679 $(QUIET)$(RM) -f -- \
680 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions1.cpp.h.ts" \
681 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions2.cpp.h.ts" \
682 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions3.cpp.h.ts" \
683 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedInstructions4.cpp.h.ts" \
684 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.cpp.h.ts" \
685 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.h.ts" \
686 "$(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMNativeFunctions.cpp.h.ts"
687
688 foobared: $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMThreadedFunctions.h.ts
689
690endif
691
692if "$(KBUILD_TARGET)" == "win" && !defined(VBOX_ONLY_EXTPACKS_USE_IMPLIBS)
693 #
694 # Debug type info hack for VMCPU, VM and similar.
695 #
696 # The microsoft linker seems to be using the last occurence of the structures
697 # when writing the module PDB file. So, we put the fully complete structures
698 # in a library which is at the end of the library list.
699 #
700 VBoxVMM_LIBS += $(VBoxVMMPdbTypeHack_1_TARGET)
701 VBoxVMM_LDFLAGS += /Export:PdbTypeHack
702
703 LIBRARIES += VBoxVMMPdbTypeHack
704 VBoxVMMPdbTypeHack_TEMPLATE = $(VBoxVMM_TEMPLATE)
705 VBoxVMMPdbTypeHack_SOURCES = VMMAll/AllPdbTypeHack.cpp
706 VBoxVMMPdbTypeHack_DEFS = $(VBoxVMM_DEFS)
707 VBoxVMMPdbTypeHack_DEFS.win = $(VBoxVMM_DEFS.win)
708 VBoxVMMPdbTypeHack_DEFS.win.x86 = $(VBoxVMM_DEFS.win.x86)
709 VBoxVMMPdbTypeHack_DEFS.win.amd64 = $(VBoxVMM_DEFS.win.amd64)
710 VBoxVMMPdbTypeHack_INCS = $(VBoxVMM_INCS)
711 VBoxVMMPdbTypeHack_INTERMEDIATES = $(VBoxVMM_INTERMEDIATES)
712endif
713
714
715if1of ($(VBOX_LDR_FMT), pe lx)
716 #
717 # VMMR0Imp.lib
718 #
719 LIBRARIES += VMMR0Imp
720 VMMR0Imp_TEMPLATE = VBoxR0
721 VMMR0Imp_SOURCES = $(VMMR0Imp_0_OUTDIR)/VMMR0.def
722 VMMR0Imp_CLEAN = $(VMMR0Imp_0_OUTDIR)/VMMR0.def
723 ifeq ($(KBUILD_TARGET),win) # Experiment: Let's see how blunt the ones messing our NULL_THUNK_DATA entries on W10 are.
724 VMMR0Imp_POST_CMDS = $(KLIBTWEAKER_EXT) --clear-timestamps --fill-null_thunk_data $(out)
725 endif
726 $(call KB_FN_DO_PASS0_ON_TARGET,VMMR0Imp)
727
728 $(call KB_FN_AUTO_CMD_DEPS,$(VMMR0Imp_0_OUTDIR)/VMMR0.def)
729 $(VMMR0Imp_0_OUTDIR)/VMMR0.def: $(VMMR0Imp_DEFPATH)/VMMR0/VMMR0.def | $$(dir $$@)
730 $(call KB_FN_AUTO_CMD_DEPS_COMMANDS)
731 ifeq ($(VBOX_LDR_FMT),lx)
732 $(SED) \
733 -e '/not-os2/d' \
734 -e '/not-amd64/d' \
735 -e 's/^[ \t][ \t]*\([a-zA-Z]\)/ _\1/' \
736 -e 's/[ \t]DATA[ \t]*/ /' \
737 --output $@ $(VMMR0Imp_DEFPATH)/VMMR0/VMMR0.def
738 $(APPEND) "$@" ""
739 $(APPEND) "$@" " ___ehInit"
740 else
741 $(SED) \
742 -e '/not-win/d' \
743 -e '/not-$(KBUILD_TARGET_ARCH)/d' \
744 --output $@ $(VMMR0Imp_DEFPATH)/VMMR0/VMMR0.def
745 endif
746endif # R0: pe + lx
747
748
749#
750# VMMR3Imp.lib
751#
752IMPORT_LIBS += VMMR3Imp
753$(call VBOX_GENERATE_IMPORT_TARGET_FN,VMMR3Imp,VBoxVMM,VMMR3/VMMR3.def)
754
755
756#
757# VMMR0.r0
758#
759if defined(VBOX_WITH_R0_MODULES) && !defined(VBOX_ONLY_EXTPACKS)
760 ifdef VBOX_WITH_VBOXR0_AS_DLL
761 DLLS += VMMR0
762 else
763 SYSMODS += VMMR0
764 endif
765 VMMR0_TEMPLATE = VBoxR0
766 VMMR0_SYSSUFF = .r0
767
768 VMMR0_DEFS = VBOX_IN_VMM IN_VMM_R0 IN_RT_R0 IN_DIS DIS_CORE_ONLY IN_GVMM_R0 IN_GMM_R0 IN_INTNET_R0 \
769 $(VMM_COMMON_DEFS) RTASSERT_HAVE_SHOULD_PANIC
770 ## @todo eliminate IN_GVMM_R0 IN_GMM_R0
771 ifdef VBOX_WITH_PCI_PASSTHROUGH
772 VMMR0_DEFS += IN_PCIRAW_R0
773 endif
774 ifdef VBOX_WITH_TRIPLE_FAULT_HACK
775 VMMR0_DEFS += VBOX_WITH_TRIPLE_FAULT_HACK
776 endif
777 ifdef VBOX_WITH_IOMMU_AMD
778 VMMR0_DEFS += VBOX_WITH_IOMMU_AMD
779 endif
780 ifdef VBOX_WITH_DBGF_TRACING
781 VMMR0_DEFS += VBOX_WITH_DBGF_TRACING
782 endif
783 if1of ($(KBUILD_TARGET), darwin linux win)
784 VMMR0_DEFS += VMM_R0_TOUCH_FPU
785 endif
786 VMMR0_DEFS.win.amd64 = VBOX_WITH_KERNEL_USING_XMM
787
788 ifeq ($(VBOX_LDR_FMT),elf)
789 VMMR0_CXXFLAGS += -Wunused -Wunused-variable -Wno-unused-parameter
790 endif
791
792 # yasm versions not knowing about -Wno-segreg-in-64bit (including vanilla 1.3.0) would cause build failure.
793 if "$(VBOX_ASTOOL)" != "YASM" || defined("VBOX_YASM_Wno-segreg-in-64bit")
794 VMMR0_ASFLAGS.amd64 := -Werror
795 endif
796 VMMR0_ASFLAGS.x86 := -Werror
797
798 VMMR0_SDKS = VBoxSoftFloatR0
799
800 VMMR0_INCS = \
801 include \
802 $(VBoxVMM_0_OUTDIR)/CommonGenIncs
803
804 VMMR0_SOURCES = \
805 VBoxVMM.d \
806 VMMR0/CPUMR0.cpp \
807 VMMR0/CPUMR0A.asm \
808 VMMR0/DBGFR0.cpp \
809 VMMR0/DBGFR0Bp.cpp \
810 $(if-expr defined(VBOX_WITH_DBGF_TRACING), VMMR0/DBGFR0Tracer.cpp,) \
811 VMMR0/GIMR0.cpp \
812 VMMR0/GIMR0Hv.cpp \
813 VMMR0/GMMR0.cpp \
814 VMMR0/GVMMR0.cpp \
815 VMMR0/EMR0.cpp \
816 VMMR0/HMR0.cpp \
817 VMMR0/HMR0A.asm \
818 VMMR0/HMR0UtilA.asm \
819 VMMR0/HMVMXR0.cpp \
820 VMMR0/HMSVMR0.cpp \
821 VMMR0/IEMR0.cpp \
822 VMMR0/IOMR0.cpp \
823 VMMR0/IOMR0IoPort.cpp \
824 VMMR0/IOMR0Mmio.cpp \
825 VMMR0/PDMR0Device.cpp \
826 VMMR0/PDMR0DevHlp.cpp \
827 $(if-expr defined(VBOX_WITH_DBGF_TRACING), VMMR0/PDMR0DevHlpTracing.cpp,) \
828 VMMR0/PDMR0Driver.cpp \
829 VMMR0/PDMR0Queue.cpp \
830 VMMR0/PGMR0.cpp \
831 VMMR0/PGMR0Pool.cpp \
832 VMMR0/PGMR0SharedPage.cpp \
833 VMMR0/TMR0.cpp \
834 VMMR0/VMMR0.cpp \
835 VMMRZ/CPUMRZ.cpp \
836 VMMRZ/CPUMRZA.asm \
837 VMMRZ/VMMRZ.cpp \
838 VMMAll/APICAll.cpp \
839 VMMAll/CPUMAllCpuId.cpp \
840 VMMAll/CPUMAllRegs.cpp \
841 VMMAll/CPUMAllMsrs.cpp \
842 VMMAll/DBGFAll.cpp \
843 VMMAll/DBGFAllBp.cpp \
844 $(if-expr defined(VBOX_WITH_DBGF_TRACING), VMMAll/DBGFAllTracer.cpp,) \
845 VMMAll/EMAll.cpp \
846 VMMAll/GCMAll.cpp \
847 VMMAll/GIMAll.cpp \
848 VMMAll/GIMAllHv.cpp \
849 VMMAll/GIMAllKvm.cpp \
850 VMMAll/HMAll.cpp \
851 VMMAll/HMSVMAll.cpp \
852 VMMAll/HMVMXAll.cpp \
853 VMMAll/IEMAll.cpp \
854 VMMAll/IEMAllIntprTables1.cpp \
855 VMMAll/IEMAllIntprTables2.cpp \
856 VMMAll/IEMAllIntprTables3.cpp \
857 VMMAll/IEMAllIntprTables4.cpp \
858 $(if-expr !defined(IEM_WITHOUT_ASSEMBLY),VMMAll/IEMAllAImpl.asm,) \
859 VMMAll/IEMAllAImplC.cpp \
860 VMMAll/IEMAllCImpl.cpp \
861 VMMAll/IEMAllCImplSvmInstr.cpp \
862 VMMAll/IEMAllCImplVmxInstr.cpp \
863 VMMAll/IEMAllDbg.cpp \
864 VMMAll/IOMAll.cpp \
865 VMMAll/IOMAllMmioNew.cpp \
866 VMMAll/MMAll.cpp \
867 VMMAll/NEMAll.cpp \
868 VMMAll/PDMAll.cpp \
869 VMMAll/PDMAllCritSect.cpp \
870 VMMAll/PDMAllCritSectRw.cpp \
871 VMMAll/PDMAllCritSectBoth.cpp \
872 $(if-expr defined(VBOX_WITH_IOMMU_AMD) || defined(VBOX_WITH_IOMMU_INTEL), VMMAll/PDMAllIommu.cpp,) \
873 VMMAll/PDMAllQueue.cpp \
874 VMMAll/PDMAllTask.cpp \
875 VMMAll/PGMAll.cpp \
876 VMMAll/PGMAllHandler.cpp \
877 VMMAll/PGMAllPhys.cpp \
878 VMMAll/PGMAllPool.cpp \
879 VMMAll/SELMAll.cpp \
880 VMMAll/TMAll.cpp \
881 VMMAll/TMAllCpu.cpp \
882 VMMAll/TMAllReal.cpp \
883 VMMAll/TMAllVirtual.cpp \
884 VMMAll/TRPMAll.cpp \
885 VMMAll/VMAll.cpp \
886 VMMAll/VMMAll.cpp \
887 VMMAll/VMMAllA.asm
888 if1of ($(VBOX_LDR_FMT), pe lx)
889 VMMR0_SOURCES += $(VMMR0Imp_0_OUTDIR)/VMMR0.def
890 endif
891 ifdef VBOX_WITH_TRIPLE_FAULT_HACK
892 VMMR0_SOURCES += \
893 VMMR0/VMMR0TripleFaultHack.cpp \
894 VMMR0/VMMR0TripleFaultHackA.asm
895 endif
896 ifdef VBOX_WITH_NETSHAPER
897 VMMR0_SOURCES += \
898 VMMAll/PDMAllNetShaper.cpp
899 endif
900 VMMR0_SOURCES.amd64 = \
901 VMMR0/VMMR0JmpA-amd64.asm
902 VMMR0_SOURCES.x86 = \
903 VMMR0/VMMR0JmpA-x86.asm
904
905 VMMR0_LIBS = \
906 $(PATH_STAGE_LIB)/ServicesR0$(VBOX_SUFF_LIB) \
907 $(PATH_STAGE_LIB)/RuntimeR0$(VBOX_SUFF_LIB) \
908 $(PATH_STAGE_LIB)/DisasmR0$(VBOX_SUFF_LIB) \
909 $(VBOX_LIB_SUPR0)
910 ifdef VBOX_WITH_NATIVE_NEM
911 VMMR0_SOURCES.linux.amd64 += VMMR0/NEMR0Native-stubs.cpp
912 VMMR0_SOURCES.win.amd64 += VMMR0/NEMR0Native-stubs.cpp
913 VMMR0_SOURCES.darwin.amd64 += VMMR0/NEMR0Native-stubs.cpp
914 VMMR0_DEFS.darwin.amd64 += VBOX_WITH_NATIVE_NEM VBOX_WITH_NEM_R0
915 endif
916
917 $(call VBOX_SET_VER_INFO_R0,VMMR0,VirtualBox VMM - ring-0 context parts) # Version info / description.
918
919 if "$(USERNAME)" == "bird" && "$(KBUILD_TARGET)" == "win"
920 VMMR0_VMMAll/IEMAll.cpp_CXXFLAGS = /FAcs /Fa$(subst /,\\,$(outbase).cod)
921 VMMR0_VMMAll/IEMAllAImplC.cpp_CXXFLAGS = /FAcs /Fa$(subst /,\\,$(outbase).cod)
922 VMMR0_VMMAll/PGMAll.cpp_CXXFLAGS = /FAcs /Fa$(subst /,\\,$(outbase).cod)
923 VMMR0_CLEAN += $(addprefix $(VMMR0_0_OUTDIR)/VMMAll/, IEMAll.cod IEMAllAImplC.cod PGMAll.cod)
924 endif
925
926 VMMR0_INTERMEDIATES += $(VBoxVMM_0_OUTDIR)/CommonGenIncs/IEMInstructionStatisticsTmpl.h
927
928 if "$(KBUILD_TARGET)" == "win"
929 # Debug type info hack for VMCPU, VM and similar. See VBoxVMM for details.
930 VMMR0_LIBS += $(VMMR0PdbTypeHack_1_TARGET)
931 VMMR0_LDFLAGS += /Export:PdbTypeHack
932
933 LIBRARIES += VMMR0PdbTypeHack
934 VMMR0PdbTypeHack_TEMPLATE = $(VMMR0_TEMPLATE)
935 VMMR0PdbTypeHack_SOURCES = VMMAll/AllPdbTypeHack.cpp
936 VMMR0PdbTypeHack_DEFS = $(VMMR0_DEFS)
937 VMMR0PdbTypeHack_DEFS.win = $(VMMR0_DEFS.win)
938 VMMR0PdbTypeHack_DEFS.win.x86 = $(VMMR0_DEFS.win.x86)
939 VMMR0PdbTypeHack_DEFS.win.amd64 = $(VMMR0_DEFS.win.amd64)
940 VMMR0PdbTypeHack_INCS = $(VMMR0_INCS)
941 VMMR0PdbTypeHack_INTERMEDIATES = $(VMMR0_INTERMEDIATES)
942 endif
943
944 ifdef VBOX_WITH_KMOD_WRAPPED_R0_MODS
945 # Wrapper kmod for VMMR0.r0
946 INSTALLS.linux += vbox_vmmr0-src
947 vbox_vmmr0-src_INST = bin/src/vbox_vmmr0/
948 vbox_vmmr0-src_SYMLINKS = \
949 SUPWrapperMod-linux.c=>../common/SUPWrapperMod-linux.c \
950 Makefile-wrapper.gmk=>../common/Makefile-wrapper.gmk
951 vbox_vmmr0-src_SOURCES = \
952 $(PATH_ROOT)/src/VBox/HostDrivers/Support/linux/Makefile-vbox_vmmr0.gmk=>Makefile \
953 $(VMMR0_0_OUTDIR)/VMMR0.r0=>VMMR0.r0 \
954 $(VMMR0_0_OUTDIR)/VMMR0.debug=>VMMR0.debug
955 endif
956
957endif # defined(VBOX_WITH_R0_MODULES) && !defined(VBOX_ONLY_EXTPACKS)
958
959
960
961ifndef VBOX_ONLY_EXTPACKS
962 #
963 # SSMStandalone.lib/a for linking with VBoxSVC and other executables.
964 #
965 LIBRARIES += SSMStandalone
966 SSMStandalone_TEMPLATE = VBoxR3Exe
967 SSMStandalone_DEFS = VBOX_IN_VMM IN_VMM_R3 IN_VMM_STATIC SSM_STANDALONE CPUM_DB_STANDALONE $(VMM_COMMON_DEFS)
968 SSMStandalone_INCS = include
969 SSMStandalone_SOURCES = \
970 VMMR3/SSM.cpp \
971 VMMR3/CPUMR3Db.cpp
972endif # !VBOX_ONLY_EXTPACKS
973
974
975if !defined(VBOX_ONLY_EXTPACKS) \
976 && ( defined(VBOX_WITH_DTRACE_R3) \
977 || defined(VBOX_WITH_DTRACE_R0) \
978 || defined(VBOX_WITH_DTRACE_RC))
979 #
980 # Install the dtrace library files.
981 #
982 INSTALLS += VMMLibDTrace
983 VMMLibDTrace_INST = $(VBOX_INST_DTRACE_LIB)$(KBUILD_TARGET_ARCH)/
984 VMMLibDTrace_SOURCES = \
985 dtrace/lib/vbox-types.d \
986 dtrace/lib/$(KBUILD_TARGET_ARCH)/vbox-arch-types.d \
987 $(VMMLibDTrace_0_OUTDIR)/vm.d \
988 $(VMMLibDTrace_0_OUTDIR)/cpumctx.d \
989 $(VMMLibDTrace_0_OUTDIR)/cpum.d \
990 $(VMMLibDTrace_0_OUTDIR)/CPUMInternal.d \
991 $(VMMLibDTrace_0_OUTDIR)/x86.d
992 $(call KB_FN_DO_PASS0_ON_TARGET,VMMLibDTrace)
993
994
995 ##
996 # Turn the header $2 into the DTrace library script $1.
997 #
998 define def_vmm_lib_dtrace_preprocess
999 $$(call KB_FN_AUTO_CMD_DEPS,$$(VMMLibDTrace_0_OUTDIR)/$1)
1000 $$(VMMLibDTrace_0_OUTDIR)/$1: $2 $$(VBOX_VBOXCPP) | $$$$(dir $$$$@)
1001 $$(call KB_FN_AUTO_CMD_DEPS_COMMANDS)
1002 $$(QUIET)$$(call MSG_GENERATE,VMMLibDTrace,$$@,$2)
1003 $$(QUIET)$(VBOX_VBOXCPP) -d \
1004 -D VBOX_FOR_DTRACE_LIB \
1005 -D VBOX_FOR_DTRACE_LIB_$(toupper $(KBUILD_TARGET_ARCH)) \
1006 -D IN_RING0 \
1007 -D RT_C_DECLS_BEGIN= \
1008 -D RT_C_DECLS_END= \
1009 -D RT_GCC_EXTENSION= \
1010 -D 'RCPTRTYPE(a_Type)=RTRCPTR' \
1011 -D 'R3PTRTYPE(a_Type)=RTR3PTR' \
1012 -D 'R0PTRTYPE(a_Type)=a_Type' \
1013 -D 'AssertCompile(a_Expr)=' \
1014 -D 'AssertCompileSize(a_Stuct, a_Size)=' \
1015 -D 'bool=uint8_t' \
1016 $$(foreach def,\
1017 $$(DEFS) \
1018 $$(DEFS.$$(KBUILD_TARGET)) \
1019 $$(DEFS.$(KBUILD_TARGET_ARCH)) \
1020 $$(VMM_COMMON_DEFS) \
1021 $$(ARCH_BITS_DEFS)\
1022 ,-D '$$(def)') \
1023 $2 \
1024 $$@
1025 $$(QUIET)$$(CHMOD) 644 $$@
1026
1027 VMMLibDTrace_CLEAN += $(VMMLibDTrace_0_OUTDIR)/$1
1028 endef
1029 $(evalcall2 def_vmm_lib_dtrace_preprocess,vm.d,$(PATH_ROOT)/include/VBox/vmm/vm.h)
1030 $(evalcall2 def_vmm_lib_dtrace_preprocess,cpumctx.d,$(PATH_ROOT)/include/VBox/vmm/cpumctx.h)
1031 $(evalcall2 def_vmm_lib_dtrace_preprocess,cpum.d,$(PATH_ROOT)/include/VBox/vmm/cpum.h)
1032 $(evalcall2 def_vmm_lib_dtrace_preprocess,CPUMInternal.d,$(PATH_SUB_CURRENT)/include/CPUMInternal.h)
1033 $(evalcall2 def_vmm_lib_dtrace_preprocess,x86.d,$(PATH_ROOT)/include/iprt/x86.h)
1034
1035endif
1036
1037
1038
1039#
1040# For vmmGetSvnRev.
1041#
1042VMMAll/VMMAll.cpp_DEFS = VBOX_SVN_REV=$(VBOX_SVN_REV)
1043
1044#
1045# Disable annoying warnings about array subscript above array bounds in aPages[]
1046#
1047ifneq ($(KBUILD_TARGET),win)
1048 VMMR3/PGMPool.cpp_CXXFLAGS = $(VBOX_GCC_Wno-array_bounds)
1049 VMMAll/PGMAllPool.cpp_CXXFLAGS = $(VBOX_GCC_Wno-array_bounds)
1050 VMMAll/PGMAll.cpp_CXXFLAGS = -Wno-unused-function
1051 VMMAll/IEMAll.cpp_CXXFLAGS = -Wno-unused-function
1052 VMMR0/GMMR0.cpp_CXXFLAGS = -Wno-unused-value
1053endif
1054
1055#
1056# Always optimize the interpreter.
1057#
1058#if "$(KBUILD_TYPE)" == "release" || ($(USERNAME) != "bird" && $(USERNAME) != "aeichner")
1059if "$(KBUILD_TYPE)" == "release" || ($(USERNAME) != "aeichner")
1060 if1of ($(KBUILD_TARGET), win)
1061 # -noover is recognized despite the statement saying otherwise. It silences these warnings:
1062 # cl : Command line warning D9025 : overriding '/Od' with '/O2'
1063 # cl : Command line warning D9025 : overriding '/Oy-' with '/Oy'
1064 VMMAll/IEMAll.cpp_CXXFLAGS += -noover -O2xy
1065 VMMAll/IEMAllAImplC.cpp_CXXFLAGS += -noover -O2xy
1066 VMMAll/IEMAllCImpl.cpp_CXXFLAGS += -noover -O2xy
1067 VMMAll/IEMAllCImplSvmInstr.cpp_CXXFLAGS += -noover -O2xy
1068 VMMAll/IEMAllCImplVmxInstr.cpp_CXXFLAGS += -noover -O2xy
1069 VMMAll/IEMAllIntprTables1.cpp_CXXFLAGS += -noover -O2xy
1070 VMMAll/IEMAllIntprTables2.cpp_CXXFLAGS += -noover -O2xy
1071 VMMAll/IEMAllIntprTables3.cpp_CXXFLAGS += -noover -O2xy
1072 VMMAll/IEMAllIntprTables4.cpp_CXXFLAGS += -noover -O2xy
1073 else
1074 # Omitting the frame pointer results in larger code, but it might be worth it. (esp addressing vs ebp?)
1075 VMMAll/IEMAll.cpp_CXXFLAGS += -O2 -fomit-frame-pointer
1076 VMMAll/IEMAllCImpl.cpp_CXXFLAGS += -O2 -fomit-frame-pointer
1077 VMMAll/IEMAllCImplSvmInstr.cpp_CXXFLAGS += -O2 -fomit-frame-pointer
1078 VMMAll/IEMAllCImplVmxInstr.cpp_CXXFLAGS += -O2 -fomit-frame-pointer
1079 VMMAll/IEMAllIntprTables1.cpp_CXXFLAGS += -O2 -fomit-frame-pointer
1080 VMMAll/IEMAllIntprTables2.cpp_CXXFLAGS += -O2 -fomit-frame-pointer
1081 VMMAll/IEMAllIntprTables3.cpp_CXXFLAGS += -O2 -fomit-frame-pointer
1082 VMMAll/IEMAllIntprTables4.cpp_CXXFLAGS += -O2 -fomit-frame-pointer
1083 endif
1084endif # bird wants good stacks (aeichner as well)
1085
1086
1087# Alias the CPU database entries.
1088$(foreach base,$(notdir $(basename $(wildcard $(PATH_SUB_CURRENT)/VMMR3/cpus/*.h))), $(eval $(base).o $(base).obj: CPUMR3Db.o))
1089
1090
1091#
1092# Process python source(s).
1093#
1094BLDDIRS += $(PATH_TARGET)/pylint
1095
1096define def_vbox_vmm_py_check
1097 $(eval name:=$(basename $(notdir $(py))))
1098
1099 pylint: $(name)-py-phony.o
1100 $(name).o: $(name)-py-phony.o
1101 $(PATH_TARGET)/pylint/$(name).o $(name)-py-phony.o:: $(py) | $(PATH_TARGET)/pylint/
1102 ifdef VBOX_WITH_PYLINT
1103 $(QUIET2)$(call MSG_L1,Subjecting $(py) to pylint...)
1104 $(QUIET)$(REDIRECT) -C "$(dir $(py))" -E LC_ALL=C -- \
1105 $(VBOX_PYLINT) --rcfile=$(PATH_TARGET)/no-such-pylintrc \
1106 $$(VBOX_PYLINT_FLAGS) $$($(py)_VBOX_PYLINT_FLAGS) ./$(notdir $(py))
1107 endif
1108 $(QUIET)$(APPEND) -t "$(PATH_TARGET)/pylint/$(name).o"
1109
1110 TESTING += $(name)-py-phony.o
1111endef # def_vbox_vmm_py_check
1112
1113$(foreach py, $(addprefix $(PATH_SUB_CURRENT)/VMMAll/, IEMAllInstPython.py IEMAllThrdPython.py IEMAllN8vePython.py ) \
1114, $(eval $(def_vbox_vmm_py_check)))
1115
1116
1117include $(FILE_KBUILD_SUB_FOOTER)
1118
1119
1120# Alias the PGM templates to the object in which they are defined.
1121PGMInternal.o: PGM.o
1122
1123PGMAllBth.o PGMAllGst.o PGMAllShw.o \
1124PGMAllBth.obj PGMAllGst.obj PGMAllShw.obj: PGMAll.o
1125
1126PGMRCBth.o PGMRCGst.o PGMRCShw.o \
1127PGMRCBth.obj PGMRCGst.obj PGMRCShw.obj: PGMRC.o
1128
1129PGMPhysRWTmpl.o PGMPhysRWTmpl.obj: PGMPhys.o
1130
1131PGMInline.o PGMInline.obj: PGMDbg.o
1132
1133# Alias the IEM templates to the object in which they are instantiated.
1134IEMAllInst.cpp.o IEMAllInst.cpp.obj \
1135IEMAllInstCommon.cpp.o IEMAllInstCommon.cpp.obj \
1136IEMAllInstOneByte.cpp.o IEMAllInstOneByte.cpp.obj \
1137IEMAllInstTwoByte0f.cpp.o IEMAllInstTwoByte0f.cpp.obj \
1138IEMAllInstThree0f38.cpp.o IEMAllInstThree0f38.cpp.obj \
1139IEMAllInstThree0f3a.cpp.o IEMAllInstThree0f3a.cpp.obj \
1140IEMAllInstVexMap1.cpp.o IEMAllInstVexMap1.cpp.obj \
1141IEMAllInstVexMap2.cpp.o IEMAllInstVexMap2.cpp.obj \
1142IEMAllInstVexMap3.cpp.o IEMAllInstVexMap3.cpp.obj \
1143IEMAllInst3DNow.cpp.o IEMAllInst3DNow.cpp.obj: IEMAllInstInterpretOnly.o
1144
1145IEMInternal.o IEMInternal.obj: IEMAll.o
1146
1147IEMAllCImplStrInstr.cpp.o IEMAllCImplStrInstr.cpp.obj: IEMAllCImpl.o
1148
1149# Alias the NEM template to the objects where it is used:
1150NEMAllNativeTemplate-win.cpp.o: NEMR3Native-win.o
1151
1152# Alias the VMX template onto HMVMXR0 or darwin specific NEM object:
1153ifeq ($(KBUILD_TARGET),darwin)
1154 VMXAllTemplate.cpp.o: NEMR3Native-darwin.o
1155else
1156 VMXAllTemplate.cpp.o: HMVMXR0.o
1157endif
1158
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette