]> git.proxmox.com Git - qemu.git/blame - Makefile.target
sd.c build fix.
[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
faf07963 27CPPFLAGS=-I. -I.. -I$(TARGET_PATH) -I$(SRC_PATH) -MMD -MP -DNEED_CPU_H
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 \
579a97f7 263 elfload.o linuxload.o uaccess.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
626df76a
FB
305endif
306
0b0babc6
FB
307ifeq ($(TARGET_ARCH), x86_64)
308LIBOBJS+=helper.o helper2.o
309endif
310
a2458627 311ifeq ($(TARGET_BASE_ARCH), ppc)
728c9fd5 312LIBOBJS+= op_helper.o helper.o
67867308
FB
313endif
314
fbe4f65b 315ifeq ($(TARGET_BASE_ARCH), mips)
6af0bf9c
FB
316LIBOBJS+= op_helper.o helper.o
317endif
318
64b3ab24 319ifeq ($(TARGET_BASE_ARCH), sparc)
e95c8d51
FB
320LIBOBJS+= op_helper.o helper.o
321endif
322
b7bcbe95 323ifeq ($(TARGET_BASE_ARCH), arm)
b5ff1b31 324LIBOBJS+= op_helper.o helper.o
b7bcbe95
FB
325endif
326
fdf9b3e8
FB
327ifeq ($(TARGET_BASE_ARCH), sh4)
328LIBOBJS+= op_helper.o helper.o
329endif
330
e6e5906b 331ifeq ($(TARGET_BASE_ARCH), m68k)
0633879f 332LIBOBJS+= op_helper.o helper.o
e6e5906b
PB
333endif
334
cf6c1b16
JM
335ifeq ($(TARGET_BASE_ARCH), alpha)
336LIBOBJS+= op_helper.o helper.o alpha_palcode.o
337endif
338
e7daa605
TS
339ifeq ($(TARGET_BASE_ARCH), cris)
340LIBOBJS+= op_helper.o helper.o
341LIBOBJS+= cris-dis.o
342
343ifndef CONFIG_USER_ONLY
344LIBOBJS+= mmu.o
345endif
346endif
347
626df76a 348# NOTE: the disassembler code is only needed for debugging
5fafdf24 349LIBOBJS+=disas.o
626df76a 350ifeq ($(findstring i386, $(TARGET_ARCH) $(ARCH)),i386)
bc51c5c9
FB
351USE_I386_DIS=y
352endif
0b0babc6 353ifeq ($(findstring x86_64, $(TARGET_ARCH) $(ARCH)),x86_64)
bc51c5c9
FB
354USE_I386_DIS=y
355endif
356ifdef USE_I386_DIS
626df76a
FB
357LIBOBJS+=i386-dis.o
358endif
359ifeq ($(findstring alpha, $(TARGET_ARCH) $(ARCH)),alpha)
360LIBOBJS+=alpha-dis.o
361endif
a2458627 362ifeq ($(findstring ppc, $(TARGET_BASE_ARCH) $(ARCH)),ppc)
626df76a
FB
363LIBOBJS+=ppc-dis.o
364endif
fbe4f65b 365ifeq ($(findstring mips, $(TARGET_BASE_ARCH) $(ARCH)),mips)
6af0bf9c
FB
366LIBOBJS+=mips-dis.o
367endif
64b3ab24 368ifeq ($(findstring sparc, $(TARGET_BASE_ARCH) $(ARCH)),sparc)
626df76a
FB
369LIBOBJS+=sparc-dis.o
370endif
371ifeq ($(findstring arm, $(TARGET_ARCH) $(ARCH)),arm)
372LIBOBJS+=arm-dis.o
373endif
48024e4a
FB
374ifeq ($(findstring m68k, $(TARGET_ARCH) $(ARCH)),m68k)
375LIBOBJS+=m68k-dis.o
376endif
fdf9b3e8
FB
377ifeq ($(findstring sh4, $(TARGET_ARCH) $(ARCH)),sh4)
378LIBOBJS+=sh4-dis.o
379endif
8f860bb8
TS
380ifeq ($(findstring s390, $(TARGET_ARCH) $(ARCH)),s390)
381LIBOBJS+=s390-dis.o
382endif
626df76a 383
1fddef4b
FB
384ifdef CONFIG_GDBSTUB
385OBJS+=gdbstub.o
386endif
626df76a 387
1e43adfc 388all: $(PROGS)
626df76a 389
1e43adfc 390$(QEMU_USER): $(OBJS)
6f30fa85 391 $(CC) $(LDFLAGS) $(BASE_LDFLAGS) -o $@ $^ $(LIBS)
626df76a
FB
392ifeq ($(ARCH),alpha)
393# Mark as 32 bit binary, i. e. it will be mapped into the low 31 bit of
394# the address space (31 bit so sign extending doesn't matter)
395 echo -ne '\001\000\000\000' | dd of=qemu bs=1 seek=48 count=4 conv=notrunc
396endif
397
398# must use static linking to avoid leaving stuff in virtual address space
4fb240a4
FB
399VL_OBJS=vl.o osdep.o monitor.o pci.o loader.o isa_mmio.o
400# XXX: suppress QEMU_TOOL tests
faf07963 401VL_OBJS+=block-raw.o
d537cf6c 402VL_OBJS+=irq.o
a541f297 403
1d14ffa9 404ifdef CONFIG_ALSA
1d14ffa9
FB
405LIBS += -lasound
406endif
407ifdef CONFIG_DSOUND
1d14ffa9 408LIBS += -lole32 -ldxguid
85571bc7 409endif
102a52e4 410ifdef CONFIG_FMOD
102a52e4 411LIBS += $(CONFIG_FMOD_LIB)
85571bc7 412endif
4fb240a4
FB
413
414SOUND_HW = sb16.o es1370.o
1d14ffa9
FB
415ifdef CONFIG_ADLIB
416SOUND_HW += fmopl.o adlib.o
417endif
85571bc7 418
8d5d2d4c
TS
419ifdef CONFIG_VNC_TLS
420CPPFLAGS += $(CONFIG_VNC_TLS_CFLAGS)
421LIBS += $(CONFIG_VNC_TLS_LIBS)
422endif
423
0ff596d0
PB
424VL_OBJS += i2c.o smbus.o
425
2e5d83bb 426# SCSI layer
7d8406be 427VL_OBJS+= scsi-disk.o cdrom.o lsi53c895a.o
2e5d83bb 428
a594cfbf 429# USB layer
2e5d83bb 430VL_OBJS+= usb.o usb-hub.o usb-linux.o usb-hid.o usb-ohci.o usb-msd.o
f6d2a316 431VL_OBJS+= usb-wacom.o
a594cfbf 432
663e8e51
TS
433# EEPROM emulation
434VL_OBJS += eeprom93xx.o
435
a41b2ff2 436# PCI network cards
663e8e51
TS
437VL_OBJS += eepro100.o
438VL_OBJS += ne2000.o
439VL_OBJS += pcnet.o
440VL_OBJS += rtl8139.o
a41b2ff2 441
0b0babc6 442ifeq ($(TARGET_BASE_ARCH), i386)
a541f297 443# Hardware support
4fb240a4 444VL_OBJS+= ide.o pckbd.o ps2.o vga.o $(SOUND_HW) dma.o
fd06c375 445VL_OBJS+= fdc.o mc146818rtc.o serial.o i8259.o i8254.o pcspk.o pc.o
b00052e4 446VL_OBJS+= cirrus_vga.o apic.o parallel.o acpi.o piix_pci.o
591a6d62 447VL_OBJS+= usb-uhci.o smbus_eeprom.o vmmouse.o vmport.o vmware_vga.o
b00052e4 448CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
67b915a5 449endif
a2458627 450ifeq ($(TARGET_BASE_ARCH), ppc)
b00052e4 451CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
3cbee15b 452# shared objects
4fb240a4 453VL_OBJS+= ppc.o ide.o vga.o $(SOUND_HW) dma.o openpic.o
3cbee15b
JM
454# PREP target
455VL_OBJS+= pckbd.o ps2.o serial.o i8259.o i8254.o fdc.o m48t59.o mc146818rtc.o
456VL_OBJS+= prep_pci.o ppc_prep.o
457# Mac shared devices
458VL_OBJS+= macio.o cuda.o adb.o mac_nvram.o mac_dbdma.o
459# OldWorld PowerMac
460VL_OBJS+= heathrow_pic.o grackle_pci.o ppc_oldworld.o
461# NewWorld PowerMac
462VL_OBJS+= unin_pci.o ppc_chrp.o
463# PowerPC 4xx boards
464VL_OBJS+= pflash_cfi02.o ppc4xx_devs.o ppc405_uc.o ppc405_boards.o
a541f297 465endif
fbe4f65b 466ifeq ($(TARGET_BASE_ARCH), mips)
6bf5b4e8 467VL_OBJS+= mips_r4k.o mips_malta.o mips_pica61.o mips_mipssim.o
ad6fe1d2 468VL_OBJS+= mips_timer.o mips_int.o dma.o vga.o serial.o i8254.o i8259.o
31211df1 469VL_OBJS+= jazz_led.o
9542611a 470VL_OBJS+= ide.o gt64xxx.o pckbd.o ps2.o fdc.o mc146818rtc.o usb-uhci.o acpi.o ds1225y.o
4fb240a4 471VL_OBJS+= piix_pci.o smbus_eeprom.o parallel.o cirrus_vga.o $(SOUND_HW)
6bf5b4e8 472VL_OBJS+= mipsnet.o
83b1fb88 473CPPFLAGS += -DHAS_AUDIO
6af0bf9c 474endif
e7daa605
TS
475ifeq ($(TARGET_BASE_ARCH), cris)
476VL_OBJS+= etraxfs.o
477VL_OBJS+= ptimer.o
478VL_OBJS+= etraxfs_timer.o
479VL_OBJS+= etraxfs_ser.o
480endif
64b3ab24 481ifeq ($(TARGET_BASE_ARCH), sparc)
3475187d 482ifeq ($(TARGET_ARCH), sparc64)
502a5395 483VL_OBJS+= sun4u.o ide.o pckbd.o ps2.o vga.o apb_pci.o
83469015 484VL_OBJS+= fdc.o mc146818rtc.o serial.o m48t59.o
20c9f095 485VL_OBJS+= cirrus_vga.o parallel.o ptimer.o
3475187d 486else
67e999be
FB
487VL_OBJS+= sun4m.o tcx.o pcnet.o iommu.o m48t59.o slavio_intctl.o
488VL_OBJS+= slavio_timer.o slavio_serial.o slavio_misc.o fdc.o esp.o sparc32_dma.o
8d05ea8a 489VL_OBJS+= cs4231.o ptimer.o
3475187d 490endif
e95c8d51 491endif
b5ff1b31 492ifeq ($(TARGET_BASE_ARCH), arm)
cdbdb648 493VL_OBJS+= integratorcp.o versatilepb.o ps2.o smc91c111.o arm_pic.o arm_timer.o
7e1543c2 494VL_OBJS+= arm_boot.o pl011.o pl031.o pl050.o pl080.o pl110.o pl181.o pl190.o
6963d7af 495VL_OBJS+= versatile_pci.o sd.o ptimer.o
9ee6e8bb 496VL_OBJS+= realview_gic.o realview.o arm_sysctl.o mpcore.o
aba9ee87 497VL_OBJS+= armv7m.o armv7m_nvic.o stellaris.o ssd0303.o pl022.o
9ee6e8bb 498VL_OBJS+= ssd0323.o pl061.o
8e71621f 499VL_OBJS+= arm-semi.o
b00052e4 500VL_OBJS+= pxa2xx.o pxa2xx_pic.o pxa2xx_gpio.o pxa2xx_timer.o pxa2xx_dma.o
adb86c37 501VL_OBJS+= pxa2xx_lcd.o pxa2xx_mmci.o pxa2xx_pcmcia.o max111x.o max7310.o
05ee37eb 502VL_OBJS+= pflash_cfi01.o gumstix.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
ca02f319 514VL_OBJS+= m68k-semi.o dummy_m68k.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)