Makefile.target 10.6 KB
Newer Older
1 2
# -*- Mode: makefile -*-

3
GENERATED_HEADERS = config-target.h
4
CONFIG_NO_KVM = $(if $(subst n,,$(CONFIG_KVM)),n,y)
Juan Quintela's avatar
Juan Quintela committed
5

6
include ../config-host.mak
7
include config-devices.mak
8
include config-target.mak
aliguori's avatar
aliguori committed
9
include $(SRC_PATH)/rules.mak
10 11 12
ifneq ($(HWDIR),)
include $(HWDIR)/config.mak
endif
bellard's avatar
bellard committed
13

bellard's avatar
bellard committed
14
TARGET_PATH=$(SRC_PATH)/target-$(TARGET_BASE_ARCH)
Paolo Bonzini's avatar
Paolo Bonzini committed
15
$(call set-vpath, $(SRC_PATH):$(TARGET_PATH):$(SRC_PATH)/hw)
16
QEMU_CFLAGS+= -I.. -I$(TARGET_PATH) -DNEED_CPU_H
17

18 19
include $(SRC_PATH)/Makefile.objs

20 21 22 23
ifdef CONFIG_USER_ONLY
# user emulator name
QEMU_PROG=qemu-$(TARGET_ARCH2)
else
24
# system emulator name
25
ifeq ($(TARGET_ARCH), i386)
26
QEMU_PROG=qemu$(EXESUF)
27
else
28
QEMU_PROG=qemu-system-$(TARGET_ARCH2)$(EXESUF)
29
endif
bellard's avatar
bellard committed
30
endif
bellard's avatar
bellard committed
31

32
PROGS=$(QEMU_PROG)
33
STPFILES=
bellard's avatar
bellard committed
34

Andreas Färber's avatar
Andreas Färber committed
35
ifndef CONFIG_HAIKU
bellard's avatar
bellard committed
36
LIBS+=-lm
Andreas Färber's avatar
Andreas Färber committed
37
endif
38

Jan Kiszka's avatar
Jan Kiszka committed
39
kvm.o kvm-all.o vhost.o vhost_net.o: QEMU_CFLAGS+=$(KVM_CFLAGS)
aliguori's avatar
aliguori committed
40

41 42 43
config-target.h: config-target.h-timestamp
config-target.h-timestamp: config-target.mak

44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
ifdef CONFIG_SYSTEMTAP_TRACE
stap: $(QEMU_PROG).stp

ifdef CONFIG_USER_ONLY
TARGET_TYPE=user
else
TARGET_TYPE=system
endif

$(QEMU_PROG).stp:
	$(call quiet-command,sh $(SRC_PATH)/tracetool \
		--$(TRACE_BACKEND) \
		--binary $(bindir)/$(QEMU_PROG) \
		--target-arch $(TARGET_ARCH) \
		--target-type $(TARGET_TYPE) \
		--stap < $(SRC_PATH)/trace-events > $(QEMU_PROG).stp,"  GEN   $(QEMU_PROG).stp")
else
stap:
endif

all: $(PROGS) stap
65

66 67
# Dummy command so that make thinks it has done something
	@true
bellard's avatar
bellard committed
68

69
#########################################################
bellard's avatar
bellard committed
70
# cpu emulator library
Blue Swirl's avatar
Blue Swirl committed
71
libobj-y = exec.o translate-all.o cpu-exec.o translate.o
72
libobj-y += tcg/tcg.o
73 74
libobj-$(CONFIG_SOFTFLOAT) += fpu/softfloat.o
libobj-$(CONFIG_NOSOFTFLOAT) += fpu/softfloat-native.o
Juan Quintela's avatar
Juan Quintela committed
75
libobj-y += op_helper.o helper.o
76 77 78
ifeq ($(TARGET_BASE_ARCH), i386)
libobj-y += cpuid.o
endif
79
libobj-$(CONFIG_NEED_MMU) += mmu.o
80
libobj-$(TARGET_ARM) += neon_helper.o iwmmxt_helper.o
81

Juan Quintela's avatar
Juan Quintela committed
82
libobj-y += disas.o
bellard's avatar
bellard committed
83

84
$(libobj-y): $(GENERATED_HEADERS)
85

86
# libqemu
87

88
translate.o: translate.c cpu.h
89

90
translate-all.o: translate-all.c cpu.h
91

92
tcg/tcg.o: cpu.h
93 94 95

