]> git.proxmox.com Git - qemu.git/blame - Makefile.target
PPC: Round VGA BIOS size to page boundary
[qemu.git] / Makefile.target
CommitLineData
626df76a 1include config.mak
17759187 2include $(SRC_PATH)/rules.mak
626df76a 3
0b0babc6 4TARGET_PATH=$(SRC_PATH)/target-$(TARGET_BASE_ARCH)
4fb240a4 5VPATH=$(SRC_PATH):$(TARGET_PATH):$(SRC_PATH)/hw
46dc3881 6CPPFLAGS=-I. -I.. -I$(TARGET_PATH) -I$(SRC_PATH) -MMD -MT $@ -MP -DNEED_CPU_H
0b0babc6 7#CFLAGS+=-Werror
626df76a 8LIBS=
40293e58
FB
9
10ifdef CONFIG_USER_ONLY
11# user emulator name
12QEMU_PROG=qemu-$(TARGET_ARCH2)
13else
1e43adfc 14# system emulator name
a541f297 15ifeq ($(TARGET_ARCH), i386)
40293e58 16QEMU_PROG=qemu$(EXESUF)
0db63474 17else
40293e58 18QEMU_PROG=qemu-system-$(TARGET_ARCH2)$(EXESUF)
a541f297 19endif
de5eaa64 20endif
626df76a 21
40293e58 22PROGS=$(QEMU_PROG)
626df76a 23
6c041c54 24# cc-option
c7328801 25# Usage: CFLAGS+=$(call cc-option, $(CFLAGS), -falign-functions=0, -malign-functions=0)
6c041c54 26
c7328801
AL
27cc-option = $(shell if $(CC) $(1) $(2) -S -o /dev/null -xc /dev/null \
28 > /dev/null 2>&1; then echo "$(2)"; else echo "$(3)"; fi ;)
6f30fa85 29
40293e58
FB
30HELPER_CFLAGS=
31
626df76a 32ifeq ($(ARCH),i386)
6f30fa85 33HELPER_CFLAGS+=-fomit-frame-pointer
bc51c5c9
FB
34endif
35
d19076fa 36ifeq ($(subst ppc64,ppc,$(ARCH))$(TARGET_BASE_ARCH),ppcppc)
37translate.o: CFLAGS := $(CFLAGS) $(call cc-option, $(CFLAGS), -fno-unit-at-a-time,)
38endif
39
626df76a 40ifeq ($(ARCH),sparc)
4c050b3f 41 ifneq ($(CONFIG_SOLARIS),y)
40293e58 42 HELPER_CFLAGS+=-ffixed-i0
3142255c 43 endif
fdbb4691 44endif
626df76a 45
626df76a 46ifeq ($(ARCH),alpha)
626df76a 47# Ensure there's only a single GP
40293e58 48CFLAGS+=-msmall-data
626df76a
FB
49endif
50
51ifeq ($(ARCH),ia64)
40293e58 52CFLAGS+=-mno-sdata
83fb7adf
FB
53endif
54
6f30fa85 55CPPFLAGS+=-D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE
4a244704 56CPPFLAGS+=-U_FORTIFY_SOURCE
626df76a 57LIBS+=-lm
67b915a5 58ifdef CONFIG_WIN32
3db38e87 59LIBS+=-lwinmm -lws2_32 -liphlpapi
67b915a5 60endif
ec530c81
FB
61ifdef CONFIG_SOLARIS
62LIBS+=-lsocket -lnsl -lresolv
0475a5ca
TS
63ifdef NEEDS_LIBSUNMATH
64LIBS+=-lsunmath
65LDFLAGS+=-L/opt/SUNWspro/prod/lib -R/opt/SUNWspro/prod/lib
40293e58 66CFLAGS+=-I/opt/SUNWspro/prod/include/cc
f72b519c 67endif
831b7825
TS
68endif
69
7ba1e619
AL
70kvm.o: CFLAGS+=$(KVM_CFLAGS)
71kvm-all.o: CFLAGS+=$(KVM_CFLAGS)
72
40293e58 73all: $(PROGS)
c2fb2637
PB
74# Dummy command so that make thinks it has done something
75 @true
626df76a 76
40293e58 77#########################################################
626df76a 78# cpu emulator library
c9e0df73 79libobj-y = exec.o translate-all.o cpu-exec.o translate.o host-utils.o
943e0a31 80libobj-$(CONFIG_KQEMU) += kqemu.o
57fec1fe 81# TCG code generator
c9e0df73 82libobj-y += tcg/tcg.o tcg/tcg-runtime.o
57fec1fe 83CPPFLAGS+=-I$(SRC_PATH)/tcg -I$(SRC_PATH)/tcg/$(ARCH)
8289b279
BS
84ifeq ($(ARCH),sparc64)
85CPPFLAGS+=-I$(SRC_PATH)/tcg/sparc
86endif
158142c2 87ifdef CONFIG_SOFTFLOAT
c9e0df73 88libobj-y += fpu/softfloat.o
158142c2 89else
c9e0df73 90libobj-y += fpu/softfloat-native.o
158142c2 91endif
6f30fa85 92CPPFLAGS+=-I$(SRC_PATH)/fpu
c9e0df73 93libobj-y += op_helper.o helper.o
e95c8d51 94
b7bcbe95 95ifeq ($(TARGET_BASE_ARCH), arm)
c9e0df73 96libobj-y += neon_helper.o iwmmxt_helper.o
e6e5906b
PB
97endif
98
cf6c1b16 99ifeq ($(TARGET_BASE_ARCH), alpha)
c9e0df73 100libobj-y += alpha_palcode.o
cf6c1b16
JM
101endif
102
e7daa605 103ifeq ($(TARGET_BASE_ARCH), cris)
c9e0df73 104libobj-y += cris-dis.o
e7daa605
TS
105
106ifndef CONFIG_USER_ONLY
c9e0df73 107libobj-y += mmu.o
e7daa605
TS
108endif
109endif
110
626df76a 111# NOTE: the disassembler code is only needed for debugging
c9e0df73 112libobj-y += disas.o
626df76a 113ifeq ($(findstring i386, $(TARGET_ARCH) $(ARCH)),i386)
bc51c5c9
FB
114USE_I386_DIS=y
115endif
0b0babc6 116ifeq ($(findstring x86_64, $(TARGET_ARCH) $(ARCH)),x86_64)
bc51c5c9
FB
117USE_I386_DIS=y
118endif
943e0a31 119libobj-$(USE_I386_DIS) += i386-dis.o
626df76a 120ifeq ($(findstring alpha, $(TARGET_ARCH) $(ARCH)),alpha)
c9e0df73 121libobj-y += alpha-dis.o
626df76a 122endif
a2458627 123ifeq ($(findstring ppc, $(TARGET_BASE_ARCH) $(ARCH)),ppc)
c9e0df73 124libobj-y += ppc-dis.o
626df76a 125endif
72b675ca 126ifeq ($(findstring microblaze, $(TARGET_BASE_ARCH) $(ARCH)),microblaze)
c9e0df73 127libobj-y += microblaze-dis.o
72b675ca 128ifndef CONFIG_USER_ONLY
c9e0df73 129libobj-y += mmu.o
72b675ca
EI
130endif
131endif
fbe4f65b 132ifeq ($(findstring mips, $(TARGET_BASE_ARCH) $(ARCH)),mips)
c9e0df73 133libobj-y += mips-dis.o
6af0bf9c 134endif
64b3ab24 135ifeq ($(findstring sparc, $(TARGET_BASE_ARCH) $(ARCH)),sparc)
c9e0df73 136libobj-y += sparc-dis.o
626df76a
FB
137endif
138ifeq ($(findstring arm, $(TARGET_ARCH) $(ARCH)),arm)
c9e0df73 139libobj-y += arm-dis.o
626df76a 140endif
48024e4a 141ifeq ($(findstring m68k, $(TARGET_ARCH) $(ARCH)),m68k)
c9e0df73 142libobj-y += m68k-dis.o
48024e4a 143endif
fdf9b3e8 144ifeq ($(findstring sh4, $(TARGET_ARCH) $(ARCH)),sh4)
c9e0df73 145libobj-y += sh4-dis.o
fdf9b3e8 146endif
f54b3f92 147ifeq ($(findstring hppa, $(TARGET_BASE_ARCH) $(ARCH)),hppa)
c9e0df73 148libobj-y += hppa-dis.o
f54b3f92 149endif
8f860bb8 150ifeq ($(findstring s390, $(TARGET_ARCH) $(ARCH)),s390)
c9e0df73 151libobj-y += s390-dis.o
8f860bb8 152endif
626df76a 153
40293e58
FB
154# libqemu
155
c9e0df73 156libqemu.a: $(libobj-y)
40293e58 157
86e840ee 158translate.o: translate.c cpu.h
40293e58 159
86e840ee 160translate-all.o: translate-all.c cpu.h
40293e58 161
86e840ee 162tcg/tcg.o: cpu.h
40293e58
FB
163
164# HELPER_CFLAGS is used for all the code compiled with static register
165# variables
71c4f21f 166op_helper.o: CFLAGS += $(HELPER_CFLAGS)
40293e58 167
807544e2 168cpu-exec.o: CFLAGS += $(HELPER_CFLAGS)
40293e58
FB
169
170#########################################################
171# Linux user emulator target
172
173ifdef CONFIG_LINUX_USER
174
3ebdd119 175VPATH+=:$(SRC_PATH)/linux-user:$(SRC_PATH)/linux-user/$(TARGET_ABI_DIR)
40293e58
FB
176CPPFLAGS+=-I$(SRC_PATH)/linux-user -I$(SRC_PATH)/linux-user/$(TARGET_ABI_DIR)
177
178ifdef CONFIG_STATIC
179LDFLAGS+=-static
180endif
181
182ifeq ($(ARCH),i386)
183ifdef TARGET_GPROF
184USE_I386_LD=y
185endif
186ifdef CONFIG_STATIC
187USE_I386_LD=y
188endif
189ifdef USE_I386_LD
190LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
191else
192# WARNING: this LDFLAGS is _very_ tricky : qemu is an ELF shared object
193# that the kernel ELF loader considers as an executable. I think this
194# is the simplest way to make it self virtualizable!
195LDFLAGS+=-Wl,-shared
196endif
197endif
198
199ifeq ($(ARCH),x86_64)
200LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
201endif
202
203ifeq ($(ARCH),ppc)
204LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
205endif
206
810260a8 207ifeq ($(ARCH),ppc64)
208LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
209endif
210
40293e58
FB
211ifeq ($(ARCH),s390)
212LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
213endif
214
215ifeq ($(ARCH),sparc)
216# -static is used to avoid g1/g3 usage by the dynamic linker
217LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld -static
218endif
219
220ifeq ($(ARCH),sparc64)
221LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
222endif
223
224ifeq ($(ARCH),alpha)
225LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
226endif
227
228ifeq ($(ARCH),ia64)
229LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/$(ARCH).ld
230endif
231
232ifeq ($(ARCH),arm)
233LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
234endif
235
236ifeq ($(ARCH),m68k)
237LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
238endif
239
240ifeq ($(ARCH),mips)
241ifeq ($(WORDS_BIGENDIAN),yes)
242LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
243else
244LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH)el.ld
245endif
246endif
247
248ifeq ($(ARCH),mips64)
249ifeq ($(WORDS_BIGENDIAN),yes)
250LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
251else
252LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH)el.ld
253endif
254endif
255
6d946cda
AJ
256# profiling code
257ifdef TARGET_GPROF
258LDFLAGS+=-p
259CFLAGS+=-p
260endif
261
a8e492c0 262obj-y = main.o syscall.o strace.o mmap.o signal.o path.o thunk.o \
5f650495
IY
263 elfload.o linuxload.o uaccess.o envlist.o gdbstub.o gdbstub-xml.o \
264 ioport-user.o
943e0a31
JQ
265obj-$(TARGET_HAS_BFLT) += flatload.o
266
40293e58 267ifdef TARGET_HAS_ELFLOAD32
40293e58
FB
268elfload32.o: elfload.c
269endif
943e0a31 270obj-$(TARGET_HAS_ELFLOAD32) += elfload32.o
40293e58
FB
271
272ifeq ($(TARGET_ARCH), i386)
a8e492c0 273obj-y += vm86.o
40293e58 274endif
1c872672 275
9c1dd99b
JQ
276nwfpe-obj-y := fpa11.o fpa11_cpdo.o fpa11_cpdt.o fpa11_cprt.o fpopcode.o
277nwfpe-obj-y += single_cpdo.o double_cpdo.o extended_cpdo.o
1c872672
JQ
278obj-arm-y += $(addprefix nwfpe/, $(nwfpe-obj-y))
279obj-arm-y += arm-semi.o
280
281obj-m68k-y += m68k-sim.o m68k-semi.o
40293e58 282
40293e58
FB
283# Note: this is a workaround. The real fix is to avoid compiling
284# cpu_signal_handler() in cpu-exec.c.
807544e2 285signal.o: CFLAGS += $(HELPER_CFLAGS)
626df76a 286
16394485 287ARLIBS=../libqemu_user.a libqemu.a
40293e58
FB
288endif #CONFIG_LINUX_USER
289
0d35bf2d
AL
290LIBS+= $(PTHREADLIBS)
291LIBS+= $(CLOCKLIBS)
292
40293e58
FB
293#########################################################
294# Darwin user emulator target
295
296ifdef CONFIG_DARWIN_USER
297
298VPATH+=:$(SRC_PATH)/darwin-user
299CPPFLAGS+=-I$(SRC_PATH)/darwin-user -I$(SRC_PATH)/darwin-user/$(TARGET_ARCH)
300
301# Leave some space for the regular program loading zone
302LDFLAGS+=-Wl,-segaddr,__STD_PROG_ZONE,0x1000 -image_base 0x0e000000
303
304LIBS+=-lmx
305
a8e492c0 306obj-y = main.o commpage.o machload.o mmap.o signal.o syscall.o thunk.o \
5f650495 307 gdbstub.o gdbstub-xml.o ioport-user.o
40293e58 308
40293e58
FB
309# Note: this is a workaround. The real fix is to avoid compiling
310# cpu_signal_handler() in cpu-exec.c.
807544e2 311signal.o: CFLAGS += $(HELPER_CFLAGS)
40293e58 312
16394485 313ARLIBS=libqemu.a
40293e58
FB
314
315endif #CONFIG_DARWIN_USER
316
84778508
BS
317#########################################################
318# BSD user emulator target
319
320ifdef CONFIG_BSD_USER
321
322VPATH+=:$(SRC_PATH)/bsd-user
323CPPFLAGS+=-I$(SRC_PATH)/bsd-user -I$(SRC_PATH)/bsd-user/$(TARGET_ARCH)
324
325ifdef CONFIG_STATIC
326LDFLAGS+=-static
327endif
328
329ifeq ($(ARCH),i386)
330ifdef TARGET_GPROF
331USE_I386_LD=y
332endif
333ifdef CONFIG_STATIC
334USE_I386_LD=y
335endif
336ifdef USE_I386_LD
337LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
338else
339# WARNING: this LDFLAGS is _very_ tricky : qemu is an ELF shared object
340# that the kernel ELF loader considers as an executable. I think this
341# is the simplest way to make it self virtualizable!
342LDFLAGS+=-Wl,-shared
343endif
344endif
345
346ifeq ($(ARCH),x86_64)
347LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
348endif
349
350ifeq ($(ARCH),ppc)
351LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
352endif
353
354ifeq ($(ARCH),ppc64)
355LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
356endif
357
358ifeq ($(ARCH),s390)
359LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
360endif
361
362ifeq ($(ARCH),sparc)
363# -static is used to avoid g1/g3 usage by the dynamic linker
364LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld -static
365endif
366
367ifeq ($(ARCH),sparc64)
368LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
369endif
370
371ifeq ($(ARCH),alpha)
372LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
373endif
374
375ifeq ($(ARCH),ia64)
376LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/$(ARCH).ld
377endif
378
379ifeq ($(ARCH),arm)
380LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
381endif
382
383ifeq ($(ARCH),m68k)
384LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
385endif
386
387ifeq ($(ARCH),mips)
388ifeq ($(WORDS_BIGENDIAN),yes)
389LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
390else
391LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH)el.ld
392endif
393endif
394
395ifeq ($(ARCH),mips64)
396ifeq ($(WORDS_BIGENDIAN),yes)
397LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
398else
399LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH)el.ld
400endif
401endif
402
a8e492c0 403obj-y = main.o bsdload.o elfload.o mmap.o path.o signal.o strace.o syscall.o \
5f650495 404 gdbstub.o gdbstub-xml.o ioport-user.o
a8e492c0 405obj-y += uaccess.o
84778508 406
84778508
BS
407# Note: this is a workaround. The real fix is to avoid compiling
408# cpu_signal_handler() in cpu-exec.c.
807544e2 409signal.o: CFLAGS += $(HELPER_CFLAGS)
84778508 410
16394485 411ARLIBS=libqemu.a ../libqemu_user.a
84778508
BS
412
413endif #CONFIG_BSD_USER
414
40293e58
FB
415#########################################################
416# System emulator target
417ifndef CONFIG_USER_ONLY
418
a8e492c0 419obj-y = vl.o osdep.o monitor.o pci.o loader.o isa_mmio.o machine.o \
32993977 420 gdbstub.o gdbstub-xml.o msix.o ioport.o
1fd31ad7
AL
421# virtio has to be here due to weird dependency between PCI and virtio-net.
422# need to fix this properly
a8e492c0
JQ
423obj-y += virtio-blk.o virtio-balloon.o virtio-net.o virtio-console.o
424obj-$(CONFIG_KVM) += kvm.o kvm-all.o
a3392f9b 425
40293e58 426LIBS+=-lz
1d14ffa9 427ifdef CONFIG_ALSA
1d14ffa9
FB
428LIBS += -lasound
429endif
ca9cc28c
AZ
430ifdef CONFIG_ESD
431LIBS += -lesd
432endif
b8e59f18 433ifdef CONFIG_PA
434LIBS += -lpulse-simple
435endif
1d14ffa9 436ifdef CONFIG_DSOUND
1d14ffa9 437LIBS += -lole32 -ldxguid
85571bc7 438endif
102a52e4 439ifdef CONFIG_FMOD
102a52e4 440LIBS += $(CONFIG_FMOD_LIB)
85571bc7 441endif
2f6a1ab0
BS
442ifdef CONFIG_OSS
443LIBS += $(CONFIG_OSS_LIB)
444endif
4fb240a4 445
b6271b48
JQ
446sound-obj-y =
447sound-obj-$(CONFIG_SB16) += sb16.o
448sound-obj-$(CONFIG_ES1370) += es1370.o
449sound-obj-$(CONFIG_AC97) += ac97.o
450sound-obj-$(CONFIG_ADLIB) += fmopl.o adlib.o
451sound-obj-$(CONFIG_GUS) += gus.o gusemu_hal.o gusemu_mixer.o
57a943c4 452sound-obj-$(CONFIG_CS4231A) += cs4231a.o
b6271b48 453
1d14ffa9 454ifdef CONFIG_ADLIB
c40e866f 455adlib.o fmopl.o: CFLAGS := ${CFLAGS} -DBUILD_Y8950=0
1d14ffa9 456endif
85571bc7 457
8d5d2d4c
TS
458ifdef CONFIG_VNC_TLS
459CPPFLAGS += $(CONFIG_VNC_TLS_CFLAGS)
460LIBS += $(CONFIG_VNC_TLS_LIBS)
461endif
462
2f9606b3
AL
463ifdef CONFIG_VNC_SASL
464CPPFLAGS += $(CONFIG_VNC_SASL_CFLAGS)
465LIBS += $(CONFIG_VNC_SASL_LIBS)
466endif
467
fb599c9a
AZ
468ifdef CONFIG_BLUEZ
469LIBS += $(CONFIG_BLUEZ_LIBS)
470endif
471
e37630ca 472# xen backend driver support
943e0a31 473obj-$(CONFIG_XEN) += xen_machine_pv.o xen_domainbuild.o
7ed208c4 474ifeq ($(CONFIG_XEN), y)
e37630ca
AL
475 LIBS += $(XEN_LIBS)
476endif
477
a594cfbf 478# USB layer
a8e492c0 479obj-y += usb-ohci.o
a594cfbf 480
a41b2ff2 481# PCI network cards
a8e492c0
JQ
482obj-y += eepro100.o
483obj-y += ne2000.o
484obj-y += pcnet.o
485obj-y += rtl8139.o
486obj-y += e1000.o
a41b2ff2 487
9dd986cc 488# Generic watchdog support and some watchdog devices
a8e492c0 489obj-y += wdt_ib700.o wdt_i6300esb.o
9dd986cc 490
a541f297 491# Hardware support
9637443f
JQ
492obj-i386-y = ide.o pckbd.o vga.o $(sound-obj-y) dma.o
493obj-i386-y += fdc.o mc146818rtc.o serial.o i8259.o i8254.o pcspk.o pc.o
494obj-i386-y += cirrus_vga.o apic.o ioapic.o parallel.o acpi.o piix_pci.o
495obj-i386-y += usb-uhci.o vmmouse.o vmport.o vmware_vga.o hpet.o
496obj-i386-y += device-hotplug.o pci-hotplug.o smbios.o
497
498ifeq ($(TARGET_BASE_ARCH), i386)
b00052e4 499CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
67b915a5 500endif
9637443f 501
3cbee15b 502# shared objects
9637443f 503obj-ppc-y = ppc.o ide.o vga.o $(sound-obj-y) dma.o openpic.o
3cbee15b 504# PREP target
9637443f
JQ
505obj-ppc-y += pckbd.o serial.o i8259.o i8254.o fdc.o mc146818rtc.o
506obj-ppc-y += prep_pci.o ppc_prep.o
3cbee15b 507# Mac shared devices
9637443f 508obj-ppc-y += macio.o cuda.o adb.o mac_nvram.o mac_dbdma.o
3cbee15b 509# OldWorld PowerMac
9637443f 510obj-ppc-y += heathrow_pic.o grackle_pci.o ppc_oldworld.o
3cbee15b 511# NewWorld PowerMac
9637443f 512obj-ppc-y += unin_pci.o ppc_newworld.o
3cbee15b 513# PowerPC 4xx boards
9637443f
JQ
514obj-ppc-y += pflash_cfi02.o ppc4xx_devs.o ppc4xx_pci.o ppc405_uc.o ppc405_boards.o
515obj-ppc-y += ppc440.o ppc440_bamboo.o
74c62ba8 516# PowerPC E500 boards
9637443f
JQ
517obj-ppc-y += ppce500_pci.o ppce500_mpc8544ds.o
518obj-ppc-$(CONFIG_KVM) += kvm_ppc.o
519
520ifeq ($(TARGET_BASE_ARCH), ppc)
521CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
522endif
523
f652e6af 524ifdef FDT_LIBS
9637443f 525obj-ppc-y += device_tree.o
f652e6af
AJ
526LIBS+= $(FDT_LIBS)
527endif
9637443f
JQ
528
529obj-mips-y = mips_r4k.o mips_jazz.o mips_malta.o mips_mipssim.o
530obj-mips-y += mips_timer.o mips_int.o dma.o vga.o serial.o i8254.o i8259.o rc4030.o
531obj-mips-y += g364fb.o jazz_led.o dp8393x.o
532obj-mips-y += ide.o gt64xxx.o pckbd.o fdc.o mc146818rtc.o usb-uhci.o acpi.o ds1225y.o
533obj-mips-y += piix_pci.o parallel.o cirrus_vga.o pcspk.o $(sound-obj-y)
534obj-mips-y += mipsnet.o
535obj-mips-y += pflash_cfi01.o
536obj-mips-y += vmware_vga.o
537
fbe4f65b 538ifeq ($(TARGET_BASE_ARCH), mips)
4ce7ff6e 539CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
6af0bf9c 540endif
72b675ca 541
9637443f
JQ
542obj-microblaze-y = petalogix_s3adsp1800_mmu.o
543
544obj-microblaze-y += microblaze_pic_cpu.o
545obj-microblaze-y += xilinx_intc.o
546obj-microblaze-y += xilinx_timer.o
547obj-microblaze-y += xilinx_uartlite.o
548obj-microblaze-y += xilinx_ethlite.o
549
550obj-microblaze-y += pflash_cfi02.o
72b675ca 551
72b675ca 552ifdef FDT_LIBS
9637443f 553obj-microblaze-y += device_tree.o
72b675ca
EI
554LIBS+= $(FDT_LIBS)
555endif
9637443f 556
10c144e2 557# Boards
9637443f 558obj-cris-y = cris_pic_cpu.o etraxfs.o axis_dev88.o
10c144e2
EI
559
560# IO blocks
9637443f
JQ
561obj-cris-y += etraxfs_dma.o
562obj-cris-y += etraxfs_pic.o
563obj-cris-y += etraxfs_eth.o
564obj-cris-y += etraxfs_timer.o
565obj-cris-y += etraxfs_ser.o
566
567obj-cris-y += pflash_cfi02.o
e62b5b13 568
3475187d 569ifeq ($(TARGET_ARCH), sparc64)
9637443f
JQ
570obj-sparc-y = sun4u.o ide.o pckbd.o vga.o apb_pci.o
571obj-sparc-y += fdc.o mc146818rtc.o serial.o
572obj-sparc-y += cirrus_vga.o parallel.o
3475187d 573else
9637443f
JQ
574obj-sparc-y = sun4m.o tcx.o iommu.o slavio_intctl.o
575obj-sparc-y += slavio_timer.o slavio_misc.o fdc.o sparc32_dma.o
576obj-sparc-y += cs4231.o eccmemctl.o sbi.o sun4c_intctl.o
577endif
578
579obj-arm-y = integratorcp.o versatilepb.o smc91c111.o arm_pic.o arm_timer.o
580obj-arm-y += arm_boot.o pl011.o pl031.o pl050.o pl080.o pl110.o pl181.o pl190.o
581obj-arm-y += versatile_pci.o
582obj-arm-y += realview_gic.o realview.o arm_sysctl.o mpcore.o
583obj-arm-y += armv7m.o armv7m_nvic.o stellaris.o pl022.o stellaris_enet.o
584obj-arm-y += pl061.o
585obj-arm-y += arm-semi.o
586obj-arm-y += pxa2xx.o pxa2xx_pic.o pxa2xx_gpio.o pxa2xx_timer.o pxa2xx_dma.o
587obj-arm-y += pxa2xx_lcd.o pxa2xx_mmci.o pxa2xx_pcmcia.o pxa2xx_keypad.o
588obj-arm-y += pflash_cfi01.o gumstix.o
589obj-arm-y += zaurus.o ide.o serial.o spitz.o tosa.o tc6393xb.o
590obj-arm-y += omap1.o omap_lcdc.o omap_dma.o omap_clk.o omap_mmc.o omap_i2c.o
591obj-arm-y += omap2.o omap_dss.o soc_dma.o
592obj-arm-y += omap_sx1.o palm.o tsc210x.o
593obj-arm-y += nseries.o blizzard.o onenand.o vga.o cbus.o tusb6010.o usb-musb.o
594obj-arm-y += mst_fpga.o mainstone.o
595obj-arm-y += musicpal.o pflash_cfi02.o
596obj-arm-y += framebuffer.o
597obj-arm-y += syborg.o syborg_fb.o syborg_interrupt.o syborg_keyboard.o
598obj-arm-y += syborg_serial.o syborg_timer.o syborg_pointer.o syborg_rtc.o
599obj-arm-y += syborg_virtio.o
600
b5ff1b31 601ifeq ($(TARGET_BASE_ARCH), arm)
5a1237c4 602CPPFLAGS += -DHAS_AUDIO
b5ff1b31 603endif
9637443f
JQ
604
605obj-sh4-y = shix.o r2d.o sh7750.o sh7750_regnames.o tc58128.o
606obj-sh4-y += sh_timer.o sh_serial.o sh_intc.o sh_pci.o sm501.o serial.o
607obj-sh4-y += ide.o
608
609obj-m68k-y = an5206.o mcf5206.o mcf_uart.o mcf_intc.o mcf5208.o mcf_fec.o
610obj-m68k-y += m68k-semi.o dummy_m68k.o
611
5b0753e0 612ifdef CONFIG_COCOA
1d14ffa9
FB
613COCOA_LIBS=-F/System/Library/Frameworks -framework Cocoa -framework IOKit
614ifdef CONFIG_COREAUDIO
615COCOA_LIBS+=-framework CoreAudio
616endif
5b0753e0 617endif
7c1f25b4 618ifdef CONFIG_SLIRP
6f30fa85 619CPPFLAGS+=-I$(SRC_PATH)/slirp
626df76a
FB
620endif
621
c321f673 622# specific flags are needed for non soft mmu emulator
c321f673 623ifdef CONFIG_STATIC
40293e58 624LDFLAGS+=-static
de5eaa64 625endif
83fb7adf 626ifndef CONFIG_DARWIN
11d9f695 627ifndef CONFIG_WIN32
ec530c81 628ifndef CONFIG_SOLARIS
b29fe3ed 629ifndef CONFIG_AIX
40293e58 630LIBS+=-lutil
11d9f695 631endif
b29fe3ed 632endif
83fb7adf 633endif
ec530c81 634endif
e3086fbf 635ifdef TARGET_GPROF
40293e58
FB
636vl.o: CFLAGS+=-p
637LDFLAGS+=-p
e3086fbf 638endif
c321f673 639
b8076a74 640ifeq ($(ARCH),ia64)
40293e58 641LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/ia64.ld
74ccb34e
FB
642endif
643
1d14ffa9
FB
644ifdef CONFIG_WIN32
645SDL_LIBS := $(filter-out -mwindows, $(SDL_LIBS)) -mconsole
646endif
647
40293e58
FB
648# profiling code
649ifdef TARGET_GPROF
650LDFLAGS+=-p
651main.o: CFLAGS+=-p
6e1b3e4d
FB
652endif
653
537fe2d6
AL
654vl.o: CFLAGS+=$(SDL_CFLAGS)
655
5824d651
BS
656vl.o: qemu-options.h
657
2313086a
BS
658monitor.o: qemu-monitor.h
659
16394485
JQ
660LIBS += $(SDL_LIBS) $(COCOA_LIBS) $(CURSES_LIBS) $(BRLAPI_LIBS) $(VDE_LIBS) $(CURL_LIBS)
661ARLIBS=../libqemu_common.a libqemu.a $(HWLIB)
626df76a 662
40293e58 663endif # !CONFIG_USER_ONLY
00a67ba1 664
16394485
JQ
665$(QEMU_PROG): $(obj-y) $(obj-$(TARGET_BASE_ARCH)-y) $(ARLIBS)
666 $(call LINK,$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y))
667
668
56aebc89 669gdbstub-xml.c: $(TARGET_XML_FILES) feature_to_c.sh
56aebc89 670ifeq ($(TARGET_XML_FILES),)
1aef4c57 671 $(call quiet-command,rm -f $@ && echo > $@," GEN $(TARGET_DIR)$@")
56aebc89 672else
1aef4c57 673 $(call quiet-command,rm -f $@ && $(SHELL) $(SRC_PATH)/feature_to_c.sh $@ $(TARGET_XML_FILES)," GEN $(TARGET_DIR)$@")
56aebc89
PB
674endif
675
5824d651 676qemu-options.h: $(SRC_PATH)/qemu-options.hx
0d00e563 677 $(call quiet-command,sh $(SRC_PATH)/hxtool -h < $< > $@," GEN $(TARGET_DIR)$@")
5824d651 678
2313086a
BS
679qemu-monitor.h: $(SRC_PATH)/qemu-monitor.hx
680 $(call quiet-command,sh $(SRC_PATH)/hxtool -h < $< > $@," GEN $(TARGET_DIR)$@")
681
626df76a 682clean:
2313086a 683 rm -f *.o *.a *~ $(PROGS) nwfpe/*.o fpu/*.o
57fec1fe 684 rm -f *.d */*.d tcg/*.o
2313086a 685 rm -f qemu-options.h qemu-monitor.h gdbstub-xml.c
1e43adfc 686
5fafdf24 687install: all
9b14bb04 688ifneq ($(PROGS),)
1625af87 689 $(INSTALL) -m 755 $(STRIP_OPT) $(PROGS) "$(DESTDIR)$(bindir)"
9b14bb04 690endif
626df76a 691
2f96c28d
JM
692# Include automatically generated dependency files
693-include $(wildcard *.d */*.d)