hw/pci-host: save/restore pci host config register
[qemu.git] / Makefile.target
blobffa2657269ac5e4ed4eab213e1bdea0f395a340f
1 # -*- Mode: makefile -*-
3 BUILD_DIR?=$(CURDIR)/..
5 include ../config-host.mak
6 include config-target.mak
7 include $(SRC_PATH)/rules.mak
9 ifdef CONFIG_SOFTMMU
10 include config-devices.mak
11 endif
13 $(call set-vpath, $(SRC_PATH):$(BUILD_DIR))
14 ifdef CONFIG_LINUX
15 QEMU_CFLAGS += -isystem ../linux-headers
16 endif
17 QEMU_CFLAGS += -iquote .. -iquote $(SRC_PATH)/target/$(TARGET_BASE_ARCH) -DNEED_CPU_H
19 QEMU_CFLAGS+=-iquote $(SRC_PATH)/include
21 ifdef CONFIG_USER_ONLY
22 # user emulator name
23 QEMU_PROG=qemu-$(TARGET_NAME)
24 QEMU_PROG_BUILD = $(QEMU_PROG)
25 else
26 # system emulator name
27 QEMU_PROG=qemu-system-$(TARGET_NAME)$(EXESUF)
28 ifneq (,$(findstring -mwindows,$(SDL_LIBS)))
29 # Terminate program name with a 'w' because the linker builds a windows executable.
30 QEMU_PROGW=qemu-system-$(TARGET_NAME)w$(EXESUF)
31 $(QEMU_PROG): $(QEMU_PROGW)
32         $(call quiet-command,$(OBJCOPY) --subsystem console $(QEMU_PROGW) $(QEMU_PROG),"GEN","$(TARGET_DIR)$(QEMU_PROG)")
33 QEMU_PROG_BUILD = $(QEMU_PROGW)
34 else
35 QEMU_PROG_BUILD = $(QEMU_PROG)
36 endif
37 endif
39 PROGS=$(QEMU_PROG) $(QEMU_PROGW)
40 STPFILES=
42 config-target.h: config-target.h-timestamp
43 config-target.h-timestamp: config-target.mak
45 config-devices.h: config-devices.h-timestamp
46 config-devices.h-timestamp: config-devices.mak
48 ifdef CONFIG_TRACE_SYSTEMTAP
49 stap: $(QEMU_PROG).stp-installed $(QEMU_PROG).stp $(QEMU_PROG)-simpletrace.stp $(QEMU_PROG)-log.stp
51 ifdef CONFIG_USER_ONLY
52 TARGET_TYPE=user
53 else
54 TARGET_TYPE=system
55 endif
57 tracetool-y = $(SRC_PATH)/scripts/tracetool.py
58 tracetool-y += $(shell find $(SRC_PATH)/scripts/tracetool -name "*.py")
60 $(QEMU_PROG).stp-installed: $(BUILD_DIR)/trace-events-all $(tracetool-y)
61         $(call quiet-command,$(TRACETOOL) \
62                 --group=all \
63                 --format=stap \
64                 --backends=$(TRACE_BACKENDS) \
65                 --binary=$(bindir)/$(QEMU_PROG) \
66                 --target-name=$(TARGET_NAME) \
67                 --target-type=$(TARGET_TYPE) \
68                 $< > $@,"GEN","$(TARGET_DIR)$(QEMU_PROG).stp-installed")
70 $(QEMU_PROG).stp: $(BUILD_DIR)/trace-events-all $(tracetool-y)
71         $(call quiet-command,$(TRACETOOL) \
72                 --group=all \
73                 --format=stap \
74                 --backends=$(TRACE_BACKENDS) \
75                 --binary=$(realpath .)/$(QEMU_PROG) \
76                 --target-name=$(TARGET_NAME) \
77                 --target-type=$(TARGET_TYPE) \
78                 $< > $@,"GEN","$(TARGET_DIR)$(QEMU_PROG).stp")
80 $(QEMU_PROG)-simpletrace.stp: $(BUILD_DIR)/trace-events-all $(tracetool-y)
81         $(call quiet-command,$(TRACETOOL) \
82                 --group=all \
83                 --format=simpletrace-stap \
84                 --backends=$(TRACE_BACKENDS) \
85                 --probe-prefix=qemu.$(TARGET_TYPE).$(TARGET_NAME) \
86                 $< > $@,"GEN","$(TARGET_DIR)$(QEMU_PROG)-simpletrace.stp")
88 $(QEMU_PROG)-log.stp: $(BUILD_DIR)/trace-events-all $(tracetool-y)
89         $(call quiet-command,$(TRACETOOL) \
90                 --group=all \
91                 --format=log-stap \
92                 --backends=$(TRACE_BACKENDS) \
93                 --probe-prefix=qemu.$(TARGET_TYPE).$(TARGET_NAME) \
94                 $< > $@,"GEN","$(TARGET_DIR)$(QEMU_PROG)-log.stp")
96 else
97 stap:
98 endif
99 .PHONY: stap
101 all: $(PROGS) stap
103 # Dummy command so that make thinks it has done something
104         @true
106 obj-y += trace/
108 #########################################################
109 # cpu emulator library
110 obj-y += exec.o exec-vary.o
111 obj-y += accel/
112 obj-$(CONFIG_TCG) += tcg/tcg.o tcg/tcg-op.o tcg/tcg-op-vec.o tcg/tcg-op-gvec.o
113 obj-$(CONFIG_TCG) += tcg/tcg-common.o tcg/optimize.o
114 obj-$(CONFIG_TCG_INTERPRETER) += tcg/tci.o
115 obj-$(CONFIG_TCG_INTERPRETER) += disas/tci.o
116 obj-$(CONFIG_TCG) += fpu/softfloat.o
117 obj-y += target/$(TARGET_BASE_ARCH)/
118 obj-y += disas.o
119 obj-$(call notempty,$(TARGET_XML_FILES)) += gdbstub-xml.o
120 LIBS := $(libs_cpu) $(LIBS)
122 obj-$(CONFIG_PLUGIN) += plugins/
124 #########################################################
125 # Linux user emulator target
127 ifdef CONFIG_LINUX_USER
129 QEMU_CFLAGS+=-I$(SRC_PATH)/linux-user/$(TARGET_ABI_DIR) \
130              -I$(SRC_PATH)/linux-user/host/$(ARCH) \
131              -I$(SRC_PATH)/linux-user \
132              -Ilinux-user/$(TARGET_ABI_DIR)
134 obj-y += linux-user/
135 obj-y += gdbstub.o thunk.o
137 endif #CONFIG_LINUX_USER
139 #########################################################
140 # BSD user emulator target
142 ifdef CONFIG_BSD_USER
144 QEMU_CFLAGS+=-I$(SRC_PATH)/bsd-user -I$(SRC_PATH)/bsd-user/$(TARGET_ABI_DIR) \
145                          -I$(SRC_PATH)/bsd-user/$(HOST_VARIANT_DIR)
147 obj-y += bsd-user/
148 obj-y += gdbstub.o
150 endif #CONFIG_BSD_USER
152 #########################################################
153 # System emulator target
154 ifdef CONFIG_SOFTMMU
155 obj-y += softmmu/
156 obj-y += gdbstub.o
157 obj-y += dump/
158 obj-y += hw/
159 obj-y += monitor/
160 obj-y += qapi/
161 obj-y += migration/ram.o
162 LIBS := $(libs_softmmu) $(LIBS)
164 # Hardware support
165 ifeq ($(TARGET_NAME), sparc64)
166 obj-y += hw/sparc64/
167 else
168 obj-y += hw/$(TARGET_BASE_ARCH)/
169 endif
171 generated-files-y += hmp-commands.h hmp-commands-info.h
172 generated-files-y += config-devices.h
174 endif # CONFIG_SOFTMMU
176 dummy := $(call unnest-vars,,obj-y)
177 all-obj-y := $(obj-y)
180 # common-obj-m has some crap here, probably as side effect from
181 # unnest-vars recursing into target directories to fill obj-y and not
182 # properly handling the -m case.
184 # Clear common-obj-m as workaround.  Fixes suspious dependency errors
185 # when building devices as modules.  A bit hackish, but should be ok
186 # as long as we do not have any target-specific modules.
188 # The meson-based build system currently in development doesn't need
189 # unnest-vars and will obsolete this workaround.
191 common-obj-m :=
193 include $(SRC_PATH)/Makefile.objs
194 dummy := $(call unnest-vars,.., \
195                authz-obj-y \
196                block-obj-y \
197                block-obj-m \
198                chardev-obj-y \
199                crypto-obj-y \
200                qom-obj-y \
201                io-obj-y \
202                common-obj-y \
203                common-obj-m)
204 all-obj-y += $(common-obj-y)
205 all-obj-y += $(qom-obj-y)
206 all-obj-$(CONFIG_SOFTMMU) += $(authz-obj-y)
207 all-obj-$(CONFIG_SOFTMMU) += $(block-obj-y) $(chardev-obj-y)
208 all-obj-$(CONFIG_SOFTMMU) += $(crypto-obj-y)
209 all-obj-$(CONFIG_SOFTMMU) += $(io-obj-y)
211 ifdef CONFIG_SOFTMMU
212 $(QEMU_PROG_BUILD): config-devices.mak
213 endif
215 COMMON_LDADDS = ../libqemuutil.a
217 # build either PROG or PROGW
218 $(QEMU_PROG_BUILD): $(all-obj-y) $(COMMON_LDADDS) $(softmmu-main-y)
219         $(call LINK, $(filter-out %.mak, $^))
220 ifdef CONFIG_DARWIN
221         $(call quiet-command,Rez -append $(SRC_PATH)/pc-bios/qemu.rsrc -o $@,"REZ","$(TARGET_DIR)$@")
222         $(call quiet-command,SetFile -a C $@,"SETFILE","$(TARGET_DIR)$@")
223 endif
225 gdbstub-xml.c: $(TARGET_XML_FILES) $(SRC_PATH)/scripts/feature_to_c.sh
226         $(call quiet-command,rm -f $@ && $(SHELL) $(SRC_PATH)/scripts/feature_to_c.sh $@ $(TARGET_XML_FILES),"GEN","$(TARGET_DIR)$@")
228 hmp-commands.h: $(SRC_PATH)/hmp-commands.hx $(SRC_PATH)/scripts/hxtool
229         $(call quiet-command,sh $(SRC_PATH)/scripts/hxtool -h < $< > $@,"GEN","$(TARGET_DIR)$@")
231 hmp-commands-info.h: $(SRC_PATH)/hmp-commands-info.hx $(SRC_PATH)/scripts/hxtool
232         $(call quiet-command,sh $(SRC_PATH)/scripts/hxtool -h < $< > $@,"GEN","$(TARGET_DIR)$@")
234 clean: clean-target
235         rm -f *.a *~ $(PROGS)
236         rm -f $(shell find . -name '*.[od]')
237         rm -f hmp-commands.h gdbstub-xml.c
238         rm -f trace/generated-helpers.c trace/generated-helpers.c-timestamp
239 ifdef CONFIG_TRACE_SYSTEMTAP
240         rm -f *.stp
241 endif
243 ifdef CONFIG_FUZZ
244 include $(SRC_PATH)/tests/qtest/fuzz/Makefile.include
245 include $(SRC_PATH)/tests/qtest/Makefile.include
247 fuzz: fuzz-vars
248 fuzz-vars: QEMU_CFLAGS := $(FUZZ_CFLAGS) $(QEMU_CFLAGS)
249 fuzz-vars: QEMU_LDFLAGS := $(FUZZ_LDFLAGS) $(QEMU_LDFLAGS)
250 fuzz-vars: $(QEMU_PROG_FUZZ)
251 dummy := $(call unnest-vars,, fuzz-obj-y)
254 $(QEMU_PROG_FUZZ): config-devices.mak $(all-obj-y) $(COMMON_LDADDS) $(fuzz-obj-y)
255         $(call LINK, $(filter-out %.mak, $^))
257 endif
259 install: all
260 ifneq ($(PROGS),)
261         $(call install-prog,$(PROGS),$(DESTDIR)$(bindir))
262 endif
263 ifdef CONFIG_TRACE_SYSTEMTAP
264         $(INSTALL_DIR) "$(DESTDIR)$(qemu_datadir)/../systemtap/tapset"
265         $(INSTALL_DATA) $(QEMU_PROG).stp-installed "$(DESTDIR)$(qemu_datadir)/../systemtap/tapset/$(QEMU_PROG).stp"
266         $(INSTALL_DATA) $(QEMU_PROG)-simpletrace.stp "$(DESTDIR)$(qemu_datadir)/../systemtap/tapset/$(QEMU_PROG)-simpletrace.stp"
267         $(INSTALL_DATA) $(QEMU_PROG)-log.stp "$(DESTDIR)$(qemu_datadir)/../systemtap/tapset/$(QEMU_PROG)-log.stp"
268 endif
270 generated-files-y += config-target.h
271 Makefile: $(generated-files-y)
273 # Reports/Analysis
275 # The target specific coverage report only cares about target specific
276 # blobs and not the shared code.
279 %/coverage-report.html:
280         @mkdir -p $*
281         $(call quiet-command,\
282                 gcovr -r $(SRC_PATH) --object-directory $(CURDIR) \
283                 -p --html --html-details -o $@, \
284                 "GEN", "coverage-report.html")
286 .PHONY: coverage-report
287 coverage-report: $(CURDIR)/reports/coverage/coverage-report.html