# HELPER_CFLAGS is used for all the code compiled with static register
# variables
Juan Quintela's avatar
Juan Quintela committed
96
op_helper.o cpu-exec.o: QEMU_CFLAGS += $(HELPER_CFLAGS)
97

Juan Quintela's avatar
Juan Quintela committed
98 99 100 101
# Note: this is a workaround. The real fix is to avoid compiling
# cpu_signal_handler() in cpu-exec.c.
signal.o: QEMU_CFLAGS += $(HELPER_CFLAGS)

102 103 104 105 106
#########################################################
# Linux user emulator target

ifdef CONFIG_LINUX_USER

Paolo Bonzini's avatar
Paolo Bonzini committed
107 108
$(call set-vpath, $(SRC_PATH)/linux-user:$(SRC_PATH)/linux-user/$(TARGET_ABI_DIR))

109
QEMU_CFLAGS+=-I$(SRC_PATH)/linux-user -I$(SRC_PATH)/linux-user/$(TARGET_ABI_DIR)
Blue Swirl's avatar
Blue Swirl committed
110
obj-y = main.o syscall.o strace.o mmap.o signal.o thunk.o \
111
      elfload.o linuxload.o uaccess.o gdbstub.o cpu-uname.o \
112
      qemu-malloc.o $(oslib-obj-y)
113

114
obj-$(TARGET_HAS_BFLT) += flatload.o
115

116
obj-$(TARGET_I386) += vm86.o
117

118
obj-i386-y += ioport-user.o
119

120
nwfpe-obj-y = fpa11.o fpa11_cpdo.o fpa11_cpdt.o fpa11_cprt.o fpopcode.o
121
nwfpe-obj-y += single_cpdo.o double_cpdo.o extended_cpdo.o
122 123 124 125
obj-arm-y +=  $(addprefix nwfpe/, $(nwfpe-obj-y))
obj-arm-y += arm-semi.o

obj-m68k-y += m68k-sim.o m68k-semi.o
126

127 128 129
$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y): $(GENERATED_HEADERS)

obj-y += $(addprefix ../libuser/, $(user-obj-y))
Blue Swirl's avatar
Blue Swirl committed
130
obj-y += $(addprefix ../libdis-user/, $(libdis-y))
131
obj-y += $(libobj-y)
132

133 134 135 136 137 138 139
endif #CONFIG_LINUX_USER

#########################################################
# Darwin user emulator target

ifdef CONFIG_DARWIN_USER

Paolo Bonzini's avatar
Paolo Bonzini committed
140 141
$(call set-vpath, $(SRC_PATH)/darwin-user)

142
QEMU_CFLAGS+=-I$(SRC_PATH)/darwin-user -I$(SRC_PATH)/darwin-user/$(TARGET_ARCH)
143 144 145 146 147 148

# Leave some space for the regular program loading zone
LDFLAGS+=-Wl,-segaddr,__STD_PROG_ZONE,0x1000 -image_base 0x0e000000

LIBS+=-lmx

Juan Quintela's avatar
Juan Quintela committed
149
obj-y = main.o commpage.o machload.o mmap.o signal.o syscall.o thunk.o \
150
        gdbstub.o
151

152
obj-i386-y += ioport-user.o
153

154 155 156
$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y): $(GENERATED_HEADERS)

obj-y += $(addprefix ../libuser/, $(user-obj-y))
Blue Swirl's avatar
Blue Swirl committed
157
obj-y += $(addprefix ../libdis-user/, $(libdis-y))
158
obj-y += $(libobj-y)
159 160 161

endif #CONFIG_DARWIN_USER

162 163 164 165 166
#########################################################
# BSD user emulator target

ifdef CONFIG_BSD_USER

Paolo Bonzini's avatar
Paolo Bonzini committed
167 168
$(call set-vpath, $(SRC_PATH)/bsd-user)

169
QEMU_CFLAGS+=-I$(SRC_PATH)/bsd-user -I$(SRC_PATH)/bsd-user/$(TARGET_ARCH)
170

Blue Swirl's avatar
Blue Swirl committed
171
obj-y = main.o bsdload.o elfload.o mmap.o signal.o strace.o syscall.o \
172
        gdbstub.o uaccess.o
173

174
obj-i386-y += ioport-user.o
175

176 177 178
$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y): $(GENERATED_HEADERS)

obj-y += $(addprefix ../libuser/, $(user-obj-y))
Blue Swirl's avatar
Blue Swirl committed
179
obj-y += $(addprefix ../libdis-user/, $(libdis-y))
180
obj-y += $(libobj-y)
181 182 183

