]> git.proxmox.com Git - mirror_qemu.git/blame - Makefile.target
Make Alpha and PowerPC targets use shared helpers
[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)
85571bc7 26VPATH=$(SRC_PATH):$(TARGET_PATH):$(SRC_PATH)/hw:$(SRC_PATH)/audio
6f30fa85 27CPPFLAGS=-I. -I.. -I$(TARGET_PATH) -I$(SRC_PATH)
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
e5fe0c52
PB
262OBJS= main.o syscall.o mmap.o signal.o path.o osdep.o thunk.o \
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
aef445bd 402VL_OBJS=vl.o osdep.o readline.o monitor.o pci.o console.o loader.o isa_mmio.o
18607dcb 403VL_OBJS+=cutils.o
83f64091 404VL_OBJS+=block.o block-raw.o
6ada7453 405VL_OBJS+=block-cow.o block-qcow.o aes.o block-vmdk.o block-cloop.o block-dmg.o block-bochs.o block-vpc.o block-vvfat.o block-qcow2.o block-parallels.o
d537cf6c 406VL_OBJS+=irq.o
7fb843f8
FB
407ifdef CONFIG_WIN32
408VL_OBJS+=tap-win32.o
409endif
a541f297 410
1d14ffa9 411SOUND_HW = sb16.o es1370.o
b00052e4 412AUDIODRV = audio.o noaudio.o wavaudio.o mixeng.o
fb065187
FB
413ifdef CONFIG_SDL
414AUDIODRV += sdlaudio.o
415endif
416ifdef CONFIG_OSS
417AUDIODRV += ossaudio.o
418endif
1d14ffa9
FB
419ifdef CONFIG_COREAUDIO
420AUDIODRV += coreaudio.o
421endif
422ifdef CONFIG_ALSA
423AUDIODRV += alsaaudio.o
424LIBS += -lasound
425endif
426ifdef CONFIG_DSOUND
427AUDIODRV += dsoundaudio.o
428LIBS += -lole32 -ldxguid
85571bc7 429endif
102a52e4 430ifdef CONFIG_FMOD
85571bc7 431AUDIODRV += fmodaudio.o
6f30fa85 432audio.o fmodaudio.o: CPPFLAGS := -I$(CONFIG_FMOD_INC) $(CPPFLAGS)
102a52e4 433LIBS += $(CONFIG_FMOD_LIB)
85571bc7 434endif
1d14ffa9
FB
435ifdef CONFIG_ADLIB
436SOUND_HW += fmopl.o adlib.o
437endif
ec36b695 438AUDIODRV+= wavcapture.o
85571bc7 439
8d5d2d4c
TS
440ifdef CONFIG_VNC_TLS
441CPPFLAGS += $(CONFIG_VNC_TLS_CFLAGS)
442LIBS += $(CONFIG_VNC_TLS_LIBS)
443endif
444
0ff596d0
PB
445VL_OBJS += i2c.o smbus.o
446
2e5d83bb 447# SCSI layer
7d8406be 448VL_OBJS+= scsi-disk.o cdrom.o lsi53c895a.o
2e5d83bb 449
a594cfbf 450# USB layer
2e5d83bb 451VL_OBJS+= usb.o usb-hub.o usb-linux.o usb-hid.o usb-ohci.o usb-msd.o
f6d2a316 452VL_OBJS+= usb-wacom.o
a594cfbf 453
663e8e51
TS
454# EEPROM emulation
455VL_OBJS += eeprom93xx.o
456
a41b2ff2 457# PCI network cards
663e8e51
TS
458VL_OBJS += eepro100.o
459VL_OBJS += ne2000.o
460VL_OBJS += pcnet.o
461VL_OBJS += rtl8139.o
a41b2ff2 462
0b0babc6 463ifeq ($(TARGET_BASE_ARCH), i386)
a541f297 464# Hardware support
a41b2ff2 465VL_OBJS+= ide.o pckbd.o ps2.o vga.o $(SOUND_HW) dma.o $(AUDIODRV)
fd06c375 466VL_OBJS+= fdc.o mc146818rtc.o serial.o i8259.o i8254.o pcspk.o pc.o
b00052e4 467VL_OBJS+= cirrus_vga.o apic.o parallel.o acpi.o piix_pci.o
591a6d62 468VL_OBJS+= usb-uhci.o smbus_eeprom.o vmmouse.o vmport.o vmware_vga.o
b00052e4 469CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
67b915a5 470endif
a2458627 471ifeq ($(TARGET_BASE_ARCH), ppc)
a41b2ff2 472VL_OBJS+= ppc.o ide.o pckbd.o ps2.o vga.o $(SOUND_HW) dma.o $(AUDIODRV)
8ecc7913 473VL_OBJS+= mc146818rtc.o serial.o i8259.o i8254.o fdc.o m48t59.o pflash_cfi02.o
b00052e4 474VL_OBJS+= ppc_prep.o ppc_chrp.o cuda.o adb.o openpic.o heathrow_pic.o
7875ed20
JM
475VL_OBJS+= grackle_pci.o prep_pci.o unin_pci.o
476# PowerPC 4xx boards
477VL_OBJS+= ppc4xx_devs.o ppc405_uc.o ppc405_boards.o
b00052e4 478CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
a541f297 479endif
fbe4f65b 480ifeq ($(TARGET_BASE_ARCH), mips)
6bf5b4e8 481VL_OBJS+= mips_r4k.o mips_malta.o mips_pica61.o mips_mipssim.o
ad6fe1d2 482VL_OBJS+= mips_timer.o mips_int.o dma.o vga.o serial.o i8254.o i8259.o
31211df1 483VL_OBJS+= jazz_led.o
9542611a 484VL_OBJS+= ide.o gt64xxx.o pckbd.o ps2.o fdc.o mc146818rtc.o usb-uhci.o acpi.o ds1225y.o
7b717336 485VL_OBJS+= piix_pci.o smbus_eeprom.o parallel.o mixeng.o cirrus_vga.o $(SOUND_HW) $(AUDIODRV)
6bf5b4e8 486VL_OBJS+= mipsnet.o
83b1fb88 487CPPFLAGS += -DHAS_AUDIO
6af0bf9c 488endif
e7daa605
TS
489ifeq ($(TARGET_BASE_ARCH), cris)
490VL_OBJS+= etraxfs.o
491VL_OBJS+= ptimer.o
492VL_OBJS+= etraxfs_timer.o
493VL_OBJS+= etraxfs_ser.o
494endif
64b3ab24 495ifeq ($(TARGET_BASE_ARCH), sparc)
3475187d 496ifeq ($(TARGET_ARCH), sparc64)
502a5395 497VL_OBJS+= sun4u.o ide.o pckbd.o ps2.o vga.o apb_pci.o
83469015 498VL_OBJS+= fdc.o mc146818rtc.o serial.o m48t59.o
20c9f095 499VL_OBJS+= cirrus_vga.o parallel.o ptimer.o
3475187d 500else
67e999be
FB
501VL_OBJS+= sun4m.o tcx.o pcnet.o iommu.o m48t59.o slavio_intctl.o
502VL_OBJS+= slavio_timer.o slavio_serial.o slavio_misc.o fdc.o esp.o sparc32_dma.o
8d05ea8a 503VL_OBJS+= cs4231.o ptimer.o
3475187d 504endif
e95c8d51 505endif
b5ff1b31 506ifeq ($(TARGET_BASE_ARCH), arm)
cdbdb648 507VL_OBJS+= integratorcp.o versatilepb.o ps2.o smc91c111.o arm_pic.o arm_timer.o
7e1543c2 508VL_OBJS+= arm_boot.o pl011.o pl031.o pl050.o pl080.o pl110.o pl181.o pl190.o
6963d7af 509VL_OBJS+= versatile_pci.o sd.o ptimer.o
e69954b9 510VL_OBJS+= arm_gic.o realview.o arm_sysctl.o
8e71621f 511VL_OBJS+= arm-semi.o
b00052e4 512VL_OBJS+= pxa2xx.o pxa2xx_pic.o pxa2xx_gpio.o pxa2xx_timer.o pxa2xx_dma.o
adb86c37
AZ
513VL_OBJS+= pxa2xx_lcd.o pxa2xx_mmci.o pxa2xx_pcmcia.o max111x.o max7310.o
514VL_OBJS+= spitz.o ads7846.o ide.o serial.o nand.o $(AUDIODRV) wm8750.o
9ff6755b 515VL_OBJS+= omap.o omap_lcdc.o omap1_clk.o omap_mmc.o palm.o ecc.o
5a1237c4 516CPPFLAGS += -DHAS_AUDIO
b5ff1b31 517endif
fdf9b3e8 518ifeq ($(TARGET_BASE_ARCH), sh4)
0d78f544 519VL_OBJS+= shix.o r2d.o sh7750.o sh7750_regnames.o tc58128.o
80f515e6 520VL_OBJS+= sh_timer.o ptimer.o sh_serial.o sh_intc.o
fdf9b3e8 521endif
0633879f 522ifeq ($(TARGET_BASE_ARCH), m68k)
7e049b8a 523VL_OBJS+= an5206.o mcf5206.o ptimer.o mcf_uart.o mcf_intc.o mcf5208.o mcf_fec.o
a87295e8 524VL_OBJS+= m68k-semi.o
0633879f 525endif
a541f297 526ifdef CONFIG_GDBSTUB
5fafdf24 527VL_OBJS+=gdbstub.o
728c9fd5 528endif
626df76a 529ifdef CONFIG_SDL
6070dd07 530VL_OBJS+=sdl.o x_keymap.o
de5eaa64 531endif
70848515 532VL_OBJS+=vnc.o d3des.o
5b0753e0
FB
533ifdef CONFIG_COCOA
534VL_OBJS+=cocoa.o
1d14ffa9
FB
535COCOA_LIBS=-F/System/Library/Frameworks -framework Cocoa -framework IOKit
536ifdef CONFIG_COREAUDIO
537COCOA_LIBS+=-framework CoreAudio
538endif
5b0753e0 539endif
7c1f25b4 540ifdef CONFIG_SLIRP
6f30fa85 541CPPFLAGS+=-I$(SRC_PATH)/slirp
7c1f25b4
FB
542SLIRP_OBJS=cksum.o if.o ip_icmp.o ip_input.o ip_output.o \
543slirp.o mbuf.o misc.o sbuf.o socket.o tcp_input.o tcp_output.o \
c7f74643 544tcp_subr.o tcp_timer.o udp.o bootp.o debug.o tftp.o
7c1f25b4 545VL_OBJS+=$(addprefix slirp/, $(SLIRP_OBJS))
626df76a
FB
546endif
547
db8d7dd1 548VL_LDFLAGS=$(VL_OS_LDFLAGS)
70956b77 549VL_LIBS=$(AIOLIBS)
c321f673 550# specific flags are needed for non soft mmu emulator
c321f673
FB
551ifdef CONFIG_STATIC
552VL_LDFLAGS+=-static
553endif
de5eaa64 554ifndef CONFIG_SOFTMMU
5fafdf24 555VL_LDFLAGS+=-Wl,-T,$(SRC_PATH)/i386-vl.ld
de5eaa64 556endif
83fb7adf 557ifndef CONFIG_DARWIN
11d9f695 558ifndef CONFIG_WIN32
ec530c81 559ifndef CONFIG_SOLARIS
70956b77 560VL_LIBS+=-lutil
11d9f695 561endif
83fb7adf 562endif
ec530c81 563endif
e3086fbf 564ifdef TARGET_GPROF
6f30fa85 565vl.o: BASE_CFLAGS+=-p
e3086fbf
FB
566VL_LDFLAGS+=-p
567endif
c321f673 568
b8076a74
FB
569ifeq ($(ARCH),ia64)
570VL_LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/ia64.ld
571endif
572
74ccb34e 573ifeq ($(ARCH),sparc64)
3142255c
BS
574 VL_LDFLAGS+=-m64
575 ifneq ($(CONFIG_SOLARIS),yes)
576 VL_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
577 endif
74ccb34e
FB
578endif
579
1d14ffa9
FB
580ifdef CONFIG_WIN32
581SDL_LIBS := $(filter-out -mwindows, $(SDL_LIBS)) -mconsole
582endif
583
1e43adfc 584$(QEMU_SYSTEM): $(VL_OBJS) libqemu.a
3a11702b 585 $(CC) $(VL_LDFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS) $(SDL_LIBS) $(COCOA_LIBS) $(VL_LIBS)
5b0753e0
FB
586
587cocoa.o: cocoa.m
6f30fa85 588 $(CC) $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
626df76a 589
3d11d0eb 590sdl.o: sdl.c keymaps.c sdl_keysym.h
6f30fa85 591 $(CC) $(CFLAGS) $(CPPFLAGS) $(SDL_CFLAGS) $(BASE_CFLAGS) -c -o $@ $<
626df76a 592
70848515 593vnc.o: vnc.c keymaps.c sdl_keysym.h vnchextile.h d3des.c d3des.h
6f30fa85 594 $(CC) $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
24236869 595
9f059eca 596sdlaudio.o: sdlaudio.c
6f30fa85 597 $(CC) $(CFLAGS) $(CPPFLAGS) $(SDL_CFLAGS) $(BASE_CFLAGS) -c -o $@ $<
9f059eca 598
626df76a 599depend: $(SRCS)
6f30fa85 600 $(CC) -MM $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) $^ 1>.depend
626df76a 601
1d14ffa9 602vldepend: $(VL_OBJS:.o=.c)
6f30fa85 603 $(CC) -MM $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) $^ 1>.depend
1d14ffa9 604
5fafdf24 605# libqemu
626df76a
FB
606
607libqemu.a: $(LIBOBJS)
608 rm -f $@
609 $(AR) rcs $@ $(LIBOBJS)
610
1e43adfc 611translate.o: translate.c gen-op.h opc.h cpu.h
626df76a 612
158142c2
FB
613translate-all.o: translate-all.c opc.h cpu.h
614
615translate-op.o: translate-all.c op.h opc.h cpu.h
626df76a 616
1e43adfc 617op.h: op.o $(DYNGEN)
626df76a
FB
618 $(DYNGEN) -o $@ $<
619
1e43adfc 620opc.h: op.o $(DYNGEN)
626df76a
FB
621 $(DYNGEN) -c -o $@ $<
622
1e43adfc 623gen-op.h: op.o $(DYNGEN)
626df76a
FB
624 $(DYNGEN) -g -o $@ $<
625
1e43adfc 626op.o: op.c
6f30fa85 627 $(CC) $(OP_CFLAGS) $(CPPFLAGS) -c -o $@ $<
626df76a 628
6e1b3e4d
FB
629# HELPER_CFLAGS is used for all the code compiled with static register
630# variables
631ifeq ($(TARGET_BASE_ARCH), i386)
632# XXX: rename helper.c to op_helper.c
1e43adfc 633helper.o: helper.c
6f30fa85 634 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
6e1b3e4d
FB
635else
636op_helper.o: op_helper.c
6f30fa85 637 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
6e1b3e4d
FB
638endif
639
640cpu-exec.o: cpu-exec.c
6f30fa85 641 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
626df76a 642
00a67ba1
FB
643# Note: this is a workaround. The real fix is to avoid compiling
644# cpu_signal_handler() in cpu-exec.c.
645signal.o: signal.c
6f30fa85 646 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
00a67ba1 647
94470844
BS
648vga.o: pixel_ops.h
649
650tcx.o: pixel_ops.h
651
0b0babc6 652ifeq ($(TARGET_BASE_ARCH), i386)
664e0f19 653op.o: op.c opreg_template.h ops_template.h ops_template_mem.h ops_mem.h ops_sse.h
1e43adfc
FB
654endif
655
656ifeq ($(TARGET_ARCH), arm)
657op.o: op.c op_template.h
bdd5003a 658pl110.o: pl110_template.h
1e43adfc 659endif
626df76a 660
64b3ab24 661ifeq ($(TARGET_BASE_ARCH), sparc)
0aac653c
BS
662helper.o: cpu.h exec-all.h
663op.o: op.c op_template.h op_mem.h fop_template.h fbranch_template.h exec.h cpu.h
664op_helper.o: exec.h softmmu_template.h cpu.h
665translate.o: cpu.h exec-all.h disas.h
1e43adfc 666endif
626df76a 667
a2458627 668ifeq ($(TARGET_BASE_ARCH), ppc)
47c4d8f0
JM
669op.o: op.c op_template.h op_mem.h op_helper.h
670op_helper.o: op_helper.c mfrom_table.c op_helper_mem.h op_helper.h
3fc6c082 671translate.o: translate.c translate_init.c
728c9fd5
FB
672endif
673
fbe4f65b
TS
674ifeq ($(TARGET_BASE_ARCH), mips)
675helper.o: cpu.h exec-all.h
9daea906 676op.o: op_template.c fop_template.c op_mem.c exec.h cpu.h
4e9f8537 677op_helper.o: exec.h softmmu_template.h cpu.h
fbe4f65b 678translate.o: translate_init.c exec-all.h disas.h
6af0bf9c
FB
679endif
680
5fe141fd
FB
681loader.o: loader.c elf_ops.h
682
fdf9b3e8
FB
683ifeq ($(TARGET_ARCH), sh4)
684op.o: op.c op_mem.c cpu.h
685op_helper.o: op_helper.c exec.h cpu.h
686helper.o: helper.c exec.h cpu.h
27c7ca7e
FB
687sh7750.o: sh7750.c sh7750_regs.h sh7750_regnames.h cpu.h
688shix.o: shix.c sh7750_regs.h sh7750_regnames.h
fdf9b3e8 689sh7750_regnames.o: sh7750_regnames.c sh7750_regnames.h sh7750_regs.h
27c7ca7e 690tc58128.o: tc58128.c
fdf9b3e8
FB
691endif
692
cf6c1b16
JM
693ifeq ($(TARGET_BASE_ARCH), alpha)
694op.o: op.c op_template.h op_mem.h
695op_helper.o: op_helper_mem.h
696endif
697
214feb51
PB
698$(OBJS) $(LIBOBJS) $(VL_OBJS): config.h ../config-host.h
699
626df76a 700%.o: %.c
6f30fa85 701 $(CC) $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
626df76a 702
f72b519c 703%.o: %.S
6f30fa85 704 $(CC) $(CPPFLAGS) -c -o $@ $<
f72b519c 705
626df76a 706clean:
e362b55a 707 rm -f *.o *.a *~ $(PROGS) gen-op.h opc.h op.h nwfpe/*.o slirp/*.o fpu/*.o
1e43adfc 708
5fafdf24 709install: all
9b14bb04 710ifneq ($(PROGS),)
6a882643 711 $(INSTALL) -m 755 -s $(PROGS) "$(DESTDIR)$(bindir)"
9b14bb04 712endif
626df76a
FB
713
714ifneq ($(wildcard .depend),)
715include .depend
716endif
1d14ffa9 717
c0fe3827 718ifeq (1, 0)
1d14ffa9 719audio.o sdlaudio.o dsoundaudio.o ossaudio.o wavaudio.o noaudio.o \
c0fe3827 720fmodaudio.o alsaaudio.o mixeng.o sb16.o es1370.o gus.o adlib.o: \
1d14ffa9
FB
721CFLAGS := $(CFLAGS) -Wall -Werror -W -Wsign-compare
722endif