]> Git Repo - qemu.git/blame_incremental - Makefile.target
remove CONFIG_ from VNC_SASL_{LIBS, FLAGS}
[qemu.git] / Makefile.target
... / ...
CommitLineData
1include config.mak
2include $(SRC_PATH)/rules.mak
3
4TARGET_PATH=$(SRC_PATH)/target-$(TARGET_BASE_ARCH)
5VPATH=$(SRC_PATH):$(TARGET_PATH):$(SRC_PATH)/hw
6CPPFLAGS=-I. -I.. -I$(TARGET_PATH) -I$(SRC_PATH) -MMD -MT $@ -MP -DNEED_CPU_H
7#CFLAGS+=-Werror
8LIBS=
9
10ifdef CONFIG_USER_ONLY
11# user emulator name
12QEMU_PROG=qemu-$(TARGET_ARCH2)
13else
14# system emulator name
15ifeq ($(TARGET_ARCH), i386)
16QEMU_PROG=qemu$(EXESUF)
17else
18QEMU_PROG=qemu-system-$(TARGET_ARCH2)$(EXESUF)
19endif
20endif
21
22PROGS=$(QEMU_PROG)
23
24# cc-option
25# Usage: CFLAGS+=$(call cc-option, $(CFLAGS), -falign-functions=0, -malign-functions=0)
26
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 ;)
29
30HELPER_CFLAGS=
31
32ifeq ($(ARCH),i386)
33HELPER_CFLAGS+=-fomit-frame-pointer
34endif
35
36ifeq ($(subst ppc64,ppc,$(ARCH))$(TARGET_BASE_ARCH),ppcppc)
37translate.o: CFLAGS := $(CFLAGS) $(call cc-option, $(CFLAGS), -fno-unit-at-a-time,)
38endif
39
40ifeq ($(ARCH),sparc)
41 ifneq ($(CONFIG_SOLARIS),y)
42 HELPER_CFLAGS+=-ffixed-i0
43 endif
44endif
45
46ifeq ($(ARCH),alpha)
47# Ensure there's only a single GP
48CFLAGS+=-msmall-data
49endif
50
51ifeq ($(ARCH),ia64)
52CFLAGS+=-mno-sdata
53endif
54
55CPPFLAGS+=-D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE
56CPPFLAGS+=-U_FORTIFY_SOURCE
57LIBS+=-lm
58ifdef CONFIG_WIN32
59LIBS+=-lwinmm -lws2_32 -liphlpapi
60endif
61ifdef CONFIG_SOLARIS
62LIBS+=-lsocket -lnsl -lresolv
63ifdef NEEDS_LIBSUNMATH
64LIBS+=-lsunmath
65LDFLAGS+=-L/opt/SUNWspro/prod/lib -R/opt/SUNWspro/prod/lib
66CFLAGS+=-I/opt/SUNWspro/prod/include/cc
67endif
68endif
69
70kvm.o: CFLAGS+=$(KVM_CFLAGS)
71kvm-all.o: CFLAGS+=$(KVM_CFLAGS)
72
73all: $(PROGS)
74# Dummy command so that make thinks it has done something
75 @true
76
77#########################################################
78# cpu emulator library
79libobj-y = exec.o translate-all.o cpu-exec.o translate.o host-utils.o
80libobj-$(CONFIG_KQEMU) += kqemu.o
81# TCG code generator
82libobj-y += tcg/tcg.o tcg/tcg-runtime.o
83CPPFLAGS+=-I$(SRC_PATH)/tcg -I$(SRC_PATH)/tcg/$(ARCH)
84ifeq ($(ARCH),sparc64)
85CPPFLAGS+=-I$(SRC_PATH)/tcg/sparc
86endif
87ifdef CONFIG_SOFTFLOAT
88libobj-y += fpu/softfloat.o
89else
90libobj-y += fpu/softfloat-native.o
91endif
92CPPFLAGS+=-I$(SRC_PATH)/fpu
93libobj-y += op_helper.o helper.o
94
95ifeq ($(TARGET_BASE_ARCH), arm)
96libobj-y += neon_helper.o iwmmxt_helper.o
97endif
98
99ifeq ($(TARGET_BASE_ARCH), alpha)
100libobj-y += alpha_palcode.o
101endif
102
103ifeq ($(TARGET_BASE_ARCH), cris)
104libobj-y += cris-dis.o
105
106ifndef CONFIG_USER_ONLY
107libobj-y += mmu.o
108endif
109endif
110
111# NOTE: the disassembler code is only needed for debugging
112libobj-y += disas.o
113ifeq ($(findstring i386, $(TARGET_ARCH) $(ARCH)),i386)
114USE_I386_DIS=y
115endif
116ifeq ($(findstring x86_64, $(TARGET_ARCH) $(ARCH)),x86_64)
117USE_I386_DIS=y
118endif
119libobj-$(USE_I386_DIS) += i386-dis.o
120ifeq ($(findstring alpha, $(TARGET_ARCH) $(ARCH)),alpha)
121libobj-y += alpha-dis.o
122endif
123ifeq ($(findstring ppc, $(TARGET_BASE_ARCH) $(ARCH)),ppc)
124libobj-y += ppc-dis.o
125endif
126ifeq ($(findstring microblaze, $(TARGET_BASE_ARCH) $(ARCH)),microblaze)
127libobj-y += microblaze-dis.o
128ifndef CONFIG_USER_ONLY
129libobj-y += mmu.o
130endif
131endif
132ifeq ($(findstring mips, $(TARGET_BASE_ARCH) $(ARCH)),mips)
133libobj-y += mips-dis.o
134endif
135ifeq ($(findstring sparc, $(TARGET_BASE_ARCH) $(ARCH)),sparc)
136libobj-y += sparc-dis.o
137endif
138ifeq ($(findstring arm, $(TARGET_ARCH) $(ARCH)),arm)
139libobj-y += arm-dis.o
140endif
141ifeq ($(findstring m68k, $(TARGET_ARCH) $(ARCH)),m68k)
142libobj-y += m68k-dis.o
143endif
144ifeq ($(findstring sh4, $(TARGET_ARCH) $(ARCH)),sh4)
145libobj-y += sh4-dis.o
146endif
147ifeq ($(findstring hppa, $(TARGET_BASE_ARCH) $(ARCH)),hppa)
148libobj-y += hppa-dis.o
149endif
150ifeq ($(findstring s390, $(TARGET_ARCH) $(ARCH)),s390)
151libobj-y += s390-dis.o
152endif
153
154# libqemu
155
156libqemu.a: $(libobj-y)
157
158translate.o: translate.c cpu.h
159
160translate-all.o: translate-all.c cpu.h
161
162tcg/tcg.o: cpu.h
163
164# HELPER_CFLAGS is used for all the code compiled with static register
165# variables
166op_helper.o: CFLAGS += $(HELPER_CFLAGS)
167
168cpu-exec.o: CFLAGS += $(HELPER_CFLAGS)
169
170#########################################################
171# Linux user emulator target
172
173ifdef CONFIG_LINUX_USER
174
175VPATH+=:$(SRC_PATH)/linux-user:$(SRC_PATH)/linux-user/$(TARGET_ABI_DIR)
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
207ifeq ($(ARCH),ppc64)
208LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
209endif
210
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
256# profiling code
257ifdef TARGET_GPROF
258LDFLAGS+=-p
259CFLAGS+=-p
260endif
261
262obj-y = main.o syscall.o strace.o mmap.o signal.o path.o thunk.o \
263 elfload.o linuxload.o uaccess.o envlist.o gdbstub.o gdbstub-xml.o \
264 ioport-user.o
265obj-$(TARGET_HAS_BFLT) += flatload.o
266
267ifdef TARGET_HAS_ELFLOAD32
268elfload32.o: elfload.c
269endif
270obj-$(TARGET_HAS_ELFLOAD32) += elfload32.o
271
272ifeq ($(TARGET_ARCH), i386)
273obj-y += vm86.o
274endif
275
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
278obj-arm-y += $(addprefix nwfpe/, $(nwfpe-obj-y))
279obj-arm-y += arm-semi.o
280
281obj-m68k-y += m68k-sim.o m68k-semi.o
282
283# Note: this is a workaround. The real fix is to avoid compiling
284# cpu_signal_handler() in cpu-exec.c.
285signal.o: CFLAGS += $(HELPER_CFLAGS)
286
287ARLIBS=../libqemu_user.a libqemu.a
288endif #CONFIG_LINUX_USER
289
290LIBS+= $(PTHREADLIBS)
291LIBS+= $(CLOCKLIBS)
292
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
306obj-y = main.o commpage.o machload.o mmap.o signal.o syscall.o thunk.o \
307 gdbstub.o gdbstub-xml.o ioport-user.o
308
309# Note: this is a workaround. The real fix is to avoid compiling
310# cpu_signal_handler() in cpu-exec.c.
311signal.o: CFLAGS += $(HELPER_CFLAGS)
312
313ARLIBS=libqemu.a
314
315endif #CONFIG_DARWIN_USER
316
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
403obj-y = main.o bsdload.o elfload.o mmap.o path.o signal.o strace.o syscall.o \
404 gdbstub.o gdbstub-xml.o ioport-user.o
405obj-y += uaccess.o
406
407# Note: this is a workaround. The real fix is to avoid compiling
408# cpu_signal_handler() in cpu-exec.c.
409signal.o: CFLAGS += $(HELPER_CFLAGS)
410
411ARLIBS=libqemu.a ../libqemu_user.a
412
413endif #CONFIG_BSD_USER
414
415#########################################################
416# System emulator target
417ifndef CONFIG_USER_ONLY
418
419obj-y = vl.o osdep.o monitor.o pci.o loader.o isa_mmio.o machine.o \
420 gdbstub.o gdbstub-xml.o msix.o ioport.o
421# virtio has to be here due to weird dependency between PCI and virtio-net.
422# need to fix this properly
423obj-y += virtio-blk.o virtio-balloon.o virtio-net.o virtio-console.o
424obj-$(CONFIG_KVM) += kvm.o kvm-all.o
425
426LIBS+=-lz
427ifdef CONFIG_ALSA
428LIBS += -lasound
429endif
430ifdef CONFIG_ESD
431LIBS += -lesd
432endif
433ifdef CONFIG_PA
434LIBS += -lpulse-simple
435endif
436ifdef CONFIG_DSOUND
437LIBS += -lole32 -ldxguid
438endif
439ifdef CONFIG_FMOD
440LIBS += $(CONFIG_FMOD_LIB)
441endif
442ifdef CONFIG_OSS
443LIBS += $(CONFIG_OSS_LIB)
444endif
445
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
452sound-obj-$(CONFIG_CS4231A) += cs4231a.o
453
454ifdef CONFIG_ADLIB
455adlib.o fmopl.o: CFLAGS := ${CFLAGS} -DBUILD_Y8950=0
456endif
457
458ifdef CONFIG_VNC_TLS
459CPPFLAGS += $(VNC_TLS_CFLAGS)
460LIBS += $(VNC_TLS_LIBS)
461endif
462
463ifdef CONFIG_VNC_SASL
464CPPFLAGS += $(VNC_SASL_CFLAGS)
465LIBS += $(VNC_SASL_LIBS)
466endif
467
468ifdef CONFIG_BLUEZ
469LIBS += $(CONFIG_BLUEZ_LIBS)
470endif
471
472# xen backend driver support
473obj-$(CONFIG_XEN) += xen_machine_pv.o xen_domainbuild.o
474ifeq ($(CONFIG_XEN), y)
475 LIBS += $(XEN_LIBS)
476endif
477
478# USB layer
479obj-y += usb-ohci.o
480
481# PCI network cards
482obj-y += eepro100.o
483obj-y += ne2000.o
484obj-y += pcnet.o
485obj-y += rtl8139.o
486obj-y += e1000.o
487
488# Generic watchdog support and some watchdog devices
489obj-y += wdt_ib700.o wdt_i6300esb.o
490
491# Hardware support
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)
499CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
500endif
501
502# shared objects
503obj-ppc-y = ppc.o ide.o vga.o $(sound-obj-y) dma.o openpic.o
504# PREP target
505obj-ppc-y += pckbd.o serial.o i8259.o i8254.o fdc.o mc146818rtc.o
506obj-ppc-y += prep_pci.o ppc_prep.o
507# Mac shared devices
508obj-ppc-y += macio.o cuda.o adb.o mac_nvram.o mac_dbdma.o
509# OldWorld PowerMac
510obj-ppc-y += heathrow_pic.o grackle_pci.o ppc_oldworld.o
511# NewWorld PowerMac
512obj-ppc-y += unin_pci.o ppc_newworld.o
513# PowerPC 4xx boards
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
516# PowerPC E500 boards
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
524ifdef FDT_LIBS
525obj-ppc-y += device_tree.o
526LIBS+= $(FDT_LIBS)
527endif
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
538ifeq ($(TARGET_BASE_ARCH), mips)
539CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
540endif
541
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
551
552ifdef FDT_LIBS
553obj-microblaze-y += device_tree.o
554LIBS+= $(FDT_LIBS)
555endif
556
557# Boards
558obj-cris-y = cris_pic_cpu.o etraxfs.o axis_dev88.o
559
560# IO blocks
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
568
569ifeq ($(TARGET_ARCH), sparc64)
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
573else
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
601ifeq ($(TARGET_BASE_ARCH), arm)
602CPPFLAGS += -DHAS_AUDIO
603endif
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
612ifdef CONFIG_COCOA
613COCOA_LIBS=-F/System/Library/Frameworks -framework Cocoa -framework IOKit
614ifdef CONFIG_COREAUDIO
615COCOA_LIBS+=-framework CoreAudio
616endif
617endif
618ifdef CONFIG_SLIRP
619CPPFLAGS+=-I$(SRC_PATH)/slirp
620endif
621
622# specific flags are needed for non soft mmu emulator
623ifdef CONFIG_STATIC
624LDFLAGS+=-static
625endif
626ifndef CONFIG_DARWIN
627ifndef CONFIG_WIN32
628ifndef CONFIG_SOLARIS
629ifndef CONFIG_AIX
630LIBS+=-lutil
631endif
632endif
633endif
634endif
635ifdef TARGET_GPROF
636vl.o: CFLAGS+=-p
637LDFLAGS+=-p
638endif
639
640ifeq ($(ARCH),ia64)
641LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/ia64.ld
642endif
643
644ifdef CONFIG_WIN32
645SDL_LIBS := $(filter-out -mwindows, $(SDL_LIBS)) -mconsole
646endif
647
648# profiling code
649ifdef TARGET_GPROF
650LDFLAGS+=-p
651main.o: CFLAGS+=-p
652endif
653
654vl.o: CFLAGS+=$(SDL_CFLAGS)
655
656vl.o: qemu-options.h
657
658monitor.o: qemu-monitor.h
659
660LIBS += $(SDL_LIBS) $(COCOA_LIBS) $(CURSES_LIBS) $(BRLAPI_LIBS) $(VDE_LIBS) $(CURL_LIBS)
661ARLIBS=../libqemu_common.a libqemu.a $(HWLIB)
662
663endif # !CONFIG_USER_ONLY
664
665$(QEMU_PROG): $(obj-y) $(obj-$(TARGET_BASE_ARCH)-y) $(ARLIBS)
666 $(call LINK,$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y))
667
668
669gdbstub-xml.c: $(TARGET_XML_FILES) feature_to_c.sh
670ifeq ($(TARGET_XML_FILES),)
671 $(call quiet-command,rm -f $@ && echo > $@," GEN $(TARGET_DIR)$@")
672else
673 $(call quiet-command,rm -f $@ && $(SHELL) $(SRC_PATH)/feature_to_c.sh $@ $(TARGET_XML_FILES)," GEN $(TARGET_DIR)$@")
674endif
675
676qemu-options.h: $(SRC_PATH)/qemu-options.hx
677 $(call quiet-command,sh $(SRC_PATH)/hxtool -h < $< > $@," GEN $(TARGET_DIR)$@")
678
679qemu-monitor.h: $(SRC_PATH)/qemu-monitor.hx
680 $(call quiet-command,sh $(SRC_PATH)/hxtool -h < $< > $@," GEN $(TARGET_DIR)$@")
681
682clean:
683 rm -f *.o *.a *~ $(PROGS) nwfpe/*.o fpu/*.o
684 rm -f *.d */*.d tcg/*.o
685 rm -f qemu-options.h qemu-monitor.h gdbstub-xml.c
686
687install: all
688ifneq ($(PROGS),)
689 $(INSTALL) -m 755 $(STRIP_OPT) $(PROGS) "$(DESTDIR)$(bindir)"
690endif
691
692# Include automatically generated dependency files
693-include $(wildcard *.d */*.d)
This page took 0.028477 seconds and 4 git commands to generate.