endif #CONFIG_BSD_USER

184 185
#########################################################
# System emulator target
186
ifdef CONFIG_SOFTMMU
187

Blue Swirl's avatar
Blue Swirl committed
188
obj-y = arch_init.o cpus.o monitor.o machine.o gdbstub.o balloon.o
189 190
# virtio has to be here due to weird dependency between PCI and virtio-net.
# need to fix this properly
Paul Brook's avatar
Paul Brook committed
191
obj-$(CONFIG_VIRTIO) += virtio-blk.o virtio-balloon.o virtio-net.o virtio-serial-bus.o
192
obj-$(CONFIG_VIRTIO_PCI) += virtio-pci.o
193 194
obj-y += vhost_net.o
obj-$(CONFIG_VHOST_NET) += vhost.o
Paul Brook's avatar
Paul Brook committed
195
obj-$(CONFIG_REALLY_VIRTFS) += virtio-9p.o
196
obj-y += rwhandler.o
Juan Quintela's avatar
Juan Quintela committed
197
obj-$(CONFIG_KVM) += kvm.o kvm-all.o
198
obj-$(CONFIG_NO_KVM) += kvm-stub.o
199
LIBS+=-lz
bellard's avatar
bellard committed
200

201 202
QEMU_CFLAGS += $(VNC_TLS_CFLAGS)
QEMU_CFLAGS += $(VNC_SASL_CFLAGS)
203
QEMU_CFLAGS += $(VNC_JPEG_CFLAGS)
Corentin Chary's avatar
Corentin Chary committed
204
QEMU_CFLAGS += $(VNC_PNG_CFLAGS)
205

206
# xen backend driver support
207
obj-$(CONFIG_XEN) += xen_machine_pv.o xen_domainbuild.o
208

209
# Inter-VM PCI shared memory
210
obj-$(CONFIG_KVM) += ivshmem.o
211

212
# Hardware support
Blue Swirl's avatar
Blue Swirl committed
213
obj-i386-y += vga.o
Blue Swirl's avatar
Blue Swirl committed
214
obj-i386-y += mc146818rtc.o i8259.o pc.o
Blue Swirl's avatar
Blue Swirl committed
215
obj-i386-y += cirrus_vga.o apic.o ioapic.o piix_pci.o
Alexander Graf's avatar
Alexander Graf committed
216
obj-i386-y += vmmouse.o vmport.o hpet.o applesmc.o
Markus Armbruster's avatar
Markus Armbruster committed
217
obj-i386-y += device-hotplug.o pci-hotplug.o smbios.o wdt_ib700.o
Blue Swirl's avatar
Blue Swirl committed
218
obj-i386-y += debugcon.o multiboot.o
219
obj-i386-y += pc_piix.o
220

221
# shared objects
Blue Swirl's avatar
Blue Swirl committed
222
obj-ppc-y = ppc.o
Blue Swirl's avatar
Blue Swirl committed
223
obj-ppc-y += vga.o
224
# PREP target
Blue Swirl's avatar
Blue Swirl committed
225
obj-ppc-y += i8259.o mc146818rtc.o
Blue Swirl's avatar
Blue Swirl committed
226
obj-ppc-y += ppc_prep.o
227
# OldWorld PowerMac
228
obj-ppc-y += ppc_oldworld.o
229
# NewWorld PowerMac
230
obj-ppc-y += ppc_newworld.o
231
# PowerPC 4xx boards
Blue Swirl's avatar
Blue Swirl committed
232
obj-ppc-y += ppc4xx_devs.o ppc4xx_pci.o ppc405_uc.o ppc405_boards.o
233
obj-ppc-y += ppc440.o ppc440_bamboo.o
234
# PowerPC E500 boards
235
obj-ppc-y += ppce500_mpc8544ds.o
236 237
# PowerPC 440 Xilinx ML507 reference board.
obj-ppc-y += virtex_ml507.o
238
obj-ppc-$(CONFIG_KVM) += kvm_ppc.o
239
obj-ppc-$(CONFIG_FDT) += device_tree.o
240

241 242 243 244 245 246
# Xilinx PPC peripherals
obj-ppc-y += xilinx_intc.o
obj-ppc-y += xilinx_timer.o
obj-ppc-y += xilinx_uartlite.o
obj-ppc-y += xilinx_ethlite.o

