]> git.proxmox.com Git - qemu.git/blame - Makefile.target
ide: Set bus master inactive on error
[qemu.git] / Makefile.target
CommitLineData
562593aa
AL
1# -*- Mode: makefile -*-
2
a992fe3d 3GENERATED_HEADERS = config-target.h
98c8573e 4CONFIG_NO_KVM = $(if $(subst n,,$(CONFIG_KVM)),n,y)
f527c579 5
deed3ccf 6include ../config-host.mak
1f3d3c8f 7include config-devices.mak
25be210f 8include config-target.mak
17759187 9include $(SRC_PATH)/rules.mak
0e8c9214
AF
10ifneq ($(HWDIR),)
11include $(HWDIR)/config.mak
12endif
626df76a 13
0b0babc6 14TARGET_PATH=$(SRC_PATH)/target-$(TARGET_BASE_ARCH)
076d2471 15$(call set-vpath, $(SRC_PATH):$(TARGET_PATH):$(SRC_PATH)/hw)
6c90361a 16QEMU_CFLAGS+= -I.. -I$(TARGET_PATH) -DNEED_CPU_H
40293e58 17
0e8c9214
AF
18include $(SRC_PATH)/Makefile.objs
19
40293e58
FB
20ifdef CONFIG_USER_ONLY
21# user emulator name
22QEMU_PROG=qemu-$(TARGET_ARCH2)
23else
1e43adfc 24# system emulator name
a541f297 25ifeq ($(TARGET_ARCH), i386)
40293e58 26QEMU_PROG=qemu$(EXESUF)
0db63474 27else
40293e58 28QEMU_PROG=qemu-system-$(TARGET_ARCH2)$(EXESUF)
a541f297 29endif
de5eaa64 30endif
626df76a 31
40293e58 32PROGS=$(QEMU_PROG)
b8841706 33STPFILES=
626df76a 34
aff447c9 35ifndef CONFIG_HAIKU
626df76a 36LIBS+=-lm
aff447c9 37endif
831b7825 38
0e1a275b 39kvm.o kvm-all.o vhost.o vhost_net.o: QEMU_CFLAGS+=$(KVM_CFLAGS)
7ba1e619 40
91880d96
JQ
41config-target.h: config-target.h-timestamp
42config-target.h-timestamp: config-target.mak
43
c276b17d
DB
44ifdef CONFIG_SYSTEMTAP_TRACE
45stap: $(QEMU_PROG).stp
46
47ifdef CONFIG_USER_ONLY
48TARGET_TYPE=user
49else
50TARGET_TYPE=system
51endif
52
53$(QEMU_PROG).stp:
54 $(call quiet-command,sh $(SRC_PATH)/tracetool \
55 --$(TRACE_BACKEND) \
56 --binary $(bindir)/$(QEMU_PROG) \
57 --target-arch $(TARGET_ARCH) \
58 --target-type $(TARGET_TYPE) \
59 --stap < $(SRC_PATH)/trace-events > $(QEMU_PROG).stp," GEN $(QEMU_PROG).stp")
60else
61stap:
62endif
63
64all: $(PROGS) stap
91880d96 65
c2fb2637
PB
66# Dummy command so that make thinks it has done something
67 @true
626df76a 68
40293e58 69#########################################################
626df76a 70# cpu emulator library
c2b023b6 71libobj-y = exec.o translate-all.o cpu-exec.o translate.o
96e132e2 72libobj-y += tcg/tcg.o
d6b38939
JQ
73libobj-$(CONFIG_SOFTFLOAT) += fpu/softfloat.o
74libobj-$(CONFIG_NOSOFTFLOAT) += fpu/softfloat-native.o
c9e0df73 75libobj-y += op_helper.o helper.o
c6dc6f63
AP
76ifeq ($(TARGET_BASE_ARCH), i386)
77libobj-y += cpuid.o
78endif
471857dd 79libobj-$(CONFIG_NEED_MMU) += mmu.o
e18ea868 80libobj-$(TARGET_ARM) += neon_helper.o iwmmxt_helper.o
cf6c1b16 81
c9e0df73 82libobj-y += disas.o
626df76a 83
0e8c9214 84$(libobj-y): $(GENERATED_HEADERS)
40293e58 85
0e8c9214 86# libqemu
40293e58 87
86e840ee 88translate.o: translate.c cpu.h
40293e58 89
86e840ee 90translate-all.o: translate-all.c cpu.h
40293e58 91
86e840ee 92tcg/tcg.o: cpu.h
40293e58
FB
93
94# HELPER_CFLAGS is used for all the code compiled with static register
95# variables
864de24a 96op_helper.o cpu-exec.o: QEMU_CFLAGS += $(HELPER_CFLAGS)
40293e58 97
c81da56e
JQ
98# Note: this is a workaround. The real fix is to avoid compiling
99# cpu_signal_handler() in cpu-exec.c.
100signal.o: QEMU_CFLAGS += $(HELPER_CFLAGS)
101
40293e58
FB
102#########################################################
103# Linux user emulator target
104
105ifdef CONFIG_LINUX_USER
106
076d2471
PB
107$(call set-vpath, $(SRC_PATH)/linux-user:$(SRC_PATH)/linux-user/$(TARGET_ABI_DIR))
108
a558ee17 109QEMU_CFLAGS+=-I$(SRC_PATH)/linux-user -I$(SRC_PATH)/linux-user/$(TARGET_ABI_DIR)
37022086 110obj-y = main.o syscall.o strace.o mmap.o signal.o thunk.o \
680c877a 111 elfload.o linuxload.o uaccess.o gdbstub.o cpu-uname.o \
b152aa84 112 qemu-malloc.o $(oslib-obj-y)
5ba65319 113
943e0a31 114obj-$(TARGET_HAS_BFLT) += flatload.o
40293e58 115
e18ea868 116obj-$(TARGET_I386) += vm86.o
1c872672 117
e27b27b3 118obj-i386-y += ioport-user.o
5ba65319 119
ed69c30d 120nwfpe-obj-y = fpa11.o fpa11_cpdo.o fpa11_cpdt.o fpa11_cprt.o fpopcode.o
9c1dd99b 121nwfpe-obj-y += single_cpdo.o double_cpdo.o extended_cpdo.o
1c872672
JQ
122obj-arm-y += $(addprefix nwfpe/, $(nwfpe-obj-y))
123obj-arm-y += arm-semi.o
124
125obj-m68k-y += m68k-sim.o m68k-semi.o
40293e58 126
0e8c9214
AF
127$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y): $(GENERATED_HEADERS)
128
129obj-y += $(addprefix ../libuser/, $(user-obj-y))
4d904533 130obj-y += $(addprefix ../libdis-user/, $(libdis-y))
0e8c9214 131obj-y += $(libobj-y)
add16157 132
40293e58
FB
133endif #CONFIG_LINUX_USER
134
135#########################################################
136# Darwin user emulator target
137
138ifdef CONFIG_DARWIN_USER
139
076d2471
PB
140$(call set-vpath, $(SRC_PATH)/darwin-user)
141
a558ee17 142QEMU_CFLAGS+=-I$(SRC_PATH)/darwin-user -I$(SRC_PATH)/darwin-user/$(TARGET_ARCH)
40293e58
FB
143
144# Leave some space for the regular program loading zone
145LDFLAGS+=-Wl,-segaddr,__STD_PROG_ZONE,0x1000 -image_base 0x0e000000
146
147LIBS+=-lmx
148
a8e492c0 149obj-y = main.o commpage.o machload.o mmap.o signal.o syscall.o thunk.o \
3d0f1517 150 gdbstub.o
5ba65319 151
e27b27b3 152obj-i386-y += ioport-user.o
40293e58 153
0e8c9214
AF
154$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y): $(GENERATED_HEADERS)
155
156obj-y += $(addprefix ../libuser/, $(user-obj-y))
4d904533 157obj-y += $(addprefix ../libdis-user/, $(libdis-y))
0e8c9214 158obj-y += $(libobj-y)
40293e58
FB
159
160endif #CONFIG_DARWIN_USER
161
84778508
BS
162#########################################################
163# BSD user emulator target
164
165ifdef CONFIG_BSD_USER
166
076d2471
PB
167$(call set-vpath, $(SRC_PATH)/bsd-user)
168
a558ee17 169QEMU_CFLAGS+=-I$(SRC_PATH)/bsd-user -I$(SRC_PATH)/bsd-user/$(TARGET_ARCH)
84778508 170
37022086 171obj-y = main.o bsdload.o elfload.o mmap.o signal.o strace.o syscall.o \
3d0f1517 172 gdbstub.o uaccess.o
5ba65319 173
e27b27b3 174obj-i386-y += ioport-user.o
84778508 175
0e8c9214
AF
176$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y): $(GENERATED_HEADERS)
177
178obj-y += $(addprefix ../libuser/, $(user-obj-y))
4d904533 179obj-y += $(addprefix ../libdis-user/, $(libdis-y))
0e8c9214 180obj-y += $(libobj-y)
84778508
BS
181
182endif #CONFIG_BSD_USER
183
40293e58
FB
184#########################################################
185# System emulator target
76dfdd24 186ifdef CONFIG_SOFTMMU
40293e58 187
04c9a0cb 188obj-y = arch_init.o cpus.o monitor.o machine.o gdbstub.o balloon.o
1fd31ad7
AL
189# virtio has to be here due to weird dependency between PCI and virtio-net.
190# need to fix this properly
e9d0fc74
AG
191obj-y += virtio-blk.o virtio-balloon.o virtio-net.o virtio-serial-bus.o
192obj-$(CONFIG_VIRTIO_PCI) += virtio-pci.o
d5970055
MT
193obj-y += vhost_net.o
194obj-$(CONFIG_VHOST_NET) += vhost.o
758e8e38 195obj-$(CONFIG_VIRTFS) += virtio-9p.o
51464faf 196obj-y += rwhandler.o
a8e492c0 197obj-$(CONFIG_KVM) += kvm.o kvm-all.o
98c8573e 198obj-$(CONFIG_NO_KVM) += kvm-stub.o
40293e58 199LIBS+=-lz
4fb240a4 200
a558ee17 201QEMU_CFLAGS += $(VNC_TLS_CFLAGS)
a558ee17 202QEMU_CFLAGS += $(VNC_SASL_CFLAGS)
2f6f5c7a 203QEMU_CFLAGS += $(VNC_JPEG_CFLAGS)
efe556ad 204QEMU_CFLAGS += $(VNC_PNG_CFLAGS)
2f9606b3 205
e37630ca 206# xen backend driver support
943e0a31 207obj-$(CONFIG_XEN) += xen_machine_pv.o xen_domainbuild.o
e37630ca 208
a67ba3b6
PB
209# USB layer
210obj-$(CONFIG_USB_OHCI) += usb-ohci.o
211
a41b2ff2 212# PCI network cards
a8e492c0
JQ
213obj-y += rtl8139.o
214obj-y += e1000.o
a41b2ff2 215
6cbf4c8c 216# Inter-VM PCI shared memory
3dcbf8f9 217obj-$(CONFIG_KVM) += ivshmem.o
6cbf4c8c 218
a541f297 219# Hardware support
7f55c7ce 220obj-i386-y += vga.o
2d48377a 221obj-i386-y += mc146818rtc.o i8259.o pc.o
53b67b30 222obj-i386-y += cirrus_vga.o apic.o ioapic.o piix_pci.o
1ddda5cd 223obj-i386-y += vmmouse.o vmport.o hpet.o applesmc.o
09aaa160 224obj-i386-y += device-hotplug.o pci-hotplug.o smbios.o wdt_ib700.o
d3ffc7a6 225obj-i386-y += debugcon.o multiboot.o
c69ea0df 226obj-i386-y += pc_piix.o
9637443f 227
3cbee15b 228# shared objects
02c7c992 229obj-ppc-y = ppc.o
4556bd8b 230obj-ppc-y += vga.o
3cbee15b 231# PREP target
956a3e6b 232obj-ppc-y += i8259.o mc146818rtc.o
add85a76 233obj-ppc-y += ppc_prep.o
3cbee15b 234# OldWorld PowerMac
2b5eb371 235obj-ppc-y += ppc_oldworld.o
3cbee15b 236# NewWorld PowerMac
2b5eb371 237obj-ppc-y += ppc_newworld.o
3cbee15b 238# PowerPC 4xx boards
5f9fc5ad 239obj-ppc-y += ppc4xx_devs.o ppc4xx_pci.o ppc405_uc.o ppc405_boards.o
9637443f 240obj-ppc-y += ppc440.o ppc440_bamboo.o
74c62ba8 241# PowerPC E500 boards
2b5eb371 242obj-ppc-y += ppce500_mpc8544ds.o
2c50e26e
EI
243# PowerPC 440 Xilinx ML507 reference board.
244obj-ppc-y += virtex_ml507.o
9637443f 245obj-ppc-$(CONFIG_KVM) += kvm_ppc.o
3f0855b1 246obj-ppc-$(CONFIG_FDT) += device_tree.o
9637443f 247
2c50e26e
EI
248# Xilinx PPC peripherals
249obj-ppc-y += xilinx_intc.o
250obj-ppc-y += xilinx_timer.o
251obj-ppc-y += xilinx_uartlite.o
252obj-ppc-y += xilinx_ethlite.o
253
9637443f 254obj-mips-y = mips_r4k.o mips_jazz.o mips_malta.o mips_mipssim.o
409dbce5 255obj-mips-y += mips_addr.o mips_timer.o mips_int.o
4556bd8b 256obj-mips-y += vga.o i8259.o
b970ea8f 257obj-mips-y += g364fb.o jazz_led.o
956a3e6b 258obj-mips-y += gt64xxx.o mc146818rtc.o
08af49da 259obj-mips-y += cirrus_vga.o
051c190b 260obj-mips-$(CONFIG_FULONG) += bonito.o vt82c686.o mips_fulong2e.o
9637443f 261
9637443f
JQ
262obj-microblaze-y = petalogix_s3adsp1800_mmu.o
263
264obj-microblaze-y += microblaze_pic_cpu.o
265obj-microblaze-y += xilinx_intc.o
266obj-microblaze-y += xilinx_timer.o
267obj-microblaze-y += xilinx_uartlite.o
268obj-microblaze-y += xilinx_ethlite.o
269
3f0855b1 270obj-microblaze-$(CONFIG_FDT) += device_tree.o
9637443f 271
10c144e2 272# Boards
77d4f95e
EI
273obj-cris-y = cris_pic_cpu.o
274obj-cris-y += cris-boot.o
275obj-cris-y += etraxfs.o axis_dev88.o
276obj-cris-y += axis_dev88.o
10c144e2
EI
277
278# IO blocks
9637443f
JQ
279obj-cris-y += etraxfs_dma.o
280obj-cris-y += etraxfs_pic.o
281obj-cris-y += etraxfs_eth.o
282obj-cris-y += etraxfs_timer.o
283obj-cris-y += etraxfs_ser.o
284
3475187d 285ifeq ($(TARGET_ARCH), sparc64)
956a3e6b 286obj-sparc-y = sun4u.o apb_pci.o
1afdfddc 287obj-sparc-y += vga.o
2d48377a 288obj-sparc-y += mc146818rtc.o
b9945046 289obj-sparc-y += cirrus_vga.o
3475187d 290else
24056690 291obj-sparc-y = sun4m.o lance.o tcx.o sun4m_iommu.o slavio_intctl.o
35da37e1 292obj-sparc-y += slavio_timer.o slavio_misc.o sparc32_dma.o
9637443f
JQ
293obj-sparc-y += cs4231.o eccmemctl.o sbi.o sun4c_intctl.o
294endif
295
f165b53a 296obj-arm-y = integratorcp.o versatilepb.o arm_pic.o arm_timer.o
9637443f
JQ
297obj-arm-y += arm_boot.o pl011.o pl031.o pl050.o pl080.o pl110.o pl181.o pl190.o
298obj-arm-y += versatile_pci.o
f7c70325 299obj-arm-y += realview_gic.o realview.o arm_sysctl.o arm11mpcore.o a9mpcore.o
9637443f
JQ
300obj-arm-y += armv7m.o armv7m_nvic.o stellaris.o pl022.o stellaris_enet.o
301obj-arm-y += pl061.o
302obj-arm-y += arm-semi.o
303obj-arm-y += pxa2xx.o pxa2xx_pic.o pxa2xx_gpio.o pxa2xx_timer.o pxa2xx_dma.o
304obj-arm-y += pxa2xx_lcd.o pxa2xx_mmci.o pxa2xx_pcmcia.o pxa2xx_keypad.o
3d08ff69 305obj-arm-y += gumstix.o
f7736b91 306obj-arm-y += zaurus.o ide/microdrive.o spitz.o tosa.o tc6393xb.o
02d74341 307obj-arm-y += omap1.o omap_lcdc.o omap_dma.o omap_clk.o omap_mmc.o omap_i2c.o \
308 omap_gpio.o omap_intc.o omap_uart.o
2c1d9ecb 309obj-arm-y += omap2.o omap_dss.o soc_dma.o omap_gptimer.o omap_synctimer.o \
310 omap_gpmc.o omap_sdrc.o omap_spi.o omap_tap.o omap_l4.o
9637443f
JQ
311obj-arm-y += omap_sx1.o palm.o tsc210x.o
312obj-arm-y += nseries.o blizzard.o onenand.o vga.o cbus.o tusb6010.o usb-musb.o
313obj-arm-y += mst_fpga.o mainstone.o
5f9fc5ad 314obj-arm-y += musicpal.o bitbang_i2c.o marvell_88w8618_audio.o
9637443f
JQ
315obj-arm-y += framebuffer.o
316obj-arm-y += syborg.o syborg_fb.o syborg_interrupt.o syborg_keyboard.o
317obj-arm-y += syborg_serial.o syborg_timer.o syborg_pointer.o syborg_rtc.o
318obj-arm-y += syborg_virtio.o
319
9637443f 320obj-sh4-y = shix.o r2d.o sh7750.o sh7750_regnames.o tc58128.o
2d48377a 321obj-sh4-y += sh_timer.o sh_serial.o sh_intc.o sh_pci.o sm501.o
f7736b91 322obj-sh4-y += ide/mmio.o
9637443f
JQ
323
324obj-m68k-y = an5206.o mcf5206.o mcf_uart.o mcf_intc.o mcf5208.o mcf_fec.o
325obj-m68k-y += m68k-semi.o dummy_m68k.o
326
8cb310e1 327obj-s390x-y = s390-virtio-bus.o s390-virtio.o
f3304eea 328
6049f4f8
RH
329obj-alpha-y = alpha_palcode.o
330
ad96090a 331main.o: QEMU_CFLAGS+=$(GPROF_CFLAGS)
5824d651 332
acd0a093 333monitor.o: hmp-commands.h qmp-commands.h
2313086a 334
0e8c9214
AF
335$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y): $(GENERATED_HEADERS)
336
337obj-y += $(addprefix ../, $(common-obj-y))
4d904533 338obj-y += $(addprefix ../libdis/, $(libdis-y))
0e8c9214
AF
339obj-y += $(libobj-y)
340obj-y += $(addprefix $(HWDIR)/, $(hw-obj-y))
626df76a 341
76dfdd24 342endif # CONFIG_SOFTMMU
00a67ba1 343
94a420b1 344obj-y += $(addprefix ../, $(trace-obj-y))
3d0f1517
JQ
345obj-$(CONFIG_GDBSTUB_XML) += gdbstub-xml.o
346
0e8c9214 347$(QEMU_PROG): $(obj-y) $(obj-$(TARGET_BASE_ARCH)-y)
16394485
JQ
348 $(call LINK,$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y))
349
350
59bc10ee 351gdbstub-xml.c: $(TARGET_XML_FILES) $(SRC_PATH)/feature_to_c.sh
1aef4c57 352 $(call quiet-command,rm -f $@ && $(SHELL) $(SRC_PATH)/feature_to_c.sh $@ $(TARGET_XML_FILES)," GEN $(TARGET_DIR)$@")
56aebc89 353
acd0a093 354hmp-commands.h: $(SRC_PATH)/hmp-commands.hx
2313086a
BS
355 $(call quiet-command,sh $(SRC_PATH)/hxtool -h < $< > $@," GEN $(TARGET_DIR)$@")
356
f36b4afb 357qmp-commands.h: $(SRC_PATH)/qmp-commands.hx
2313086a
BS
358 $(call quiet-command,sh $(SRC_PATH)/hxtool -h < $< > $@," GEN $(TARGET_DIR)$@")
359
626df76a 360clean:
2313086a 361 rm -f *.o *.a *~ $(PROGS) nwfpe/*.o fpu/*.o
befb0316 362 rm -f *.d */*.d tcg/*.o ide/*.o
acd0a093 363 rm -f hmp-commands.h qmp-commands.h gdbstub-xml.c
c276b17d
DB
364ifdef CONFIG_SYSTEMTAP_TRACE
365 rm -f *.stp
366endif
1e43adfc 367
5fafdf24 368install: all
9b14bb04 369ifneq ($(PROGS),)
52ba784d
HB
370 $(INSTALL) -m 755 $(PROGS) "$(DESTDIR)$(bindir)"
371ifneq ($(STRIP),)
372 $(STRIP) $(patsubst %,"$(DESTDIR)$(bindir)/%",$(PROGS))
373endif
9b14bb04 374endif
c276b17d
DB
375ifdef CONFIG_SYSTEMTAP_TRACE
376 $(INSTALL_DIR) "$(DESTDIR)$(datadir)/../systemtap/tapset"
377 $(INSTALL_DATA) $(QEMU_PROG).stp "$(DESTDIR)$(datadir)/../systemtap/tapset"
378endif
626df76a 379
2f96c28d
JM
380# Include automatically generated dependency files
381-include $(wildcard *.d */*.d)