]> git.proxmox.com Git - qemu.git/blame - Makefile.target
Support alternative formats for MAC addresses, by Balazs Attila-Mihaly.
[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)
8a0ef219
TS
143 ifneq ($(CONFIG_SOLARIS),yes)
144 BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
145 endif
bc51c5c9
FB
146endif
147
626df76a 148ifeq ($(ARCH),ppc)
6f30fa85
TS
149CPPFLAGS+= -D__powerpc__
150BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
626df76a
FB
151endif
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
66f1cdbd 164 HELPER_CFLAGS=$(CFLAGS) -ffixed-i0
3142255c
BS
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
223d4670
TS
401ifdef CONFIG_WIN32
402VL_OBJS+=block-raw-win32.o
403else
404VL_OBJS+=block-raw-posix.o
405endif
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
2e5d83bb 427# SCSI layer
87ecb68b 428VL_OBJS+= lsi53c895a.o
2e5d83bb 429
a594cfbf 430# USB layer
87ecb68b 431VL_OBJS+= usb-ohci.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
87ecb68b 447VL_OBJS+= usb-uhci.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
87ecb68b 471VL_OBJS+= piix_pci.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
7eb0c8e8 489VL_OBJS+= cs4231.o ptimer.o eccmemctl.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
775616c3 495VL_OBJS+= versatile_pci.o ptimer.o
9ee6e8bb 496VL_OBJS+= realview_gic.o realview.o arm_sysctl.o mpcore.o
eea589cc 497VL_OBJS+= armv7m.o armv7m_nvic.o stellaris.o pl022.o stellaris_enet.o
87ecb68b 498VL_OBJS+= 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
87ecb68b 501VL_OBJS+= pxa2xx_lcd.o pxa2xx_mmci.o pxa2xx_pcmcia.o
05ee37eb 502VL_OBJS+= pflash_cfi01.o gumstix.o
7233b355 503VL_OBJS+= spitz.o ide.o serial.o nand.o ecc.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
7233b355 506VL_OBJS+= mst_fpga.o mainstone.o
5a1237c4 507CPPFLAGS += -DHAS_AUDIO
b5ff1b31 508endif
fdf9b3e8 509ifeq ($(TARGET_BASE_ARCH), sh4)
0d78f544 510VL_OBJS+= shix.o r2d.o sh7750.o sh7750_regnames.o tc58128.o
80f515e6 511VL_OBJS+= sh_timer.o ptimer.o sh_serial.o sh_intc.o
fdf9b3e8 512endif
0633879f 513ifeq ($(TARGET_BASE_ARCH), m68k)
7e049b8a 514VL_OBJS+= an5206.o mcf5206.o ptimer.o mcf_uart.o mcf_intc.o mcf5208.o mcf_fec.o
ca02f319 515VL_OBJS+= m68k-semi.o dummy_m68k.o
0633879f 516endif
a541f297 517ifdef CONFIG_GDBSTUB
5fafdf24 518VL_OBJS+=gdbstub.o
728c9fd5 519endif
5b0753e0 520ifdef CONFIG_COCOA
1d14ffa9
FB
521COCOA_LIBS=-F/System/Library/Frameworks -framework Cocoa -framework IOKit
522ifdef CONFIG_COREAUDIO
523COCOA_LIBS+=-framework CoreAudio
524endif
5b0753e0 525endif
7c1f25b4 526ifdef CONFIG_SLIRP
6f30fa85 527CPPFLAGS+=-I$(SRC_PATH)/slirp
626df76a
FB
528endif
529
db8d7dd1 530VL_LDFLAGS=$(VL_OS_LDFLAGS)
70956b77 531VL_LIBS=$(AIOLIBS)
c321f673 532# specific flags are needed for non soft mmu emulator
c321f673
FB
533ifdef CONFIG_STATIC
534VL_LDFLAGS+=-static
535endif
de5eaa64 536ifndef CONFIG_SOFTMMU
5fafdf24 537VL_LDFLAGS+=-Wl,-T,$(SRC_PATH)/i386-vl.ld
de5eaa64 538endif
83fb7adf 539ifndef CONFIG_DARWIN
11d9f695 540ifndef CONFIG_WIN32
ec530c81 541ifndef CONFIG_SOLARIS
70956b77 542VL_LIBS+=-lutil
11d9f695 543endif
83fb7adf 544endif
ec530c81 545endif
e3086fbf 546ifdef TARGET_GPROF
6f30fa85 547vl.o: BASE_CFLAGS+=-p
e3086fbf
FB
548VL_LDFLAGS+=-p
549endif
c321f673 550
b8076a74
FB
551ifeq ($(ARCH),ia64)
552VL_LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/ia64.ld
553endif
554
74ccb34e 555ifeq ($(ARCH),sparc64)
3142255c
BS
556 VL_LDFLAGS+=-m64
557 ifneq ($(CONFIG_SOLARIS),yes)
558 VL_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
559 endif
8a0ef219
TS
560endif
561
562ifeq ($(ARCH),x86_64)
563 VL_LDFLAGS+=-m64
564 ifneq ($(CONFIG_SOLARIS),yes)
565 VL_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
566 endif
74ccb34e
FB
567endif
568
1d14ffa9
FB
569ifdef CONFIG_WIN32
570SDL_LIBS := $(filter-out -mwindows, $(SDL_LIBS)) -mconsole
571endif
572
4fb240a4 573$(QEMU_SYSTEM): $(VL_OBJS) ../libqemu_common.a libqemu.a
3a11702b 574 $(CC) $(VL_LDFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS) $(SDL_LIBS) $(COCOA_LIBS) $(VL_LIBS)
5b0753e0 575
626df76a 576depend: $(SRCS)
6f30fa85 577 $(CC) -MM $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) $^ 1>.depend
626df76a 578
1d14ffa9 579vldepend: $(VL_OBJS:.o=.c)
6f30fa85 580 $(CC) -MM $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) $^ 1>.depend
1d14ffa9 581
5fafdf24 582# libqemu
626df76a
FB
583
584libqemu.a: $(LIBOBJS)
585 rm -f $@
586 $(AR) rcs $@ $(LIBOBJS)
587
1e43adfc 588translate.o: translate.c gen-op.h opc.h cpu.h
626df76a 589
158142c2
FB
590translate-all.o: translate-all.c opc.h cpu.h
591
592translate-op.o: translate-all.c op.h opc.h cpu.h
626df76a 593
1e43adfc 594op.h: op.o $(DYNGEN)
626df76a
FB
595 $(DYNGEN) -o $@ $<
596
1e43adfc 597opc.h: op.o $(DYNGEN)
626df76a
FB
598 $(DYNGEN) -c -o $@ $<
599
1e43adfc 600gen-op.h: op.o $(DYNGEN)
626df76a
FB
601 $(DYNGEN) -g -o $@ $<
602
1e43adfc 603op.o: op.c
6f30fa85 604 $(CC) $(OP_CFLAGS) $(CPPFLAGS) -c -o $@ $<
626df76a 605
6e1b3e4d
FB
606# HELPER_CFLAGS is used for all the code compiled with static register
607# variables
608ifeq ($(TARGET_BASE_ARCH), i386)
609# XXX: rename helper.c to op_helper.c
1e43adfc 610helper.o: helper.c
6f30fa85 611 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
6e1b3e4d
FB
612else
613op_helper.o: op_helper.c
6f30fa85 614 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
6e1b3e4d
FB
615endif
616
617cpu-exec.o: cpu-exec.c
6f30fa85 618 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
626df76a 619
00a67ba1
FB
620# Note: this is a workaround. The real fix is to avoid compiling
621# cpu_signal_handler() in cpu-exec.c.
622signal.o: signal.c
6f30fa85 623 $(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
00a67ba1 624
626df76a 625%.o: %.c
6f30fa85 626 $(CC) $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
626df76a 627
f72b519c 628%.o: %.S
6f30fa85 629 $(CC) $(CPPFLAGS) -c -o $@ $<
f72b519c 630
626df76a 631clean:
4fb240a4 632 rm -f *.o *.a *~ $(PROGS) gen-op.h opc.h op.h nwfpe/*.o fpu/*.o
2f96c28d 633 rm -f *.d */*.d
1e43adfc 634
5fafdf24 635install: all
9b14bb04 636ifneq ($(PROGS),)
6a882643 637 $(INSTALL) -m 755 -s $(PROGS) "$(DESTDIR)$(bindir)"
9b14bb04 638endif
626df76a
FB
639
640ifneq ($(wildcard .depend),)
641include .depend
642endif
1d14ffa9 643
c0fe3827 644ifeq (1, 0)
1d14ffa9 645audio.o sdlaudio.o dsoundaudio.o ossaudio.o wavaudio.o noaudio.o \
c0fe3827 646fmodaudio.o alsaaudio.o mixeng.o sb16.o es1370.o gus.o adlib.o: \
1d14ffa9
FB
647CFLAGS := $(CFLAGS) -Wall -Werror -W -Wsign-compare
648endif
2f96c28d
JM
649
650# Include automatically generated dependency files
651-include $(wildcard *.d */*.d)