247
obj-mips-y = mips_r4k.o mips_jazz.o mips_malta.o mips_mipssim.o
248
obj-mips-y += mips_addr.o mips_timer.o mips_int.o
Blue Swirl's avatar
Blue Swirl committed
249
obj-mips-y += vga.o i8259.o
250
obj-mips-y += g364fb.o jazz_led.o
Blue Swirl's avatar
Blue Swirl committed
251
obj-mips-y += gt64xxx.o mc146818rtc.o
Blue Swirl's avatar
Blue Swirl committed
252
obj-mips-y += cirrus_vga.o
253
obj-mips-$(CONFIG_FULONG) += bonito.o vt82c686.o mips_fulong2e.o
254 255 256 257 258 259 260 261 262

obj-microblaze-y = petalogix_s3adsp1800_mmu.o

obj-microblaze-y += microblaze_pic_cpu.o
obj-microblaze-y += xilinx_intc.o
obj-microblaze-y += xilinx_timer.o
obj-microblaze-y += xilinx_uartlite.o
obj-microblaze-y += xilinx_ethlite.o

263
obj-microblaze-$(CONFIG_FDT) += device_tree.o
264

265
# Boards
266 267 268 269
obj-cris-y = cris_pic_cpu.o
obj-cris-y += cris-boot.o
obj-cris-y += etraxfs.o axis_dev88.o
obj-cris-y += axis_dev88.o
270 271

# IO blocks
272 273 274 275 276 277
obj-cris-y += etraxfs_dma.o
obj-cris-y += etraxfs_pic.o
obj-cris-y += etraxfs_eth.o
obj-cris-y += etraxfs_timer.o
obj-cris-y += etraxfs_ser.o

bellard's avatar
bellard committed
278
ifeq ($(TARGET_ARCH), sparc64)
Blue Swirl's avatar
Blue Swirl committed
279
obj-sparc-y = sun4u.o apb_pci.o
Blue Swirl's avatar
Blue Swirl committed
280
obj-sparc-y += vga.o
Blue Swirl's avatar
Blue Swirl committed
281
obj-sparc-y += mc146818rtc.o
Blue Swirl's avatar
Blue Swirl committed
282
obj-sparc-y += cirrus_vga.o
bellard's avatar
bellard committed
283
else
284
obj-sparc-y = sun4m.o lance.o tcx.o sun4m_iommu.o slavio_intctl.o
Blue Swirl's avatar
Blue Swirl committed
285
obj-sparc-y += slavio_timer.o slavio_misc.o sparc32_dma.o
286 287 288
obj-sparc-y += cs4231.o eccmemctl.o sbi.o sun4c_intctl.o
endif

Paul Brook's avatar
Paul Brook committed
289
obj-arm-y = integratorcp.o versatilepb.o arm_pic.o arm_timer.o
290 291
obj-arm-y += arm_boot.o pl011.o pl031.o pl050.o pl080.o pl110.o pl181.o pl190.o
obj-arm-y += versatile_pci.o
Paul Brook's avatar
Paul Brook committed
292
obj-arm-y += realview_gic.o realview.o arm_sysctl.o arm11mpcore.o a9mpcore.o
293 294 295 296 297
obj-arm-y += armv7m.o armv7m_nvic.o stellaris.o pl022.o stellaris_enet.o
obj-arm-y += pl061.o
obj-arm-y += arm-semi.o
obj-arm-y += pxa2xx.o pxa2xx_pic.o pxa2xx_gpio.o pxa2xx_timer.o pxa2xx_dma.o
obj-arm-y += pxa2xx_lcd.o pxa2xx_mmci.o pxa2xx_pcmcia.o pxa2xx_keypad.o
Blue Swirl's avatar
Blue Swirl committed
298
obj-arm-y += gumstix.o
Blue Swirl's avatar
Blue Swirl committed
299
obj-arm-y += zaurus.o ide/microdrive.o spitz.o tosa.o tc6393xb.o
cmchao's avatar
cmchao committed
300 301
obj-arm-y += omap1.o omap_lcdc.o omap_dma.o omap_clk.o omap_mmc.o omap_i2c.o \
		omap_gpio.o omap_intc.o omap_uart.o
302 303
obj-arm-y += omap2.o omap_dss.o soc_dma.o omap_gptimer.o omap_synctimer.o \
		omap_gpmc.o omap_sdrc.o omap_spi.o omap_tap.o omap_l4.o
