]> git.proxmox.com Git - mirror_qemu.git/blame - Makefile.target
compile common code once
[mirror_qemu.git] / Makefile.target
CommitLineData
626df76a
FB
1include config.mak
2
0b0babc6
FB
3TARGET_BASE_ARCH:=$(TARGET_ARCH)
4ifeq ($(TARGET_ARCH), x86_64)
5TARGET_BASE_ARCH:=i386
6endif
540635ba
TS
7ifeq ($(TARGET_ARCH), mipsn32)
8TARGET_BASE_ARCH:=mips
9endif
fbe4f65b
TS
10ifeq ($(TARGET_ARCH), mips64)
11TARGET_BASE_ARCH:=mips
12endif
a2458627
FB
13ifeq ($(TARGET_ARCH), ppc64)
14TARGET_BASE_ARCH:=ppc
15endif
22f8a8b3
JM
16ifeq ($(TARGET_ARCH), ppc64h)
17TARGET_BASE_ARCH:=ppc
18endif
d4082e95
JM
19ifeq ($(TARGET_ARCH), ppcemb)
20TARGET_BASE_ARCH:=ppc
21endif
64b3ab24
FB
22ifeq ($(TARGET_ARCH), sparc64)
23TARGET_BASE_ARCH:=sparc
24endif
0b0babc6 25TARGET_PATH=$(SRC_PATH)/target-$(TARGET_BASE_ARCH)
4fb240a4 26VPATH=$(SRC_PATH):$(TARGET_PATH):$(SRC_PATH)/hw
2f96c28d 27CPPFLAGS=-I. -I.. -I$(TARGET_PATH) -I$(SRC_PATH) -MMD -MP
831b7825
TS
28ifdef CONFIG_DARWIN_USER
29VPATH+=:$(SRC_PATH)/darwin-user
30CPPFLAGS+=-I$(SRC_PATH)/darwin-user -I$(SRC_PATH)/darwin-user/$(TARGET_ARCH)
31endif
32ifdef CONFIG_LINUX_USER
3035f7ff 33VPATH+=:$(SRC_PATH)/linux-user
992f48a0
BS
34ifndef TARGET_ABI_DIR
35 TARGET_ABI_DIR=$(TARGET_ARCH)
36endif
37CPPFLAGS+=-I$(SRC_PATH)/linux-user -I$(SRC_PATH)/linux-user/$(TARGET_ABI_DIR)
3035f7ff 38endif
6f30fa85
TS
39BASE_CFLAGS=
40BASE_LDFLAGS=
0b0babc6 41#CFLAGS+=-Werror
626df76a 42LIBS=
626df76a 43HELPER_CFLAGS=$(CFLAGS)
67b915a5 44DYNGEN=../dyngen$(EXESUF)
1e43adfc 45# user emulator name
c91fde65 46TARGET_ARCH2=$(TARGET_ARCH)
808c4954
FB
47ifeq ($(TARGET_ARCH),arm)
48 ifeq ($(TARGET_WORDS_BIGENDIAN),yes)
c91fde65 49 TARGET_ARCH2=armeb
808c4954 50 endif
c91fde65 51endif
908f52b0
PB
52ifeq ($(TARGET_ARCH),sh4)
53 ifeq ($(TARGET_WORDS_BIGENDIAN),yes)
54 TARGET_ARCH2=sh4eb
55 endif
56endif
01f5e596 57ifeq ($(TARGET_ARCH),mips)
c91fde65
FB
58 ifneq ($(TARGET_WORDS_BIGENDIAN),yes)
59 TARGET_ARCH2=mipsel
01f5e596 60 endif
01f5e596 61endif
540635ba
TS
62ifeq ($(TARGET_ARCH),mipsn32)
63 ifneq ($(TARGET_WORDS_BIGENDIAN),yes)
64 TARGET_ARCH2=mipsn32el
65 endif
66endif
fbe4f65b
TS
67ifeq ($(TARGET_ARCH),mips64)
68 ifneq ($(TARGET_WORDS_BIGENDIAN),yes)
69 TARGET_ARCH2=mips64el
70 endif
71endif
992f48a0
BS
72ifeq ($(TARGET_ARCH),sparc64)
73 ifeq ($(TARGET_ABI_DIR),sparc)
74 TARGET_ARCH2=sparc32plus
75 endif
76endif
c91fde65 77QEMU_USER=qemu-$(TARGET_ARCH2)
1e43adfc
FB
78# system emulator name
79ifdef CONFIG_SOFTMMU
a541f297 80ifeq ($(TARGET_ARCH), i386)
67b915a5 81QEMU_SYSTEM=qemu$(EXESUF)
0db63474 82else
c91fde65 83QEMU_SYSTEM=qemu-system-$(TARGET_ARCH2)$(EXESUF)
a541f297
FB
84endif
85else
0db63474 86QEMU_SYSTEM=qemu-fast
1e43adfc
FB
87endif
88
16e9b7de 89ifdef CONFIG_USER_ONLY
1e43adfc 90PROGS=$(QEMU_USER)
16e9b7de 91else
c321f673 92PROGS+=$(QEMU_SYSTEM)
de5eaa64
FB
93ifndef CONFIG_SOFTMMU
94CONFIG_STATIC=y
95endif
728c9fd5 96endif # !CONFIG_USER_ONLY
626df76a
FB
97
98ifdef CONFIG_STATIC
6f30fa85 99BASE_LDFLAGS+=-static
626df76a
FB
100endif
101
6f30fa85 102# We require -O2 to avoid the stack setup prologue in EXIT_TB
6c041c54
TS
103OP_CFLAGS := -Wall -O2 -g -fno-strict-aliasing
104
105# cc-option
106# Usage: OP_CFLAGS+=$(call cc-option, -falign-functions=0, -malign-functions=0)
107
108cc-option = $(shell if $(CC) $(OP_CFLAGS) $(1) -S -o /dev/null -xc /dev/null \
109 > /dev/null 2>&1; then echo "$(1)"; else echo "$(2)"; fi ;)
110
111OP_CFLAGS+=$(call cc-option, -fno-reorder-blocks, "")
112OP_CFLAGS+=$(call cc-option, -fno-gcse, "")
113OP_CFLAGS+=$(call cc-option, -fno-tree-ch, "")
114OP_CFLAGS+=$(call cc-option, -fno-optimize-sibling-calls, "")
115OP_CFLAGS+=$(call cc-option, -fno-crossjumping, "")
116OP_CFLAGS+=$(call cc-option, -fno-align-labels, "")
117OP_CFLAGS+=$(call cc-option, -fno-align-jumps, "")
118OP_CFLAGS+=$(call cc-option, -fno-align-functions, $(call cc-option, -malign-functions=0, ""))
1870a74c 119OP_CFLAGS+=$(call cc-option, -fno-section-anchors, "")
6f30fa85 120
626df76a 121ifeq ($(ARCH),i386)
6f30fa85
TS
122HELPER_CFLAGS+=-fomit-frame-pointer
123OP_CFLAGS+=-mpreferred-stack-boundary=2 -fomit-frame-pointer
626df76a 124ifdef TARGET_GPROF
3a4739d6
FB
125USE_I386_LD=y
126endif
127ifdef CONFIG_STATIC
128USE_I386_LD=y
129endif
130ifdef USE_I386_LD
6f30fa85 131BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
626df76a 132else
831b7825 133ifdef CONFIG_LINUX_USER
626df76a
FB
134# WARNING: this LDFLAGS is _very_ tricky : qemu is an ELF shared object
135# that the kernel ELF loader considers as an executable. I think this
136# is the simplest way to make it self virtualizable!
6f30fa85 137BASE_LDFLAGS+=-Wl,-shared
626df76a 138endif
626df76a 139endif
831b7825 140endif
626df76a 141
0b0babc6 142ifeq ($(ARCH),x86_64)
6f30fa85 143BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
bc51c5c9
FB
144endif
145
626df76a 146ifeq ($(ARCH),ppc)
6f30fa85 147CPPFLAGS+= -D__powerpc__
831b7825 148ifdef CONFIG_LINUX_USER
6f30fa85 149BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
626df76a 150endif
831b7825 151endif
626df76a
FB
152
153ifeq ($(ARCH),s390)
6f30fa85 154BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
626df76a
FB
155endif
156
157ifeq ($(ARCH),sparc)
3142255c
BS
158 BASE_CFLAGS+=-ffixed-g2 -ffixed-g3
159 OP_CFLAGS+=-fno-delayed-branch -ffixed-i0
160 ifeq ($(CONFIG_SOLARIS),yes)
161 OP_CFLAGS+=-fno-omit-frame-pointer
162 else
163 BASE_CFLAGS+=-ffixed-g1 -ffixed-g6
164 HELPER_CFLAGS=$(CFLAGS) -ffixed-i0 -mflat
165 # -static is used to avoid g1/g3 usage by the dynamic linker
166 BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld -static
167 endif
fdbb4691 168endif
626df76a
FB
169
170ifeq ($(ARCH),sparc64)
3142255c
BS
171 BASE_CFLAGS+=-ffixed-g1 -ffixed-g4 -ffixed-g5 -ffixed-g7
172 OP_CFLAGS+=-mcpu=ultrasparc -m64 -fno-delayed-branch -ffixed-i0
173 ifneq ($(CONFIG_SOLARIS),yes)
174 BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
175 OP_CFLAGS+=-ffixed-g1 -ffixed-g4 -ffixed-g5 -ffixed-g7
176 endif
626df76a
FB
177endif
178
179ifeq ($(ARCH),alpha)
6f30fa85
TS
180# -msmall-data is not used for OP_CFLAGS because we want two-instruction
181# relocations for the constant constructions
626df76a 182# Ensure there's only a single GP
6f30fa85
TS
183BASE_CFLAGS+=-msmall-data
184BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
626df76a
FB
185endif
186
187ifeq ($(ARCH),ia64)
6f30fa85
TS
188BASE_CFLAGS+=-mno-sdata
189OP_CFLAGS+=-mno-sdata
190BASE_LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/$(ARCH).ld
626df76a
FB
191endif
192
193ifeq ($(ARCH),arm)
6f30fa85
TS
194OP_CFLAGS+=-mno-sched-prolog -fno-omit-frame-pointer
195BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
626df76a
FB
196endif
197
38e584a0 198ifeq ($(ARCH),m68k)
6f30fa85
TS
199OP_CFLAGS+=-fomit-frame-pointer
200BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
201endif
202
203ifeq ($(ARCH),mips)
9617efe8 204OP_CFLAGS+=-mabi=32 -G0 -fno-PIC -mno-abicalls -fomit-frame-pointer -fno-delayed-branch -Wa,-O0
fbe4f65b
TS
205ifeq ($(WORDS_BIGENDIAN),yes)
206BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
207else
208BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH)el.ld
209endif
210endif
211
212ifeq ($(ARCH),mips64)
9617efe8 213OP_CFLAGS+=-mabi=n32 -G0 -fno-PIC -mno-abicalls -fomit-frame-pointer -fno-delayed-branch -Wa,-O0
fbe4f65b 214ifeq ($(WORDS_BIGENDIAN),yes)
6f30fa85 215BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
fbe4f65b
TS
216else
217BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH)el.ld
218endif
38e584a0
FB
219endif
220
83fb7adf 221ifeq ($(CONFIG_DARWIN),yes)
e80cfcfc 222LIBS+=-lmx
83fb7adf
FB
223endif
224
01feaa05
TS
225ifdef CONFIG_DARWIN_USER
226# Leave some space for the regular program loading zone
227BASE_LDFLAGS+=-Wl,-segaddr,__STD_PROG_ZONE,0x1000 -image_base 0x0e000000
228endif
229
3142255c
BS
230BASE_CFLAGS+=$(OS_CFLAGS) $(ARCH_CFLAGS)
231BASE_LDFLAGS+=$(OS_LDFLAGS) $(ARCH_LDFLAGS)
232OP_CFLAGS+=$(OS_CFLAGS) $(ARCH_CFLAGS)
233OP_LDFLAGS+=$(OS_LDFLAGS) $(ARCH_LDFLAGS)
6f30fa85 234
626df76a
FB
235#########################################################
236
6f30fa85 237CPPFLAGS+=-D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE
626df76a 238LIBS+=-lm
b932caba
FB
239ifndef CONFIG_USER_ONLY
240LIBS+=-lz
241endif
67b915a5 242ifdef CONFIG_WIN32
3db38e87 243LIBS+=-lwinmm -lws2_32 -liphlpapi
67b915a5 244endif
ec530c81
FB
245ifdef CONFIG_SOLARIS
246LIBS+=-lsocket -lnsl -lresolv
0475a5ca
TS
247ifdef NEEDS_LIBSUNMATH
248LIBS+=-lsunmath
249LDFLAGS+=-L/opt/SUNWspro/prod/lib -R/opt/SUNWspro/prod/lib
250OP_CFLAGS+=-I/opt/SUNWspro/prod/include/cc
251BASE_CFLAGS+=-I/opt/SUNWspro/prod/include/cc
252endif
ec530c81 253endif
626df76a
FB
254
255# profiling code
256ifdef TARGET_GPROF
6f30fa85
TS
257BASE_LDFLAGS+=-p
258main.o: BASE_CFLAGS+=-p
626df76a
FB
259endif
260
831b7825 261ifdef CONFIG_LINUX_USER
b92c47c1 262OBJS= main.o syscall.o strace.o mmap.o signal.o path.o osdep.o thunk.o \
e5fe0c52 263 elfload.o linuxload.o
b5906f95 264LIBS+= $(AIOLIBS)
e5fe0c52
PB
265ifdef TARGET_HAS_BFLT
266OBJS+= flatload.o
267endif
cb33da57
BS
268ifdef TARGET_HAS_ELFLOAD32
269OBJS+= elfload32.o
270elfload32.o: elfload.c
271endif
e5fe0c52 272
626df76a
FB
273ifeq ($(TARGET_ARCH), i386)
274OBJS+= vm86.o
275endif
f72b519c 276ifeq ($(TARGET_ARCH), arm)
158142c2 277OBJS+=nwfpe/fpa11.o nwfpe/fpa11_cpdo.o \
f72b519c 278nwfpe/fpa11_cpdt.o nwfpe/fpa11_cprt.o nwfpe/fpopcode.o nwfpe/single_cpdo.o \
a4f81979 279 nwfpe/double_cpdo.o nwfpe/extended_cpdo.o arm-semi.o
f72b519c 280endif
e6e5906b
PB
281ifeq ($(TARGET_ARCH), m68k)
282OBJS+= m68k-sim.o m68k-semi.o
283endif
831b7825
TS
284endif #CONFIG_LINUX_USER
285
286ifdef CONFIG_DARWIN_USER
287OBJS= main.o commpage.o machload.o mmap.o osdep.o signal.o syscall.o thunk.o
288endif
289
626df76a
FB
290SRCS:= $(OBJS:.o=.c)
291OBJS+= libqemu.a
292
293# cpu emulator library
158142c2 294LIBOBJS=exec.o kqemu.o translate-op.o translate-all.o cpu-exec.o\
f1548daa 295 translate.o op.o host-utils.o
158142c2
FB
296ifdef CONFIG_SOFTFLOAT
297LIBOBJS+=fpu/softfloat.o
298else
299LIBOBJS+=fpu/softfloat-native.o
300endif
6f30fa85 301CPPFLAGS+=-I$(SRC_PATH)/fpu
626df76a
FB
302
303ifeq ($(TARGET_ARCH), i386)
1e43adfc 304LIBOBJS+=helper.o helper2.o
f72b519c
FB
305ifeq ($(ARCH), i386)
306LIBOBJS+=translate-copy.o
307endif
626df76a
FB
308endif
309
0b0babc6
FB
310ifeq ($(TARGET_ARCH), x86_64)
311LIBOBJS+=helper.o helper2.o
312endif
313
a2458627 314ifeq ($(TARGET_BASE_ARCH), ppc)
728c9fd5 315LIBOBJS+= op_helper.o helper.o
67867308
FB
316endif
317
fbe4f65b 318ifeq ($(TARGET_BASE_ARCH), mips)
6af0bf9c
FB
319LIBOBJS+= op_helper.o helper.o
320endif
321
64b3ab24 322ifeq ($(TARGET_BASE_ARCH), sparc)
e95c8d51
FB
323LIBOBJS+= op_helper.o helper.o
324endif
325
b7bcbe95 326ifeq ($(TARGET_BASE_ARCH), arm)
b5ff1b31 327LIBOBJS+= op_helper.o helper.o
b7bcbe95
FB
328endif
329
fdf9b3e8
FB
330ifeq ($(TARGET_BASE_ARCH), sh4)
331LIBOBJS+= op_helper.o helper.o
332endif
333
e6e5906b 334ifeq ($(TARGET_BASE_ARCH), m68k)
0633879f 335LIBOBJS+= op_helper.o helper.o
e6e5906b
PB
336endif
337
cf6c1b16
JM
338ifeq ($(TARGET_BASE_ARCH), alpha)
339LIBOBJS+= op_helper.o helper.o alpha_palcode.o
340endif
341
e7daa605
TS
342ifeq ($(TARGET_BASE_ARCH), cris)
343LIBOBJS+= op_helper.o helper.o
344LIBOBJS+= cris-dis.o
345
346ifndef CONFIG_USER_ONLY
347LIBOBJS+= mmu.o
348endif
349endif
350
626df76a 351# NOTE: the disassembler code is only needed for debugging
5fafdf24 352LIBOBJS+=disas.o
626df76a 353ifeq ($(findstring i386, $(TARGET_ARCH) $(ARCH)),i386)
bc51c5c9
FB
354USE_I386_DIS=y
355endif
0b0babc6 356ifeq ($(findstring x86_64, $(TARGET_ARCH) $(ARCH)),x86_64)
bc51c5c9
FB
357USE_I386_DIS=y
358endif
359ifdef USE_I386_DIS
626df76a
FB
360LIBOBJS+=i386-dis.o
361endif
362ifeq ($(findstring alpha, $(TARGET_ARCH) $(ARCH)),alpha)
363LIBOBJS+=alpha-dis.o
364endif
a2458627 365ifeq ($(findstring ppc, $(TARGET_BASE_ARCH) $(ARCH)),ppc)
626df76a
FB
366LIBOBJS+=ppc-dis.o
367endif
fbe4f65b 368ifeq ($(findstring mips, $(TARGET_BASE_ARCH) $(ARCH)),mips)
6af0bf9c
FB
369LIBOBJS+=mips-dis.o
370endif
64b3ab24 371ifeq ($(findstring sparc, $(TARGET_BASE_ARCH) $(ARCH)),sparc)
626df76a
FB
372LIBOBJS+=sparc-dis.o
373endif
374ifeq ($(findstring arm, $(TARGET_ARCH) $(ARCH)),arm)
375LIBOBJS+=arm-dis.o
376endif
48024e4a
FB
377ifeq ($(findstring m68k, $(TARGET_ARCH) $(ARCH)),m68k)
378LIBOBJS+=m68k-dis.o
379endif
fdf9b3e8
FB
380ifeq ($(findstring sh4, $(TARGET_ARCH) $(ARCH)),sh4)
381LIBOBJS+=sh4-dis.o
382endif
8f860bb8
TS
383ifeq ($(findstring s390, $(TARGET_ARCH) $(ARCH)),s390)
384LIBOBJS+=s390-dis.o
385endif
626df76a 386
1fddef4b
FB
387ifdef CONFIG_GDBSTUB
388OBJS+=gdbstub.o
389endif
626df76a 390
1e43adfc 391all: $(PROGS)
626df76a 392
1e43adfc 393$(QEMU_USER): $(OBJS)
6f30fa85 394 $(CC) $(LDFLAGS) $(BASE_LDFLAGS) -o $@ $^ $(LIBS)
626df76a
FB
395ifeq ($(ARCH),alpha)
396# Mark as 32 bit binary, i. e. it will be mapped into the low 31 bit of
397# the address space (31 bit so sign extending doesn't matter)
398 echo -ne '\001\000\000\000' | dd of=qemu bs=1 seek=48 count=4 conv=notrunc
399endif
400
401# must use static linking to avoid leaving stuff in virtual address space
4fb240a4
FB
402VL_OBJS=vl.o osdep.o monitor.o pci.o loader.o isa_mmio.o
403# XXX: suppress QEMU_TOOL tests
83f64091 404VL_OBJS+=block.o block-raw.o
d537cf6c 405VL_OBJS+=irq.o
a541f297 406
1d14ffa9 407ifdef CONFIG_ALSA
1d14ffa9
FB
408LIBS += -lasound
409endif
410ifdef CONFIG_DSOUND
1d14ffa9 411LIBS += -lole32 -ldxguid
85571bc7 412endif
102a52e4 413ifdef CONFIG_FMOD
102a52e4 414LIBS += $(CONFIG_FMOD_LIB)
85571bc7 415endif
4fb240a4
FB
416
417SOUND_HW = sb16.o es1370.o
1d14ffa9
FB
418ifdef CONFIG_ADLIB
419SOUND_HW += fmopl.o adlib.o
420endif
85571bc7 421
8d5d2d4c
TS
422ifdef CONFIG_VNC_TLS
423CPPFLAGS += $(CONFIG_VNC_TLS_CFLAGS)
424LIBS += $(CONFIG_VNC_TLS_LIBS)
425endif
426
0ff596d0
PB
427VL_OBJS += i2c.o smbus.o
428
2e5d83bb 429# SCSI layer
7d8406be 430VL_OBJS+= scsi-disk.o cdrom.o lsi53c895a.o
2e5d83bb 431
a594cfbf 432# USB layer
2e5d83bb 433VL_OBJS+= usb.o usb-hub.o usb-linux.o usb-hid.o usb-ohci.o usb-msd.o
f6d2a316 434VL_OBJS+= usb-wacom.o
a594cfbf 435
663e8e51
TS
436# EEPROM emulation
437VL_OBJS += eeprom93xx.o
438
a41b2ff2 439# PCI network cards
663e8e51
TS
440VL_OBJS += eepro100.o
441VL_OBJS += ne2000.o
442VL_OBJS += pcnet.o
443VL_OBJS += rtl8139.o
a41b2ff2 444
0b0babc6 445ifeq ($(TARGET_BASE_ARCH), i386)
a541f297 446# Hardware support
4fb240a4 447VL_OBJS+= ide.o pckbd.o ps2.o vga.o $(SOUND_HW) dma.o
fd06c375 448VL_OBJS+= fdc.o mc146818rtc.o serial.o i8259.o i8254.o pcspk.o pc.o
b00052e4 449VL_OBJS+= cirrus_vga.o apic.o parallel.o acpi.o piix_pci.o
591a6d62 450VL_OBJS+= usb-uhci.o smbus_eeprom.o vmmouse.o vmport.o vmware_vga.o
b00052e4 451CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
67b915a5 452endif
a2458627 453ifeq ($(TARGET_BASE_ARCH), ppc)
b00052e4 454CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
3cbee15b 455# shared objects
4fb240a4 456VL_OBJS+= ppc.o ide.o vga.o $(SOUND_HW) dma.o openpic.o
3cbee15b
JM
457# PREP target
458VL_OBJS+= pckbd.o ps2.o serial.o i8259.o i8254.o fdc.o m48t59.o mc146818rtc.o
459VL_OBJS+= prep_pci.o ppc_prep.o
460# Mac shared devices
461VL_OBJS+= macio.o cuda.o adb.o mac_nvram.o mac_dbdma.o
462# OldWorld PowerMac
463VL_OBJS+= heathrow_pic.o grackle_pci.o ppc_oldworld.o
464# NewWorld PowerMac
465VL_OBJS+= unin_pci.o ppc_chrp.o
466# PowerPC 4xx boards
467VL_OBJS+= pflash_cfi02.o ppc4xx_devs.o ppc405_uc.o ppc405_boards.o
a541f297 468endif
fbe4f65b 469ifeq ($(TARGET_BASE_ARCH), mips)
6bf5b4e8 470VL_OBJS+= mips_r4k.o mips_malta.o mips_pica61.o mips_mipssim.o
ad6fe1d2 471VL_OBJS+= mips_timer.o mips_int.o dma.o vga.o serial.o i8254.o i8259.o
31211df1 472VL_OBJS+= jazz_led.o
9542611a 473VL_OBJS+= ide.o gt64xxx.o pckbd.o ps2.o fdc.o mc146818rtc.o usb-uhci.o acpi.o ds1225y.o
4fb240a4 474VL_OBJS+= piix_pci.o smbus_eeprom.o parallel.o cirrus_vga.o $(SOUND_HW)
6bf5b4e8 475VL_OBJS+= mipsnet.o
83b1fb88 476CPPFLAGS += -DHAS_AUDIO
6af0bf9c 477endif
e7daa605
TS
478ifeq ($(TARGET_BASE_ARCH), cris)
479VL_OBJS+= etraxfs.o
480VL_OBJS+= ptimer.o
481VL_OBJS+= etraxfs_timer.o
482VL_OBJS+= etraxfs_ser.o
483endif
64b3ab24 484ifeq ($(TARGET_BASE_ARCH), sparc)
3475187d 485ifeq ($(TARGET_ARCH), sparc64)
502a5395 486VL_OBJS+= sun4u.o ide.o pckbd.o ps2.o vga.o apb_pci.o
83469015 487VL_OBJS+= fdc.o mc146818rtc.o serial.o m48t59.o
20c9f095 488VL_OBJS+= cirrus_vga.o parallel.o ptimer.o
3475187d 489else
67e999be
FB
490VL_OBJS+= sun4m.o tcx.o pcnet.o iommu.o m48t59.o slavio_intctl.o
491VL_OBJS+= slavio_timer.o slavio_serial.o slavio_misc.o fdc.o esp.o sparc32_dma.o
8d05ea8a 492VL_OBJS+= cs4231.o ptimer.o
3475187d 493endif
e95c8d51 494endif
b5ff1b31 495ifeq ($(TARGET_BASE_ARCH), arm)
cdbdb648 496VL_OBJS+= integratorcp.o versatilepb.o ps2.o smc91c111.o arm_pic.o arm_timer.o
7e1543c2 497VL_OBJS+= arm_boot.o pl011.o pl031.o pl050.o pl080.o pl110.o pl181.o pl190.o
6963d7af 498VL_OBJS+= versatile_pci.o sd.o ptimer.o
e69954b9 499VL_OBJS+= arm_gic.o realview.o arm_sysctl.o
8e71621f 500VL_OBJS+= arm-semi.o
b00052e4 501VL_OBJS+= pxa2xx.o pxa2xx_pic.o pxa2xx_gpio.o pxa2xx_timer.o pxa2xx_dma.o
adb86c37 502VL_OBJS+= pxa2xx_lcd.o pxa2xx_mmci.o pxa2xx_pcmcia.o max111x.o max7310.o
4fb240a4 503VL_OBJS+= spitz.o ads7846.o ide.o serial.o nand.o ecc.o wm8750.o
02645926
AZ
504VL_OBJS+= omap.o omap_lcdc.o omap1_clk.o omap_mmc.o omap_i2c.o
505VL_OBJS+= palm.o tsc210x.o
5a1237c4 506CPPFLAGS += -DHAS_AUDIO
b5ff1b31 507endif
fdf9b3e8 508ifeq ($(TARGET_BASE_ARCH), sh4)
0d78f544 509VL_OBJS+= shix.o r2d.o sh7750.o sh7750_regnames.o tc58128.o
80f515e6 510VL_OBJS+= sh_timer.o ptimer.o sh_serial.o sh_intc.o
fdf9b3e8 511endif
0633879f 512ifeq ($(TARGET_BASE_ARCH), m68k)
7e049b8a 513VL_OBJS+= an5206.o mcf5206.o ptimer.o mcf_uart.o mcf_intc.o mcf5208.o mcf_fec.o
a87295e8 514VL_OBJS+= m68k-semi.o
0633879f 515endif
a541f297 516ifdef CONFIG_GDBSTUB
5fafdf24 517VL_OBJS+=gdbstub.o
728c9fd5 518endif
5b0753e0 519ifdef CONFIG_COCOA
1d14ffa9
FB
520COCOA_LIBS=-F/System/Library/Frameworks -framework Cocoa -framework IOKit
521ifdef CONFIG_COREAUDIO
522COCOA_LIBS+=-framework CoreAudio
523endif
5b0753e0 524endif
7c1f25b4 525ifdef CONFIG_SLIRP
6f30fa85 526CPPFLAGS+=-I$(SRC_PATH)/slirp
626df76a
FB
527endif
528
db8d7dd1 529VL_LDFLAGS=$(VL_OS_LDFLAGS)
70956b77 530VL_LIBS=$(AIOLIBS)
c321f673 531# specific flags are needed for non soft mmu emulator
c321f673
FB
532ifdef CONFIG_STATIC
533VL_LDFLAGS+=-static
534endif
de5eaa64 535ifndef CONFIG_SOFTMMU
5fafdf24 536VL_LDFLAGS+=-Wl,-T,$(SRC_PATH)/i386-vl.ld
de5eaa64 537endif
83fb7adf 538ifndef CONFIG_DARWIN
11d9f695 539ifndef CONFIG_WIN32
ec530c81 540ifndef CONFIG_SOLARIS
70956b77 541VL_LIBS+=-lutil
11d9f695 542endif
83fb7adf 543endif
ec530c81 544endif
e3086fbf 545ifdef TARGET_GPROF
6f30fa85 546vl.o: BASE_CFLAGS+=-p
e3086fbf
FB
547VL_LDFLAGS+=-p
548endif
c321f673 549
b8076a74
FB
550ifeq ($(ARCH),ia64)
551VL_LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/ia64.ld
552endif
553
74ccb34e 554ifeq ($(ARCH),sparc64)
3142255c
BS
555 VL_LDFLAGS+=-m64
556 ifneq ($(CONFIG_SOLARIS),yes)
557 VL_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
558 endif
74ccb34e
FB
559endif
560
1d14ffa9
FB
561ifdef CONFIG_WIN32
562SDL_LIBS := $(filter-out -mwindows, $(SDL_LIBS)) -mconsole
563endif
564
4fb240a4 565$(QEMU_SYSTEM): $(VL_OBJS) ../libqemu_common.a libqemu.a
3a11702b 566 $(CC) $(VL_LDFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS) $(SDL_LIBS) $(COCOA_LIBS) $(VL_LIBS)
5b0753e0 567
626df76a 568depend: $(SRCS)
6f30fa85 569 $(CC) -MM $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) $^ 1>.depend
626df76a 570
1d14ffa9 571vldepend: $(VL_OBJS:.o=.c)
6f30fa85 572 $(CC) -MM $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) $^ 1>.depend
1d14ffa9 573
5fafdf24 574# libqemu
626df76a
FB
575
576libqemu.a: $(LIBOBJS)
577 rm -f $@
578 $(AR) rcs $@ $(LIBOBJS)
579
1e43adfc 580translate.o: translate.c gen-op.h opc.h cpu.h
626df76a 581
158142c2
FB
582translate-all.o: translate-all.c opc.h cpu.h
583
584translate-op.o: translate-all.c op.h opc.h cpu.h
626df76a 585
1e43adfc 586op.h: op.o $(DYNGEN)
626df76a
FB
587 $(DYNGEN) -o $@ $<
588
1e43adfc 589opc.h: op.o $(DYNGEN)
626df76a
FB
590 $(DYNGEN) -c -o $@ $<
591
1e43adfc 592gen-op.h: op.o $(DYNGEN)
626df76a
FB
593 $(DYNGEN) -g -o $@ $<
594
1e43adfc 595op.o: op.c
6f30fa85 596 $(CC) $(OP_CFLAGS) $(CPPFLAGS) -c -o $@ $<
626df76a 597
6e1b3e4d
FB
598# HELPER_CFLAGS is used for all the code compiled with static register
599# variables
600ifeq ($(TARGET_BASE_ARCH), i386)
601# XXX: rename helper.c to op_helper.c
1e43adfc 602helper.o: helper.c
6f30fa85 603 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
6e1b3e4d
FB
604else
605op_helper.o: op_helper.c
6f30fa85 606 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
6e1b3e4d
FB
607endif
608
609cpu-exec.o: cpu-exec.c
6f30fa85 610 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
626df76a 611
00a67ba1
FB
612# Note: this is a workaround. The real fix is to avoid compiling
613# cpu_signal_handler() in cpu-exec.c.
614signal.o: signal.c
6f30fa85 615 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
00a67ba1 616
626df76a 617%.o: %.c
6f30fa85 618 $(CC) $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
626df76a 619
f72b519c 620%.o: %.S
6f30fa85 621 $(CC) $(CPPFLAGS) -c -o $@ $<
f72b519c 622
626df76a 623clean:
4fb240a4 624 rm -f *.o *.a *~ $(PROGS) gen-op.h opc.h op.h nwfpe/*.o fpu/*.o
2f96c28d 625 rm -f *.d */*.d
1e43adfc 626
5fafdf24 627install: all
9b14bb04 628ifneq ($(PROGS),)
6a882643 629 $(INSTALL) -m 755 -s $(PROGS) "$(DESTDIR)$(bindir)"
9b14bb04 630endif
626df76a
FB
631
632ifneq ($(wildcard .depend),)
633include .depend
634endif
1d14ffa9 635
c0fe3827 636ifeq (1, 0)
1d14ffa9 637audio.o sdlaudio.o dsoundaudio.o ossaudio.o wavaudio.o noaudio.o \
c0fe3827 638fmodaudio.o alsaaudio.o mixeng.o sb16.o es1370.o gus.o adlib.o: \
1d14ffa9
FB
639CFLAGS := $(CFLAGS) -Wall -Werror -W -Wsign-compare
640endif
2f96c28d
JM
641
642# Include automatically generated dependency files
643-include $(wildcard *.d */*.d)