]> git.proxmox.com Git - qemu.git/blame - Makefile.target
CPU specific boot mode (Robert Reif)
[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
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
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)
b00052e4 472CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
3cbee15b
JM
473# shared objects
474VL_OBJS+= ppc.o ide.o vga.o $(SOUND_HW) dma.o openpic.o $(AUDIODRV)
475# PREP target
476VL_OBJS+= pckbd.o ps2.o serial.o i8259.o i8254.o fdc.o m48t59.o mc146818rtc.o
477VL_OBJS+= prep_pci.o ppc_prep.o
478# Mac shared devices
479VL_OBJS+= macio.o cuda.o adb.o mac_nvram.o mac_dbdma.o
480# OldWorld PowerMac
481VL_OBJS+= heathrow_pic.o grackle_pci.o ppc_oldworld.o
482# NewWorld PowerMac
483VL_OBJS+= unin_pci.o ppc_chrp.o
484# PowerPC 4xx boards
485VL_OBJS+= pflash_cfi02.o ppc4xx_devs.o ppc405_uc.o ppc405_boards.o
a541f297 486endif
fbe4f65b 487ifeq ($(TARGET_BASE_ARCH), mips)
6bf5b4e8 488VL_OBJS+= mips_r4k.o mips_malta.o mips_pica61.o mips_mipssim.o
ad6fe1d2 489VL_OBJS+= mips_timer.o mips_int.o dma.o vga.o serial.o i8254.o i8259.o
31211df1 490VL_OBJS+= jazz_led.o
9542611a 491VL_OBJS+= ide.o gt64xxx.o pckbd.o ps2.o fdc.o mc146818rtc.o usb-uhci.o acpi.o ds1225y.o
7b717336 492VL_OBJS+= piix_pci.o smbus_eeprom.o parallel.o mixeng.o cirrus_vga.o $(SOUND_HW) $(AUDIODRV)
6bf5b4e8 493VL_OBJS+= mipsnet.o
83b1fb88 494CPPFLAGS += -DHAS_AUDIO
6af0bf9c 495endif
e7daa605
TS
496ifeq ($(TARGET_BASE_ARCH), cris)
497VL_OBJS+= etraxfs.o
498VL_OBJS+= ptimer.o
499VL_OBJS+= etraxfs_timer.o
500VL_OBJS+= etraxfs_ser.o
501endif
64b3ab24 502ifeq ($(TARGET_BASE_ARCH), sparc)
3475187d 503ifeq ($(TARGET_ARCH), sparc64)
502a5395 504VL_OBJS+= sun4u.o ide.o pckbd.o ps2.o vga.o apb_pci.o
83469015 505VL_OBJS+= fdc.o mc146818rtc.o serial.o m48t59.o
20c9f095 506VL_OBJS+= cirrus_vga.o parallel.o ptimer.o
3475187d 507else
67e999be
FB
508VL_OBJS+= sun4m.o tcx.o pcnet.o iommu.o m48t59.o slavio_intctl.o
509VL_OBJS+= slavio_timer.o slavio_serial.o slavio_misc.o fdc.o esp.o sparc32_dma.o
8d05ea8a 510VL_OBJS+= cs4231.o ptimer.o
3475187d 511endif
e95c8d51 512endif
b5ff1b31 513ifeq ($(TARGET_BASE_ARCH), arm)
cdbdb648 514VL_OBJS+= integratorcp.o versatilepb.o ps2.o smc91c111.o arm_pic.o arm_timer.o
7e1543c2 515VL_OBJS+= arm_boot.o pl011.o pl031.o pl050.o pl080.o pl110.o pl181.o pl190.o
6963d7af 516VL_OBJS+= versatile_pci.o sd.o ptimer.o
e69954b9 517VL_OBJS+= arm_gic.o realview.o arm_sysctl.o
8e71621f 518VL_OBJS+= arm-semi.o
b00052e4 519VL_OBJS+= pxa2xx.o pxa2xx_pic.o pxa2xx_gpio.o pxa2xx_timer.o pxa2xx_dma.o
adb86c37 520VL_OBJS+= pxa2xx_lcd.o pxa2xx_mmci.o pxa2xx_pcmcia.o max111x.o max7310.o
3efda49d 521VL_OBJS+= spitz.o ads7846.o ide.o serial.o nand.o ecc.o $(AUDIODRV) wm8750.o
02645926
AZ
522VL_OBJS+= omap.o omap_lcdc.o omap1_clk.o omap_mmc.o omap_i2c.o
523VL_OBJS+= palm.o tsc210x.o
5a1237c4 524CPPFLAGS += -DHAS_AUDIO
b5ff1b31 525endif
fdf9b3e8 526ifeq ($(TARGET_BASE_ARCH), sh4)
0d78f544 527VL_OBJS+= shix.o r2d.o sh7750.o sh7750_regnames.o tc58128.o
80f515e6 528VL_OBJS+= sh_timer.o ptimer.o sh_serial.o sh_intc.o
fdf9b3e8 529endif
0633879f 530ifeq ($(TARGET_BASE_ARCH), m68k)
7e049b8a 531VL_OBJS+= an5206.o mcf5206.o ptimer.o mcf_uart.o mcf_intc.o mcf5208.o mcf_fec.o
a87295e8 532VL_OBJS+= m68k-semi.o
0633879f 533endif
a541f297 534ifdef CONFIG_GDBSTUB
5fafdf24 535VL_OBJS+=gdbstub.o
728c9fd5 536endif
626df76a 537ifdef CONFIG_SDL
6070dd07 538VL_OBJS+=sdl.o x_keymap.o
de5eaa64 539endif
70848515 540VL_OBJS+=vnc.o d3des.o
5b0753e0
FB
541ifdef CONFIG_COCOA
542VL_OBJS+=cocoa.o
1d14ffa9
FB
543COCOA_LIBS=-F/System/Library/Frameworks -framework Cocoa -framework IOKit
544ifdef CONFIG_COREAUDIO
545COCOA_LIBS+=-framework CoreAudio
546endif
5b0753e0 547endif
7c1f25b4 548ifdef CONFIG_SLIRP
6f30fa85 549CPPFLAGS+=-I$(SRC_PATH)/slirp
7c1f25b4
FB
550SLIRP_OBJS=cksum.o if.o ip_icmp.o ip_input.o ip_output.o \
551slirp.o mbuf.o misc.o sbuf.o socket.o tcp_input.o tcp_output.o \
c7f74643 552tcp_subr.o tcp_timer.o udp.o bootp.o debug.o tftp.o
7c1f25b4 553VL_OBJS+=$(addprefix slirp/, $(SLIRP_OBJS))
626df76a
FB
554endif
555
db8d7dd1 556VL_LDFLAGS=$(VL_OS_LDFLAGS)
70956b77 557VL_LIBS=$(AIOLIBS)
c321f673 558# specific flags are needed for non soft mmu emulator
c321f673
FB
559ifdef CONFIG_STATIC
560VL_LDFLAGS+=-static
561endif
de5eaa64 562ifndef CONFIG_SOFTMMU
5fafdf24 563VL_LDFLAGS+=-Wl,-T,$(SRC_PATH)/i386-vl.ld
de5eaa64 564endif
83fb7adf 565ifndef CONFIG_DARWIN
11d9f695 566ifndef CONFIG_WIN32
ec530c81 567ifndef CONFIG_SOLARIS
70956b77 568VL_LIBS+=-lutil
11d9f695 569endif
83fb7adf 570endif
ec530c81 571endif
e3086fbf 572ifdef TARGET_GPROF
6f30fa85 573vl.o: BASE_CFLAGS+=-p
e3086fbf
FB
574VL_LDFLAGS+=-p
575endif
c321f673 576
b8076a74
FB
577ifeq ($(ARCH),ia64)
578VL_LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/ia64.ld
579endif
580
74ccb34e 581ifeq ($(ARCH),sparc64)
3142255c
BS
582 VL_LDFLAGS+=-m64
583 ifneq ($(CONFIG_SOLARIS),yes)
584 VL_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
585 endif
74ccb34e
FB
586endif
587
1d14ffa9
FB
588ifdef CONFIG_WIN32
589SDL_LIBS := $(filter-out -mwindows, $(SDL_LIBS)) -mconsole
590endif
591
1e43adfc 592$(QEMU_SYSTEM): $(VL_OBJS) libqemu.a
3a11702b 593 $(CC) $(VL_LDFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS) $(SDL_LIBS) $(COCOA_LIBS) $(VL_LIBS)
5b0753e0
FB
594
595cocoa.o: cocoa.m
6f30fa85 596 $(CC) $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
626df76a 597
3d11d0eb 598sdl.o: sdl.c keymaps.c sdl_keysym.h
6f30fa85 599 $(CC) $(CFLAGS) $(CPPFLAGS) $(SDL_CFLAGS) $(BASE_CFLAGS) -c -o $@ $<
626df76a 600
70848515 601vnc.o: vnc.c keymaps.c sdl_keysym.h vnchextile.h d3des.c d3des.h
6f30fa85 602 $(CC) $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
24236869 603
9f059eca 604sdlaudio.o: sdlaudio.c
6f30fa85 605 $(CC) $(CFLAGS) $(CPPFLAGS) $(SDL_CFLAGS) $(BASE_CFLAGS) -c -o $@ $<
9f059eca 606
626df76a 607depend: $(SRCS)
6f30fa85 608 $(CC) -MM $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) $^ 1>.depend
626df76a 609
1d14ffa9 610vldepend: $(VL_OBJS:.o=.c)
6f30fa85 611 $(CC) -MM $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) $^ 1>.depend
1d14ffa9 612
5fafdf24 613# libqemu
626df76a
FB
614
615libqemu.a: $(LIBOBJS)
616 rm -f $@
617 $(AR) rcs $@ $(LIBOBJS)
618
1e43adfc 619translate.o: translate.c gen-op.h opc.h cpu.h
626df76a 620
158142c2
FB
621translate-all.o: translate-all.c opc.h cpu.h
622
623translate-op.o: translate-all.c op.h opc.h cpu.h
626df76a 624
1e43adfc 625op.h: op.o $(DYNGEN)
626df76a
FB
626 $(DYNGEN) -o $@ $<
627
1e43adfc 628opc.h: op.o $(DYNGEN)
626df76a
FB
629 $(DYNGEN) -c -o $@ $<
630
1e43adfc 631gen-op.h: op.o $(DYNGEN)
626df76a
FB
632 $(DYNGEN) -g -o $@ $<
633
1e43adfc 634op.o: op.c
6f30fa85 635 $(CC) $(OP_CFLAGS) $(CPPFLAGS) -c -o $@ $<
626df76a 636
6e1b3e4d
FB
637# HELPER_CFLAGS is used for all the code compiled with static register
638# variables
639ifeq ($(TARGET_BASE_ARCH), i386)
640# XXX: rename helper.c to op_helper.c
1e43adfc 641helper.o: helper.c
6f30fa85 642 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
6e1b3e4d
FB
643else
644op_helper.o: op_helper.c
6f30fa85 645 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
6e1b3e4d
FB
646endif
647
648cpu-exec.o: cpu-exec.c
6f30fa85 649 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
626df76a 650
00a67ba1
FB
651# Note: this is a workaround. The real fix is to avoid compiling
652# cpu_signal_handler() in cpu-exec.c.
653signal.o: signal.c
6f30fa85 654 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
00a67ba1 655
626df76a 656%.o: %.c
6f30fa85 657 $(CC) $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
626df76a 658
f72b519c 659%.o: %.S
6f30fa85 660 $(CC) $(CPPFLAGS) -c -o $@ $<
f72b519c 661
626df76a 662clean:
2f96c28d
JM
663 rm -f *.o *.a *~ $(PROGS) gen-op.h opc.h op.h nwfpe/*.o slirp/*.o fpu/*.o
664 rm -f *.d */*.d
1e43adfc 665
5fafdf24 666install: all
9b14bb04 667ifneq ($(PROGS),)
6a882643 668 $(INSTALL) -m 755 -s $(PROGS) "$(DESTDIR)$(bindir)"
9b14bb04 669endif
626df76a
FB
670
671ifneq ($(wildcard .depend),)
672include .depend
673endif
1d14ffa9 674
c0fe3827 675ifeq (1, 0)
1d14ffa9 676audio.o sdlaudio.o dsoundaudio.o ossaudio.o wavaudio.o noaudio.o \
c0fe3827 677fmodaudio.o alsaaudio.o mixeng.o sb16.o es1370.o gus.o adlib.o: \
1d14ffa9
FB
678CFLAGS := $(CFLAGS) -Wall -Werror -W -Wsign-compare
679endif
2f96c28d
JM
680
681# Include automatically generated dependency files
682-include $(wildcard *.d */*.d)