304 305 306
obj-arm-y += omap_sx1.o palm.o tsc210x.o
obj-arm-y += nseries.o blizzard.o onenand.o vga.o cbus.o tusb6010.o usb-musb.o
obj-arm-y += mst_fpga.o mainstone.o
Blue Swirl's avatar
Blue Swirl committed
307
obj-arm-y += musicpal.o bitbang_i2c.o marvell_88w8618_audio.o
308 309 310 311 312 313
obj-arm-y += framebuffer.o
obj-arm-y += syborg.o syborg_fb.o syborg_interrupt.o syborg_keyboard.o
obj-arm-y += syborg_serial.o syborg_timer.o syborg_pointer.o syborg_rtc.o
obj-arm-y += syborg_virtio.o

obj-sh4-y = shix.o r2d.o sh7750.o sh7750_regnames.o tc58128.o
Blue Swirl's avatar
Blue Swirl committed
314
obj-sh4-y += sh_timer.o sh_serial.o sh_intc.o sh_pci.o sm501.o
Blue Swirl's avatar
Blue Swirl committed
315
obj-sh4-y += ide/mmio.o
316 317 318 319

obj-m68k-y = an5206.o mcf5206.o mcf_uart.o mcf_intc.o mcf5208.o mcf_fec.o
obj-m68k-y += m68k-semi.o dummy_m68k.o

320
obj-s390x-y = s390-virtio-bus.o s390-virtio.o
321

322 323
obj-alpha-y = alpha_palcode.o

324
main.o: QEMU_CFLAGS+=$(GPROF_CFLAGS)
325

326
monitor.o: hmp-commands.h qmp-commands.h
327

328 329 330
$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y): $(GENERATED_HEADERS)

obj-y += $(addprefix ../, $(common-obj-y))
Blue Swirl's avatar
Blue Swirl committed
331
obj-y += $(addprefix ../libdis/, $(libdis-y))
332 333
obj-y += $(libobj-y)
obj-y += $(addprefix $(HWDIR)/, $(hw-obj-y))
bellard's avatar
bellard committed
334

335
endif # CONFIG_SOFTMMU
336

337
obj-y += $(addprefix ../, $(trace-obj-y))
338 339
obj-$(CONFIG_GDBSTUB_XML) += gdbstub-xml.o

340
$(QEMU_PROG): $(obj-y) $(obj-$(TARGET_BASE_ARCH)-y)
341 342 343
	$(call LINK,$(obj-y) $(obj-$(TARGET_BASE_ARCH)-y))


344
gdbstub-xml.c: $(TARGET_XML_FILES) $(SRC_PATH)/feature_to_c.sh
345
	$(call quiet-command,rm -f $@ && $(SHELL) $(SRC_PATH)/feature_to_c.sh $@ $(TARGET_XML_FILES),"  GEN   $(TARGET_DIR)$@")
346

347
hmp-commands.h: $(SRC_PATH)/hmp-commands.hx
348 349
	$(call quiet-command,sh $(SRC_PATH)/hxtool -h < $< > $@,"  GEN   $(TARGET_DIR)$@")

350
qmp-commands.h: $(SRC_PATH)/qmp-commands.hx
351 352
	$(call quiet-command,sh $(SRC_PATH)/hxtool -h < $< > $@,"  GEN   $(TARGET_DIR)$@")

bellard's avatar
bellard committed
353
clean:
354
	rm -f *.o *.a *~ $(PROGS) nwfpe/*.o fpu/*.o
355
	rm -f *.d */*.d tcg/*.o ide/*.o
356
	rm -f hmp-commands.h qmp-commands.h gdbstub-xml.c
357 358 359
ifdef CONFIG_SYSTEMTAP_TRACE
	rm -f *.stp
endif
360

361
install: all
bellard's avatar
bellard committed
362
ifneq ($(PROGS),)
363 364 365 366
	$(INSTALL) -m 755 $(PROGS) "$(DESTDIR)$(bindir)"
ifneq ($(STRIP),)
	$(STRIP) $(patsubst %,"$(DESTDIR)$(bindir)/%",$(PROGS))
endif
bellard's avatar
bellard committed
367
endif
368 369 370 371
ifdef CONFIG_SYSTEMTAP_TRACE
	$(INSTALL_DIR) "$(DESTDIR)$(datadir)/../systemtap/tapset"
	$(INSTALL_DATA) $(QEMU_PROG).stp "$(DESTDIR)$(datadir)/../systemtap/tapset"
endif
bellard's avatar
bellard committed
372

373 374
# Include automatically generated dependency files
-include $(wildcard *.d */*.d)