VirtualBox

source: vbox/trunk/src/VBox/Devices/Makefile.kmk@ 15963

Last change on this file since 15963 was 15963, checked in by vboxsync, 16 years ago

initial HPET device support (not yet functional)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 21.8 KB
Line 
1# $Id: Makefile.kmk 15963 2009-01-15 12:47:03Z vboxsync $
2## @file
3# Top-level makefile for the devices, drivers and services.
4#
5
6#
7# Copyright (C) 2006-2007 Sun Microsystems, Inc.
8#
9# This file is part of VirtualBox Open Source Edition (OSE), as
10# available from http://www.virtualbox.org. This file is free software;
11# you can redistribute it and/or modify it under the terms of the GNU
12# General Public License (GPL) as published by the Free Software
13# Foundation, in version 2 as it comes in the "COPYING" file of the
14# VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15# hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16#
17# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
18# Clara, CA 95054 USA or visit http://www.sun.com if you need
19# additional information or have any questions.
20#
21
22SUB_DEPTH = ../../..
23include $(KBUILD_PATH)/subheader.kmk
24
25
26VBOX_PATH_DEVICES_SRC := $(PATH_SUB_CURRENT)
27
28# Include sub-makefiles.
29include $(PATH_SUB_CURRENT)/PC/BIOS/Makefile.kmk
30ifdef VBOX_WITH_VMI
31 include $(PATH_SUB_CURRENT)/PC/VMI/Makefile.kmk
32endif
33include $(PATH_SUB_CURRENT)/Graphics/BIOS/Makefile.kmk
34include $(PATH_SUB_CURRENT)/testcase/Makefile.kmk
35include $(PATH_SUB_CURRENT)/Storage/testcase/Makefile.kmk
36ifndef VBOX_OSE
37 include $(PATH_SUB_CURRENT)/Storage/VBoxHDDFormats/Makefile.kmk
38endif
39ifdef VBOX_WITH_INTEL_PXE
40 include $(PATH_SUB_CURRENT)/PC/PXE/Makefile.kmk
41else
42 # Subdir with complex makefile.
43 SUBDIRS_LIBRARIES += $(VBOX_PATH_DEVICES_SRC)/PC/Etherboot-src
44 SUBDIRS_CLEAN += $(VBOX_PATH_DEVICES_SRC)/PC/Etherboot-src
45 # Disable the unsafe pass order optimizations.
46 KBUILD_SAFE_PARALLEL = 1
47endif
48
49#
50# Main targets.
51#
52LIBRARIES += DevicesR3 Drivers ServicesR0
53ifdef VBOX_USE_NAT
54LIBRARIES += NatAlias
55endif
56DLLS += VBoxDDU VBoxDD VBoxDD2
57SYSMODS += VBoxDDGC VBoxDD2GC VBoxDDR0 VBoxDD2R0
58
59
60#
61# VBoxDDU (shared object)
62#
63VBoxDDU_TEMPLATE = VBOXR3
64VBoxDDU_NAME = $(basename $(notdir $(LIB_DDU)))
65VBoxDDU_INST.darwin = $(INST_DLL) $(INST_TESTCASE)
66VBoxDDU_DEFS = IN_VBOXDDU
67ifdef VBOX_WITH_USB
68 VBoxDDU_DEFS += VBOX_WITH_USB IN_USBLIB
69 VBoxDDU_SDKS.win = WINPSDK W2K3DDK
70 ifdef VBOX_WITH_EHCI
71 VBoxDDU_DEFS += VBOX_WITH_EHCI
72 endif
73 ifdef VBOX_WITH_NEW_USB_CODE_ON_DARWIN
74 VBoxDDU_DEFS.darwin += VBOX_WITH_NEW_USB_CODE_ON_DARWIN
75 endif
76else
77 VBoxDDU_SDKS.win = WINPSDK
78endif
79VBoxDDU_SOURCES = \
80 Storage/VBoxHDD-new.cpp \
81 Storage/VDIHDDCore.cpp \
82 Storage/VHDHDDCore.cpp \
83 Storage/VmdkHDDCore.cpp \
84 Storage/RawHDDCore.cpp \
85 VBoxDDUDeps.cpp
86ifdef VBOX_WITH_USB
87 VBoxDDU_INCS.os2 += \
88 $(PATH_ROOT)/src/VBox/HostDrivers/VBoxUSB/os2
89endif
90VBoxDDU_LIBS = \
91 $(LIB_RUNTIME)
92ifdef VBOX_WITH_USB
93 VBoxDDU_LIBS += \
94 $(PATH_LIB)/USBLib$(VBOX_SUFF_LIB)
95endif
96ifeq ($(KBUILD_TARGET),l4)
97 VBoxDDU_LIBS += \
98 $(L4_LIBDIR)/libl4sys.p.a
99endif
100VBoxDDU_LDFLAGS.darwin = -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/VBoxDDU.dylib
101ifdef VBOX_WITH_USB
102 ifdef VBOX_WITH_NEW_USB_CODE_ON_DARWIN
103 VBoxDDU_LDFLAGS.darwin += -framework IOKit
104 endif
105endif
106
107VBoxDDU_LDFLAGS.linux = -Wl,--no-undefined
108VBoxDDU_LDFLAGS.l4 = -Wl,--no-undefined
109
110#
111# VBoxDDULnxHostR3 (Only needed for l4, currently for executing vditool on L4Linux.)
112#
113ifeq ($(KBUILD_TARGET),l4)
114 LIBRARIES += VBoxDDULnxHostR3
115 VBoxDDULnxHostR3_TEMPLATE = VBOXLNXHOSTR3LIB
116 VBoxDDULnxHostR3_DEFS = IN_VBOXDDU
117 VBoxDDULnxHostR3_SOURCES = $(VBoxDDU_SOURCES)
118endif
119
120#
121# VBoxDD (shared object)
122#
123VBoxDD_TEMPLATE = VBOXR3
124VBoxDD_SDKS.win = WINPSDK DXSDK W2K3DDK VBOX_NTDLL
125VBoxDD_SOURCES = \
126 Builtins.cpp
127VBoxDD_DEFS = VBOX_ACPI
128ifdef VBOX_WITH_USB
129 VBoxDD_DEFS += VBOX_WITH_USB IN_USB_R3
130 ifdef VBOX_WITH_EHCI
131 VBoxDD_DEFS += VBOX_WITH_EHCI
132 endif
133endif
134ifdef VBOX_WITH_AHCI
135 VBoxDD_DEFS += VBOX_WITH_AHCI
136endif
137ifdef VBOX_WITH_ISCSI
138 VBoxDD_DEFS += VBOX_WITH_ISCSI
139endif
140ifdef VBOX_WITH_E1000
141 VBoxDD_DEFS += VBOX_WITH_E1000
142endif
143ifdef VBOX_WITH_BUSLOGIC
144 VBoxDD_DEFS += VBOX_WITH_BUSLOGIC
145endif
146ifndef VBOX_OSE
147 VBoxDD_DEFS += VBOX_WITH_INIP
148endif
149ifdef VBOX_WITH_PDM_ASYNC_COMPLETION
150 VBoxDD_DEFS += VBOX_WITH_PDM_ASYNC_COMPLETION
151endif
152ifdef VBOX_WITH_SCSI
153 VBoxDD_DEFS += VBOX_WITH_SCSI
154endif
155ifdef VBOX_WITH_LSILOGIC
156 VBoxDD_DEFS += VBOX_WITH_LSILOGIC
157endif
158ifdef VBOX_WITH_FAULT_INJECTION
159 VBoxDD_DEFS += VBOX_WITH_FAULT_INJECTION
160endif
161VBoxDD_LIBS = \
162 $(PATH_LIB)/DevicesR3$(VBOX_SUFF_LIB) \
163 $(PATH_LIB)/Drivers$(VBOX_SUFF_LIB) \
164 $(PATH_LIB)/VgaDefBiosLogo$(VBOX_SUFF_LIB) \
165 $(LIB_VMM) \
166 $(LIB_RUNTIME)
167ifeq ($(KBUILD_TARGET),win)
168 VBoxDD_LIBS += \
169 $(LIB_DDU) \
170 $(PATH_LIB)/VBoxDD2.lib \
171 $(PATH_SDK_DXSDK_LIB)/dxguid.lib
172else
173 VBoxDD_LIBS += \
174 $(INSTARGET_VBoxDDU) \
175 $(INSTARGET_VBoxDD2)
176endif
177ifeq ($(KBUILD_TARGET),l4)
178 VBoxDD_LIBS += \
179 $(L4_LIBDIR)/libl4sys.p.a
180endif
181
182ifdef VBOX_USE_NAT
183VBoxDD_LIBS += $(PATH_LIB)/NatAlias$(VBOX_SUFF_LIB)
184endif
185
186ifdef VBOX_WITH_NETFLT
187VBoxDD_LIBS.win += $(PATH_LIB)/WinNetConfig.lib
188endif
189
190ifeq ($(KBUILD_TARGET),solaris)
191 VBoxDD_LIBS += adm
192 ifdef VBOX_WITH_SUID_WRAPPER
193 VBoxDD_LIBS += secdb
194 endif
195 ifdef VBOX_WITH_USB
196 VBoxDD_LIBS += aio
197 endif
198endif
199VBoxDD_LIBS.darwin += \
200 $(LIB_REM)
201VBoxDD_LDFLAGS.darwin = -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/VBoxDD.dylib \
202 -framework CoreAudio \
203 -framework IOKit \
204 -framework Carbon \
205 -framework DiskArbitration
206VBoxDD_LDFLAGS.linux = -Wl,--no-undefined
207VBoxDD_LDFLAGS.l4 = -Wl,--no-undefined
208
209#
210# VBoxDD2 (shared object)
211#
212VBoxDD2_TEMPLATE = VBOXR3
213VBoxDD2_DEFS = IN_VBOXDD2 \
214 $(if $(VBOX_WITH_VMI),VBOX_WITH_VMI,)
215VBoxDD2_INCS := \
216 $(PATH_SUB_CURRENT)
217VBoxDD2_SOURCES = \
218 Builtins2.cpp \
219 PC/DevAPIC.cpp
220VBoxDD2_LIBS = \
221 $(PATH_LIB)/PcBiosBin$(VBOX_SUFF_LIB) \
222 $(PATH_LIB)/VgaBiosBin$(VBOX_SUFF_LIB) \
223 $(PATH_LIB)/NetBiosBin$(VBOX_SUFF_LIB) \
224 $(if $(VBOX_WITH_VMI),$(PATH_LIB)/VmiBiosBin$(VBOX_SUFF_LIB)) \
225 $(LIB_VMM) \
226 $(LIB_RUNTIME)
227ifeq ($(KBUILD_TARGET),l4)
228VBoxDD2_LIBS += \
229 $(L4_LIBDIR)/libl4sys.p.a
230endif
231VBoxDD2_LIBS.darwin += $(LIB_REM)
232VBoxDD2_LDFLAGS.darwin = -install_name $(VBOX_DYLD_EXECUTABLE_PATH)/VBoxDD2.dylib
233VBoxDD2_LDFLAGS.linux = -Wl,--no-undefined
234VBoxDD2_LDFLAGS.l4 = -Wl,--no-undefined
235
236
237#
238# DevicesR3 (library)
239#
240DevicesR3_TEMPLATE = VBOXR3
241DevicesR3_SDKS.win = WINPSDK W2K3DDK
242DevicesR3_DEFS.darwin = VBOX_WITH_2X_4GB_ADDR_SPACE
243DevicesR3_DEFS += VBOX_HGCM_HOST_CODE \
244 $(if $(VBOX_WITH_VMI),VBOX_WITH_VMI,)
245DevicesR3_INCS := \
246 $(PATH_SUB_CURRENT)
247DevicesR3_SOURCES = \
248 Input/DevPS2.cpp \
249 Bus/DevPCI.cpp \
250 Graphics/DevVGA.cpp \
251 Storage/DevATA.cpp \
252 PC/DevPit-i8254.cpp \
253 PC/DevPIC.cpp \
254 PC/DevACPI.cpp \
255 PC/DevRTC.cpp \
256 PC/DevPcBios.cpp \
257 PC/DevPcArch.c \
258 VMMDev/VBoxDev.cpp \
259 VMMDev/VMMDevHGCM.cpp \
260 Network/DevPCNet.cpp \
261 Audio/DevIchAc97.cpp \
262 Audio/DevSB16.cpp \
263 PC/DevDMA.cpp \
264 Storage/fdc.c \
265 Serial/DevSerial.cpp \
266 Parallel/DevParallel.cpp
267
268ifdef VBOX_WITH_E1000
269 DevicesR3_DEFS += VBOX_WITH_E1000
270 DevicesR3_SOURCES += \
271 Network/DevE1000.cpp \
272 Network/DevE1000Phy.cpp \
273 Network/DevEEPROM.cpp
274endif
275
276ifndef VBOX_OSE
277DevicesR3_INCS += \
278 Network/lwip/src/include \
279 Network/lwip/src/include/ipv4 \
280 Network/lwip/vbox/include
281DevicesR3_SOURCES += \
282 Network/lwip/src/api/api_lib.c \
283 Network/lwip/src/api/api_msg.c \
284 Network/lwip/src/api/err.c \
285 Network/lwip/src/api/sockets.c \
286 Network/lwip/src/api/tcpip.c \
287 Network/lwip/src/core/tcp_in.c \
288 Network/lwip/src/core/dhcp.c \
289 Network/lwip/src/core/inet.c \
290 Network/lwip/src/core/mem.c \
291 Network/lwip/src/core/memp.c \
292 Network/lwip/src/core/netif.c \
293 Network/lwip/src/core/pbuf.c \
294 Network/lwip/src/core/raw.c \
295 Network/lwip/src/core/stats.c \
296 Network/lwip/src/core/sys.c \
297 Network/lwip/src/core/tcp.c \
298 Network/lwip/src/core/ipv4/ip_addr.c \
299 Network/lwip/src/core/ipv4/icmp.c \
300 Network/lwip/src/core/ipv4/ip.c \
301 Network/lwip/src/core/ipv4/ip_frag.c \
302 Network/lwip/src/core/tcp_out.c \
303 Network/lwip/src/core/udp.c \
304 Network/lwip/src/netif/etharp.c \
305 Network/lwip/vbox/sys_arch.c \
306 Network/DevINIP.cpp
307DevicesR3_DEFS += VBOX_WITH_INIP
308endif
309
310ifdef VBOX_WITH_AHCI
311DevicesR3_DEFS += VBOX_WITH_AHCI IN_AHCI_R3
312DevicesR3_SOURCES += \
313 Storage/DevAHCI.cpp \
314 Storage/ATAController.cpp
315endif
316
317ifdef VBOX_WITH_BUSLOGIC
318DevicesR3_DEFS += VBOX_WITH_BUSLOGIC
319DevicesR3_SOURCES += \
320 Storage/DevBusLogic.cpp \
321 Storage/VBoxSCSI.cpp
322endif
323
324ifdef VBOX_WITH_LSILOGIC
325DevicesR3_DEFS += VBOX_WITH_LSILOGIC
326DevicesR3_SOURCES += \
327 Storage/DevLsiLogicSCSI.cpp
328endif
329
330ifdef VBOX_WITH_HPET
331DevicesR3_DEFS += VBOX_WITH_HPET
332DevicesR3_SOURCES += PC/DevHPET.cpp
333endif
334
335ifdef VBOX_WITH_USB
336DevicesR3_DEFS += VBOX_WITH_USB IN_USB_R3
337
338DevicesR3_SOURCES += \
339 USB/DevOHCI.cpp
340
341 ifdef VBOX_WITH_EHCI
342 DevicesR3_DEFS += VBOX_WITH_EHCI
343 DevicesR3_SOURCES += \
344 USB/DevEHCI.cpp
345 endif
346
347endif
348
349DevicesR3_DEFS += VBOX_WITH_HGCM
350DevicesR3_DEFS.linux += _GNU_SOURCE
351DevicesR3_DEFS.l4 += _GNU_SOURCE
352
353# DevACPI.cpp needs vboxaml.hex which we generate from PC/vbox.dsl. (bird: What's vboxaml.aml?)
354DevicesR3_CLEAN += $(PATH_DevicesR3)/vboxaml.hex $(PATH_DevicesR3)/vboxaml.aml
355PC/DevACPI.cpp_DEPS = $(PATH_DevicesR3)/vboxaml.hex
356PC/DevACPI.cpp_INCS = $(PATH_DevicesR3)
357
358$$(PATH_DevicesR3)/vboxaml.hex: $(PATH_SUB_CURRENT)/PC/vbox.dsl | $$(dir $$@)
359 $(call MSG_TOOL,iasl,DevicesR3,$<,$@)
360 $(QUIET)$(VBOX_IASLCMD) -tc -vs -p $@ $<
361
362# For finding PCIInternal.h from VBox/pci.h.
363Bus/DevPCI.cpp_INCS = Bus
364
365# For finding and generating vbetables.h (see Graphics/BIOS/Makefile.kmk).
366Graphics/DevVGA.cpp_INCS = $(PATH_VgaBiosBin)
367Graphics/DevVGA.cpp_DEPS = $(PATH_VgaBiosBin)/vbetables.h
368
369
370
371#
372# VBoxDDGC (sysmod)
373#
374VBoxDDGC_TEMPLATE = VBOXGC
375VBoxDDGC_SYSSUFF = .gc
376VBoxDDGC_DEFS.darwin = VBOX_WITH_2X_4GB_ADDR_SPACE
377VBoxDDGC_DEFS =
378VBoxDDGC_INCS := \
379 $(PATH_SUB_CURRENT)
380VBoxDDGC_SOURCES = \
381 Bus/DevPCI.cpp \
382 Graphics/DevVGA.cpp \
383 Input/DevPS2.cpp \
384 PC/DevACPI.cpp \
385 PC/DevPit-i8254.cpp \
386 PC/DevPIC.cpp \
387 PC/DevRTC.cpp \
388 Storage/DevATA.cpp \
389 Network/DevPCNet.cpp \
390 Serial/DevSerial.cpp \
391 Parallel/DevParallel.cpp
392
393ifdef VBOX_WITH_E1000
394 VBoxDDGC_DEFS += VBOX_WITH_E1000
395 VBoxDDGC_SOURCES += \
396 Network/DevE1000.cpp \
397 Network/DevE1000Phy.cpp
398endif
399
400ifdef VBOX_WITH_USB
401VBoxDDGC_DEFS += VBOX_WITH_USB IN_USB_GC
402VBoxDDGC_SOURCES += \
403 USB/DevOHCI.cpp
404
405 ifdef VBOX_WITH_EHCI
406 VBoxDDGC_DEFS += VBOX_WITH_EHCI
407 VBoxDDGC_SOURCES += \
408 USB/DevEHCI.cpp
409 endif
410
411endif
412
413ifdef VBOX_WITH_AHCI
414VBoxDDGC_DEFS += VBOX_WITH_AHCI IN_AHCI_GC
415VBoxDDGC_SOURCES += \
416 Storage/DevAHCI.cpp \
417 Storage/ATAController.cpp
418endif
419
420ifdef VBOX_WITH_BUSLOGIC
421VBoxDDGC_DEFS += VBOX_WITH_BUSLOGIC
422VBoxDDGC_SOURCES += \
423 Storage/DevBusLogic.cpp
424endif
425
426ifdef VBOX_WITH_LSILOGIC
427VBoxDDGC_DEFS += VBOX_WITH_LSILOGIC
428VBoxDDGC_SOURCES += \
429 Storage/DevLsiLogicSCSI.cpp
430endif
431
432ifdef VBOX_WITH_HPET
433VBoxDDGC_DEFS += VBOX_WITH_HPET
434VBoxDDGC_SOURCES += PC/DevHPET.cpp
435endif
436
437ifeq ($(VBOX_LDR_FMT32),pe)
438VBoxDDGC_LDFLAGS = -Entry:vgaMMIOWrite
439endif
440if1of ($(VBOX_LDR_FMT32), pe lx)
441VBoxDDGC_LIBS = \
442 $(PATH_LIB)/VMMGCBuiltin$(VBOX_SUFF_LIB) \
443 $(PATH_LIB)/VMMGCImp$(VBOX_SUFF_LIB)
444endif
445
446
447#
448# VBoxDDR0 (sysmod)
449#
450VBoxDDR0_TEMPLATE = VBOXR0
451VBoxDDR0_SYSSUFF = .r0
452VBoxDDR0_DEFS.darwin = VBOX_WITH_2X_4GB_ADDR_SPACE_IN_R0 VBOX_WITH_2X_4GB_ADDR_SPACE
453VBoxDDR0_DEFS = IN_RT_R0
454VBoxDDR0_INCS := \
455 $(PATH_SUB_CURRENT)
456VBoxDDR0_SOURCES = \
457 Bus/DevPCI.cpp \
458 Graphics/DevVGA.cpp \
459 Input/DevPS2.cpp \
460 PC/DevACPI.cpp \
461 PC/DevPit-i8254.cpp \
462 PC/DevPIC.cpp \
463 PC/DevRTC.cpp \
464 Storage/DevATA.cpp \
465 Network/DevPCNet.cpp \
466 Serial/DevSerial.cpp \
467 Parallel/DevParallel.cpp
468
469ifdef VBOX_WITH_E1000
470 VBoxDDR0_DEFS += VBOX_WITH_E1000
471 VBoxDDR0_SOURCES += \
472 Network/DevE1000.cpp \
473 Network/DevE1000Phy.cpp
474endif
475
476ifdef VBOX_WITH_USB
477VBoxDDR0_DEFS += VBOX_WITH_USB IN_USB_R0
478VBoxDDR0_SOURCES += \
479 USB/DevOHCI.cpp
480
481 ifdef VBOX_WITH_EHCI
482 VBoxDDR0_DEFS += VBOX_WITH_EHCI
483 VBoxDDR0_SOURCES += \
484 USB/DevEHCI.cpp
485 endif
486endif
487
488ifdef VBOX_WITH_AHCI
489VBoxDDR0_DEFS += VBOX_WITH_AHCI IN_AHCI_R0
490VBoxDDR0_SOURCES += \
491 Storage/DevAHCI.cpp \
492 Storage/ATAController.cpp
493endif
494
495ifdef VBOX_WITH_BUSLOGIC
496VBoxDDR0_DEFS += VBOX_WITH_BUSLOGIC
497VBoxDDR0_SOURCES += \
498 Storage/DevBusLogic.cpp
499endif
500
501ifdef VBOX_WITH_LSILOGIC
502VBoxDDR0_DEFS += VBOX_WITH_LSILOGIC
503VBoxDDR0_SOURCES += \
504 Storage/DevLsiLogicSCSI.cpp
505endif
506
507ifdef VBOX_WITH_HPET
508VBoxDDR0_DEFS += VBOX_WITH_HPET
509VBoxDDR0_SOURCES += PC/DevHPET.cpp
510endif
511
512ifeq ($(VBOX_LDR_FMT32),pe)
513VBoxDDR0_LDFLAGS = -Entry:vgaMMIOWrite
514endif
515if1of ($(VBOX_LDR_FMT), pe lx)
516VBoxDDR0_LIBS = $(PATH_LIB)/VMMR0Imp$(VBOX_SUFF_LIB)
517endif
518
519#
520# VBoxDD2GC (LGPL sysmod)
521#
522VBoxDD2GC_TEMPLATE = VBOXGC
523VBoxDD2GC_DEFS =
524VBoxDD2GC_SYSSUFF = .gc
525VBoxDD2GC_INCS := \
526 $(PATH_SUB_CURRENT)
527VBoxDD2GC_SOURCES = \
528 PC/DevAPIC.cpp
529ifeq ($(VBOX_LDR_FMT32),pe)
530VBoxDD2GC_LDFLAGS = -Entry:apicMMIOWrite
531endif
532if1of ($(VBOX_LDR_FMT32), pe lx)
533VBoxDD2GC_LIBS = \
534 $(PATH_LIB)/VMMGCBuiltin$(VBOX_SUFF_LIB) \
535 $(PATH_LIB)/VMMGCImp$(VBOX_SUFF_LIB)
536endif
537
538
539#
540# VBoxDD2R0 (LGPL sysmod)
541#
542VBoxDD2R0_TEMPLATE = VBOXR0
543VBoxDD2R0_DEFS = IN_RT_R0
544VBoxDD2R0_SYSSUFF = .r0
545VBoxDD2R0_INCS := \
546 $(PATH_SUB_CURRENT)
547VBoxDD2R0_SOURCES = \
548 PC/DevAPIC.cpp
549ifeq ($(VBOX_LDR_FMT),pe)
550VBoxDD2R0_LDFLAGS = -Entry:apicMMIOWrite
551endif
552if1of ($(VBOX_LDR_FMT), pe lx)
553VBoxDD2R0_LIBS = $(PATH_LIB)/VMMR0Imp$(VBOX_SUFF_LIB)
554endif
555
556
557#
558# Drivers (library)
559#
560ifeq ($(KBUILD_TARGET),l4) # We are using real Linux headers, not the cleaned up user space ones
561Drivers_TEMPLATE = VBOXR3NP
562else
563Drivers_TEMPLATE = VBOXR3
564endif
565Drivers_SDKS.win = WINPSDK W2K3DDK
566Storage/DrvHostDVD.cpp_SDKS.win = W2K3DDK
567Drivers_DEFS.win += _WIN32_WINNT=0x0510
568Drivers_DEFS = IN_IDE_R3
569ifdef VBOX_WITH_NETFLT
570Drivers_DEFS += VBOX_WITH_NETFLT
571endif
572ifdef VBOX_WITH_FAULT_INJECTION
573Drivers_DEFS += VBOX_WITH_FAULT_INJECTION
574endif
575Drivers_INCS := \
576 $(PATH_SUB_CURRENT) \
577 Network/slirp
578Drivers_SOURCES = \
579 Audio/audio.c \
580 Audio/audiosniffer.c \
581 Audio/mixeng.c \
582 Audio/noaudio.c \
583 Input/DrvKeyboardQueue.cpp \
584 Input/DrvMouseQueue.cpp \
585 Network/DrvIntNet.cpp \
586 PC/DrvACPI.cpp \
587 Serial/DrvChar.cpp \
588 Serial/DrvNamedPipe.cpp \
589 Storage/DrvBlock.cpp \
590 Storage/DrvHostBase.cpp \
591 Storage/DrvHostDVD.cpp \
592 Storage/DrvHostFloppy.cpp \
593 Storage/DrvMediaISO.cpp \
594 Storage/DrvRawImage.cpp \
595 Storage/Debug.cpp \
596 Storage/DrvVD.cpp \
597 Network/DrvNetSniffer.cpp \
598 Network/Pcap.cpp
599
600VBOX_SLIRP_SOURCES = \
601 Network/DrvNAT.cpp \
602 Network/slirp/bootp.c \
603 Network/slirp/cksum.c \
604 Network/slirp/debug.c \
605 Network/slirp/if.c \
606 Network/slirp/ip_icmp.c \
607 Network/slirp/ip_input.c \
608 Network/slirp/ip_output.c \
609 Network/slirp/mbuf.c \
610 Network/slirp/misc.c \
611 Network/slirp/sbuf.c \
612 Network/slirp/slirp.c \
613 Network/slirp/socket.c \
614 Network/slirp/tcp_input.c \
615 Network/slirp/tcp_output.c \
616 Network/slirp/tcp_subr.c \
617 Network/slirp/tcp_timer.c \
618 Network/slirp/tftp.c \
619 Network/slirp/udp.c
620
621# some day will be deleted
622VBOX_WITH_SIMPLIFIED_SLIRP_SYNC=1
623
624Drivers_SOURCES += $(VBOX_SLIRP_SOURCES)
625define def_vbox_slirp_cflags
626 $(file)_DEFS += \
627 $(if $(VBOX_WITH_SIMPLIFIED_SLIRP_SYNC), VBOX_WITH_SIMPLIFIED_SLIRP_SYNC) \
628 $(if $(VBOX_WITH_SLIRP_MEMORY_CHECK),RTMEM_WRAP_TO_EF_APIS,) \
629 $(if $(VBOX_WITH_DEBUG_NAT_SOCKETS),VBOX_WITH_DEBUG_NAT_SOCKETS,)
630 ifeq ($(KBUILD_TARGET),win)
631 $(file)_CFLAGS = -wd4018
632 else
633 $(file)_CFLAGS = -Wno-sign-compare
634 endif
635endef
636$(foreach file,$(VBOX_SLIRP_SOURCES),$(eval $(def_vbox_slirp_cflags)))
637
638# -- OS specific --
639
640ifeq ($(KBUILD_TARGET),darwin)
641Drivers_SOURCES := $(filter-out \
642 Storage/DrvHostRaw% \
643 Storage/DrvHostFloppy% \
644 , $(Drivers_SOURCES)) \
645 Audio/coreaudio.c
646Drivers_SOURCES.darwin = \
647 Serial/DrvHostSerial.cpp
648endif # darwin
649
650ifeq ($(KBUILD_TARGET),freebsd)
651Drivers_SOURCES := $(filter-out \
652 Storage/DrvHost% \
653 , $(Drivers_SOURCES))
654Drivers_SOURCES.freebsd =
655endif # freebsd
656
657
658ifeq ($(KBUILD_TARGET),l4)
659Drivers_SOURCES = \
660 Input/DrvMouseQueue.cpp \
661 Input/DrvKeyboardQueue.cpp \
662 Storage/DrvBlock.cpp \
663 Storage/DrvMediaISO.cpp \
664 Storage/DrvRawImage.cpp \
665 Storage/DrvHostBase.cpp \
666 Storage/DrvHostDVD.cpp \
667 Storage/DrvVD.cpp \
668 PC/DrvACPI.cpp \
669 Network/DrvIntNet.cpp \
670 Network/DrvNetSniffer.cpp \
671 Network/Pcap.cpp \
672 Audio/audio.c \
673 Audio/mixeng.c \
674 Audio/noaudio.c \
675 Audio/audiosniffer.c
676
677Drivers_SOURCES.l4 = \
678 Network/DrvTAP.cpp \
679 Audio/ossaudio.c
680endif # l4
681
682Drivers_SOURCES.linux = \
683 Network/DrvTAP.cpp \
684 Audio/ossaudio.c \
685 Parallel/DrvHostParallel.cpp \
686 Serial/DrvHostSerial.cpp
687
688ifeq ($(KBUILD_TARGET),os2)
689Drivers_SOURCES := $(filter-out \
690 Storage/DrvHost% \
691 , $(Drivers_SOURCES))
692Drivers_SOURCES.os2 = \
693 Network/DrvTAPOs2.cpp
694endif
695
696ifeq ($(KBUILD_TARGET),solaris)
697Drivers_SOURCES := $(filter-out \
698 Storage/DrvHost% \
699 , $(Drivers_SOURCES))
700Drivers_SOURCES.solaris = \
701 Audio/solaudio.c \
702 $(if $(VBOX_SOLARIS_10),,Network/DrvTAP.cpp) \
703 Storage/DrvHostBase.cpp \
704 Storage/DrvHostDVD.cpp \
705 Serial/DrvHostSerial.cpp
706 ifdef VBOX_WITH_CROSSBOW
707 Drivers_SOURCES += Network/solaris/vbox-libdlpi.cpp
708 Drivers_DEFS += VBOX_WITH_CROSSBOW
709 endif
710 ifdef VBOX_WITH_SUID_WRAPPER
711 Drivers_DEFS += VBOX_WITH_SUID_WRAPPER
712 endif
713endif
714
715Drivers_SOURCES.win = \
716 Network/DrvTAPWin.cpp \
717 Audio/dsoundaudio.c \
718 Serial/DrvHostSerial.cpp
719
720if defined(VBOX_WITH_NETFLT)
721 if defined(VBOX_NETFLT_ONDEMAND_BIND)
722 Drivers_DEFS.win += VBOX_NETFLT_ONDEMAND_BIND
723 endif
724 Drivers_SOURCES.win += Network/win/DrvIntNet-win.cpp
725endif
726
727# -- features --
728
729ifdef VBOX_WITH_ISCSI
730 VBoxDDU_SOURCES += \
731 Storage/ISCSIHDDCore.cpp
732 VBoxDDU_DEFS += VBOX_WITH_ISCSI
733 Storage/DrvVD.cpp_INCS = \
734 Network/lwip/src/include \
735 Network/lwip/src/include/ipv4 \
736 Network/lwip/vbox/include
737endif # VBOX_WITH_ISCSI
738
739ifdef VBOX_WITH_ALSA
740 Drivers_DEFS.linux += VBOX_WITH_ALSA
741 Drivers_SOURCES.linux+= \
742 Audio/alsaaudio.c \
743 Audio/alsa_stubs.c
744# VBoxDD_LIBS.linux += asound
745endif
746
747ifdef VBOX_WITH_PULSE
748 Drivers_DEFS.linux += VBOX_WITH_PULSE
749 Drivers_SOURCES.linux+= \
750 Audio/pulseaudio.c \
751 Audio/pulse_stubs.c
752# VBoxDD_LIBS.linux += pulse
753endif
754
755ifdef VBOX_WITH_USB
756 Drivers_DEFS += VBOX_WITH_USB IN_USB_R3
757 Drivers_SOURCES += \
758 USB/DrvVUSBRootHub.cpp \
759 USB/VUSBDevice.cpp \
760 USB/VUSBUrb.cpp
761 ifdef VBOX_WITH_VRDP
762 Drivers_DEFS += VBOX_WITH_VRDP
763 Drivers_SOURCES += \
764 USB/vrdp/USBProxyDevice-vrdp.cpp
765 endif
766
767 Drivers_DEFS.darwin += VUSB_HAVE_USBPROXY_DEVICE
768 ifdef VBOX_WITH_NEW_USB_CODE_ON_DARWIN
769 Drivers_DEFS.darwin += VBOX_WITH_NEW_USB_CODE_ON_DARWIN
770 endif
771 Drivers_SOURCES.darwin += \
772 USB/USBProxyDevice.cpp \
773 USB/darwin/USBProxyDevice-darwin.cpp
774
775 Drivers_DEFS.linux += \
776 VUSB_HAVE_USBPROXY_DEVICE \
777 $(if $(VBOX_WITHOUT_LINUX_COMPILER_H),VBOX_WITHOUT_LINUX_COMPILER_H,) \
778 $(if $(VBOX_USB_WITH_SYSFS),VBOX_USB_WITH_SYSFS,)
779 Drivers_SOURCES.linux += \
780 USB/USBProxyDevice.cpp \
781 USB/linux/USBProxyDevice-linux.cpp
782
783 Drivers_DEFS.l4 += VUSB_HAVE_USBPROXY_DEVICE
784 Drivers_SOURCES.l4 += \
785 USB/USBProxyDevice.cpp \
786 USB/linux/USBProxyDevice-linux.cpp
787
788 Drivers_DEFS.os2 += VUSB_HAVE_USBPROXY_DEVICE
789 Drivers_INCS.os2 += $(PATH_ROOT)/src/VBox/HostDrivers/VBoxUSB/os2
790 Drivers_SOURCES.os2 += \
791 USB/USBProxyDevice.cpp \
792 USB/os2/USBProxyDevice-os2.cpp
793
794 Drivers_DEFS.win += VUSB_HAVE_USBPROXY_DEVICE
795 Drivers_SOURCES.win += \
796 USB/USBProxyDevice.cpp \
797 USB/win/USBProxyDevice-win.cpp
798
799 Drivers_DEFS.solaris += VUSB_HAVE_USBPROXY_DEVICE
800 Drivers_SOURCES.solaris += \
801 USB/USBProxyDevice.cpp \
802 USB/solaris/USBProxyDevice-solaris.cpp
803endif # VBOX_WITH_USB
804
805ifdef VBOX_WITH_PDM_ASYNC_COMPLETION
806 Drivers_DEFS += VBOX_WITH_PDM_ASYNC_COMPLETION
807 Drivers_SOURCES += \
808 Storage/DrvRawImageAsync.cpp \
809 Storage/DrvTransportAsync.cpp
810endif #VBOX_WITH_PDM_ASYNC_COMPLETION
811
812ifdef VBOX_WITH_SCSI
813 Drivers_DEFS += VBOX_WITH_SCSI
814 Drivers_SOURCES += \
815 Storage/DrvSCSI.cpp
816 Drivers_SOURCES.linux += \
817 Storage/DrvSCSIHost.cpp
818endif # VBOX_WITH_SCSI
819
820ifdef VBOX_WITH_FAULT_INJECTION
821 Drivers_DEFS += VBOX_WITH_FAULT_INJECTION
822 Drivers_SOURCES += \
823 Storage/DrvFaultInject.cpp
824endif # VBOX_WITH_FAULT_INJECTION
825
826#
827# Ring-0 Services (library, linked into VMMR0.r0)
828#
829ServicesR0_TEMPLATE = VBOXR0
830ServicesR0_DEFS = IN_INTNET_R0 IN_RT_R0
831ServicesR0_SOURCES = \
832 Network/SrvIntNetR0.cpp
833
834if defined(VBOX_WITH_NETFLT)
835 ServicesR0_SOURCES.win.amd64 += Network/win/SrvIntNetR0A-win.asm
836 ServicesR0_DEFS.win.amd64 += RT_WITH_W64_UNWIND_HACK
837endif
838
839
840#
841# Internal Networking - Ring-3 Testcase for the Ring-0 code (a bit hackish).
842#
843ifdef VBOX_WITH_TESTCASES
844 PROGRAMS += tstIntNetR0
845 tstIntNetR0_TEMPLATE = VBOXR3TSTEXE
846 tstIntNetR0_DEFS = IN_INTNET_R0
847 tstIntNetR0_SOURCES = \
848 Network/testcase/tstIntNetR0.cpp
849endif
850
851#
852# Internal Networking - Ring-3 Testcase for the Ring-0 code (a bit hackish).
853#
854ifdef VBOX_WITH_TESTCASES
855 PROGRAMS += tstIntNet-1
856 tstIntNet-1_TEMPLATE = VBOXR3TSTEXE
857 tstIntNet-1_SOURCES = \
858 Network/testcase/tstIntNet-1.cpp \
859 Network/Pcap.cpp
860endif
861
862
863#
864# EEPROM device unit test requires cppunit
865#
866ifdef VBOX_WITH_CPPUNIT_TESTCASES
867ifdef VBOX_WITH_E1000
868 PROGRAMS += tstDevEEPROM
869 tstDevEEPROM_TEMPLATE = VBOXCPPUNITEXE
870 tstDevEEPROM_SOURCES = \
871 Network/testcase/tstDevEEPROM.cpp
872 tstDevEEPROM_LIBS = \
873 $(TARGET_DevicesR3)
874 PROGRAMS += tstDevPhy
875 tstDevPhy_TEMPLATE = VBOXCPPUNITEXE
876 tstDevPhy_SOURCES = \
877 Network/testcase/tstDevPhy.cpp \
878 Network/DevE1000Phy.cpp
879 tstDevPhy_DEFS = PHY_UNIT_TEST
880endif
881endif
882
883include $(KBUILD_PATH)/subfooter.kmk
884
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