blob: 8ed1eba95b9c29ab4e47349cbdb2dbdf174d9106 [file] [log] [blame]
Anthony Liguori562593a2009-08-04 08:24:23 -05001# -*- Mode: makefile -*-
2
Peter Crosthwaite6b4ad3b2015-05-25 22:38:06 -07003BUILD_DIR?=$(CURDIR)/..
4
Juan Quinteladeed3cc2009-10-07 02:40:57 +02005include ../config-host.mak
Juan Quintela25be210f2009-10-07 02:41:00 +02006include config-target.mak
aliguori17759182009-01-21 18:12:52 +00007include $(SRC_PATH)/rules.mak
bellard626df762003-08-10 21:39:31 +00008
Paolo Bonzinie0e312f2019-01-23 14:56:01 +08009ifdef CONFIG_SOFTMMU
10include config-devices.mak
11endif
12
Michael Marineau12a1ddc2015-08-09 00:02:55 -070013$(call set-vpath, $(SRC_PATH):$(BUILD_DIR))
Jan Kiszkaaf2be202011-06-23 10:05:12 +020014ifdef CONFIG_LINUX
Eduardo Habkost67cf3f52020-03-11 19:23:41 -040015QEMU_CFLAGS += -isystem ../linux-headers
Jan Kiszkaaf2be202011-06-23 10:05:12 +020016endif
Michael S. Tsirkin9edc19c2018-03-21 17:22:07 +020017QEMU_CFLAGS += -iquote .. -iquote $(SRC_PATH)/target/$(TARGET_BASE_ARCH) -DNEED_CPU_H
bellard1e43adf2003-09-30 20:54:24 +000018
Michael S. Tsirkin9edc19c2018-03-21 17:22:07 +020019QEMU_CFLAGS+=-iquote $(SRC_PATH)/include
Anthony Liguori2f28d2f2011-12-03 17:10:08 -060020
bellard16e9b7d2003-10-27 21:09:52 +000021ifdef CONFIG_USER_ONLY
bellard40293e52008-01-31 11:32:10 +000022# user emulator name
Paolo Bonzinic1799a82013-06-14 15:19:07 +010023QEMU_PROG=qemu-$(TARGET_NAME)
Michael Tokarev5c40c732014-04-28 11:03:03 +040024QEMU_PROG_BUILD = $(QEMU_PROG)
bellard16e9b7d2003-10-27 21:09:52 +000025else
bellard40293e52008-01-31 11:32:10 +000026# system emulator name
Michael Tokarev5c40c732014-04-28 11:03:03 +040027QEMU_PROG=qemu-system-$(TARGET_NAME)$(EXESUF)
Stefan Weil2fe47fc2017-11-16 17:37:32 +010028ifneq (,$(findstring -mwindows,$(SDL_LIBS)))
Stefan Weil0fa54912011-12-22 11:18:53 +010029# Terminate program name with a 'w' because the linker builds a windows executable.
Paolo Bonzinic1799a82013-06-14 15:19:07 +010030QEMU_PROGW=qemu-system-$(TARGET_NAME)w$(EXESUF)
Michael Tokarev5c40c732014-04-28 11:03:03 +040031$(QEMU_PROG): $(QEMU_PROGW)
Peter Maydell0bdb12c2016-10-04 17:27:21 +010032 $(call quiet-command,$(OBJCOPY) --subsystem console $(QEMU_PROGW) $(QEMU_PROG),"GEN","$(TARGET_DIR)$(QEMU_PROG)")
Michael Tokarev5c40c732014-04-28 11:03:03 +040033QEMU_PROG_BUILD = $(QEMU_PROGW)
34else
35QEMU_PROG_BUILD = $(QEMU_PROG)
36endif
bellardde5eaa62003-11-16 23:18:17 +000037endif
bellard728c9fd2004-01-05 00:08:14 +000038
Michael Tokarev5c40c732014-04-28 11:03:03 +040039PROGS=$(QEMU_PROG) $(QEMU_PROGW)
Peter Maydellb8841702010-11-16 20:07:07 +000040STPFILES=
bellard626df762003-08-10 21:39:31 +000041
Juan Quintela91880d92009-10-07 02:41:01 +020042config-target.h: config-target.h-timestamp
43config-target.h-timestamp: config-target.mak
44
Julio Montes6c22ea92019-07-05 14:35:53 +000045config-devices.h: config-devices.h-timestamp
46config-devices.h-timestamp: config-devices.mak
47
Lluís6d8a7642011-08-31 20:30:43 +020048ifdef CONFIG_TRACE_SYSTEMTAP
Daniel P. Berrangé62dd1042019-01-23 12:00:16 +000049stap: $(QEMU_PROG).stp-installed $(QEMU_PROG).stp $(QEMU_PROG)-simpletrace.stp $(QEMU_PROG)-log.stp
Daniel P. Berrangec276b172010-11-12 13:20:25 +000050
51ifdef CONFIG_USER_ONLY
52TARGET_TYPE=user
53else
54TARGET_TYPE=system
55endif
56
Daniel P. Berrangeed865052017-07-28 14:36:31 +010057tracetool-y = $(SRC_PATH)/scripts/tracetool.py
58tracetool-y += $(shell find $(SRC_PATH)/scripts/tracetool -name "*.py")
59
60$(QEMU_PROG).stp-installed: $(BUILD_DIR)/trace-events-all $(tracetool-y)
Lluís Vilanovac0424932012-04-18 20:15:45 +020061 $(call quiet-command,$(TRACETOOL) \
Daniel P. Berrange2098c562017-01-25 16:14:14 +000062 --group=all \
Lluís Vilanova650ab982012-04-03 20:47:39 +020063 --format=stap \
Lluís Vilanova5b808272014-05-27 15:02:14 +020064 --backends=$(TRACE_BACKENDS) \
Lluís Vilanova650ab982012-04-03 20:47:39 +020065 --binary=$(bindir)/$(QEMU_PROG) \
Paolo Bonzinib9a7b742013-06-04 14:45:26 +020066 --target-name=$(TARGET_NAME) \
Lluís Vilanova650ab982012-04-03 20:47:39 +020067 --target-type=$(TARGET_TYPE) \
Daniel P. Berrange0bc64842016-10-04 14:35:58 +010068 $< > $@,"GEN","$(TARGET_DIR)$(QEMU_PROG).stp-installed")
Alon Levyc14518e2013-06-14 15:19:07 +010069
Daniel P. Berrangeed865052017-07-28 14:36:31 +010070$(QEMU_PROG).stp: $(BUILD_DIR)/trace-events-all $(tracetool-y)
Alon Levyc14518e2013-06-14 15:19:07 +010071 $(call quiet-command,$(TRACETOOL) \
Daniel P. Berrange2098c562017-01-25 16:14:14 +000072 --group=all \
Alon Levyc14518e2013-06-14 15:19:07 +010073 --format=stap \
Lluís Vilanova5b808272014-05-27 15:02:14 +020074 --backends=$(TRACE_BACKENDS) \
Alon Levyc14518e2013-06-14 15:19:07 +010075 --binary=$(realpath .)/$(QEMU_PROG) \
Paolo Bonzinib9a7b742013-06-04 14:45:26 +020076 --target-name=$(TARGET_NAME) \
Alon Levyc14518e2013-06-14 15:19:07 +010077 --target-type=$(TARGET_TYPE) \
Daniel P. Berrange0bc64842016-10-04 14:35:58 +010078 $< > $@,"GEN","$(TARGET_DIR)$(QEMU_PROG).stp")
Alon Levyc14518e2013-06-14 15:19:07 +010079
Daniel P. Berrangeed865052017-07-28 14:36:31 +010080$(QEMU_PROG)-simpletrace.stp: $(BUILD_DIR)/trace-events-all $(tracetool-y)
Stefan Hajnoczie0b2fd02014-06-22 21:46:07 +080081 $(call quiet-command,$(TRACETOOL) \
Daniel P. Berrange2098c562017-01-25 16:14:14 +000082 --group=all \
Stefan Hajnoczie0b2fd02014-06-22 21:46:07 +080083 --format=simpletrace-stap \
84 --backends=$(TRACE_BACKENDS) \
85 --probe-prefix=qemu.$(TARGET_TYPE).$(TARGET_NAME) \
Daniel P. Berrange0bc64842016-10-04 14:35:58 +010086 $< > $@,"GEN","$(TARGET_DIR)$(QEMU_PROG)-simpletrace.stp")
Stefan Hajnoczie0b2fd02014-06-22 21:46:07 +080087
Daniel P. Berrangé62dd1042019-01-23 12:00:16 +000088$(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")
95
Daniel P. Berrangec276b172010-11-12 13:20:25 +000096else
97stap:
98endif
Paolo Bonzinia273f4c2016-11-02 20:46:13 +010099.PHONY: stap
Daniel P. Berrangec276b172010-11-12 13:20:25 +0000100
101all: $(PROGS) stap
Juan Quintela91880d92009-10-07 02:41:01 +0200102
Paul Brookc2fb2632009-05-25 18:54:53 +0100103# Dummy command so that make thinks it has done something
104 @true
bellard626df762003-08-10 21:39:31 +0000105
Paolo Bonzini310b3fe2019-03-08 17:39:08 +0100106obj-y += trace/
107
bellard40293e52008-01-31 11:32:10 +0000108#########################################################
bellard626df762003-08-10 21:39:31 +0000109# cpu emulator library
Richard Henderson7886cef2019-09-19 13:30:29 -0700110obj-y += exec.o exec-vary.o
Yang Zhongd9bb58e2017-06-02 14:06:44 +0800111obj-y += accel/
Richard Hendersondb432672017-09-15 14:11:45 -0700112obj-$(CONFIG_TCG) += tcg/tcg.o tcg/tcg-op.o tcg/tcg-op-vec.o tcg/tcg-op-gvec.o
Richard Hendersond2fd7452017-09-14 13:53:46 -0700113obj-$(CONFIG_TCG) += tcg/tcg-common.o tcg/optimize.o
Philippe Mathieu-Daudé8dfaf232017-06-20 13:30:09 -0300114obj-$(CONFIG_TCG_INTERPRETER) += tcg/tci.o
Stefan Weil50348332013-01-01 18:43:56 +0100115obj-$(CONFIG_TCG_INTERPRETER) += disas/tci.o
Paolo Bonzini8f971cf2018-05-22 21:20:03 +0200116obj-$(CONFIG_TCG) += fpu/softfloat.o
Thomas Huthfcf5ef22016-10-11 08:56:52 +0200117obj-y += target/$(TARGET_BASE_ARCH)/
Paolo Bonzini76cad712012-10-24 11:12:21 +0200118obj-y += disas.o
Ákos Kovácsb77abd92013-09-13 18:25:54 +0100119obj-$(call notempty,$(TARGET_XML_FILES)) += gdbstub-xml.o
Daniel P. Berrangé02f91352019-05-16 10:51:34 +0100120LIBS := $(libs_cpu) $(LIBS)
Paolo Bonzini5e8861a2012-05-29 10:23:15 +0200121
Emilio G. Cota54cb65d2017-08-30 18:39:53 -0400122obj-$(CONFIG_PLUGIN) += plugins/
123
bellard40293e52008-01-31 11:32:10 +0000124#########################################################
125# Linux user emulator target
126
127ifdef CONFIG_LINUX_USER
128
Timothy E Baldwin4d330ce2016-05-12 18:47:46 +0100129QEMU_CFLAGS+=-I$(SRC_PATH)/linux-user/$(TARGET_ABI_DIR) \
Peter Maydellba453782016-06-13 11:57:18 +0100130 -I$(SRC_PATH)/linux-user/host/$(ARCH) \
Laurent Vivier4d6a8352020-03-10 11:33:43 +0100131 -I$(SRC_PATH)/linux-user \
132 -Ilinux-user/$(TARGET_ABI_DIR)
Blue Swirl5ba65312009-08-15 07:52:19 +0000133
Paolo Bonzini7fc51522012-05-29 09:33:59 +0200134obj-y += linux-user/
Philippe Mathieu-Daudé58410662017-09-11 18:33:25 -0300135obj-y += gdbstub.o thunk.o
bellard40293e52008-01-31 11:32:10 +0000136
bellard40293e52008-01-31 11:32:10 +0000137endif #CONFIG_LINUX_USER
138
139#########################################################
blueswir184778502008-10-26 20:33:16 +0000140# BSD user emulator target
141
142ifdef CONFIG_BSD_USER
143
Stacey Sonadfc3e92014-06-08 09:57:22 -0700144QEMU_CFLAGS+=-I$(SRC_PATH)/bsd-user -I$(SRC_PATH)/bsd-user/$(TARGET_ABI_DIR) \
145 -I$(SRC_PATH)/bsd-user/$(HOST_VARIANT_DIR)
blueswir184778502008-10-26 20:33:16 +0000146
Paolo Bonzini7fc51522012-05-29 09:33:59 +0200147obj-y += bsd-user/
Philippe Mathieu-Daudé58410662017-09-11 18:33:25 -0300148obj-y += gdbstub.o
blueswir184778502008-10-26 20:33:16 +0000149
blueswir184778502008-10-26 20:33:16 +0000150endif #CONFIG_BSD_USER
151
152#########################################################
bellard40293e52008-01-31 11:32:10 +0000153# System emulator target
Juan Quintela76dfdd22009-08-03 14:46:41 +0200154ifdef CONFIG_SOFTMMU
Markus Armbrusterac057872019-06-19 22:10:42 +0200155obj-y += arch_init.o cpus.o gdbstub.o balloon.o ioport.o
Thomas Huth5ddc6482017-06-26 07:22:57 +0200156obj-y += qtest.o
Markus Armbrusterc2a87142019-06-19 22:10:48 +0200157obj-y += dump/
Paolo Bonzinic353f262012-05-29 11:49:34 +0200158obj-y += hw/
Kevin Wolfe84328f2019-06-13 17:33:57 +0200159obj-y += monitor/
Markus Armbruster88554a22019-02-14 16:22:40 +0100160obj-y += qapi/
Yang Zhongd9bb58e2017-06-02 14:06:44 +0800161obj-y += memory.o
Andreas Färberc22d8e02013-05-28 14:53:32 +0200162obj-y += memory_mapping.o
Juan Quintela46d702b2017-04-24 21:03:48 +0200163obj-y += migration/ram.o
Alexander Bulekovbac068e2020-02-19 23:10:57 -0500164obj-y += softmmu/
Wei Liu7398dfc2015-03-09 14:54:33 +0000165LIBS := $(libs_softmmu) $(LIBS)
bellard4fb240a2007-11-07 19:24:02 +0000166
bellarda541f292004-04-12 20:39:29 +0000167# Hardware support
Paolo Bonzinib9a7b742013-06-04 14:45:26 +0200168ifeq ($(TARGET_NAME), sparc64)
Paolo Bonzini5e8861a2012-05-29 10:23:15 +0200169obj-y += hw/sparc64/
bellard34751872005-07-02 14:31:34 +0000170else
Paolo Bonzini5e8861a2012-05-29 10:23:15 +0200171obj-y += hw/$(TARGET_BASE_ARCH)/
bellard34751872005-07-02 14:31:34 +0000172endif
Juan Quintela96374432009-07-16 18:33:58 +0200173
Laurent Vivier3dff1992019-04-01 16:12:19 +0200174generated-files-y += hmp-commands.h hmp-commands-info.h
Julio Montes6c22ea92019-07-05 14:35:53 +0000175generated-files-y += config-devices.h
Andreas Färber0e8c9212010-01-06 20:24:05 +0100176
Juan Quintela76dfdd22009-08-03 14:46:41 +0200177endif # CONFIG_SOFTMMU
bellard00a67ba2006-10-28 12:19:07 +0000178
Fam Zhengba1183d2014-02-10 14:48:52 +0800179dummy := $(call unnest-vars,,obj-y)
Paolo Bonzinid608cc52014-04-29 17:49:25 +0200180all-obj-y := $(obj-y)
Fam Zhengba1183d2014-02-10 14:48:52 +0800181
Paolo Bonzini99100dc2012-05-22 13:41:27 +0200182include $(SRC_PATH)/Makefile.objs
Fam Zhengcc475692014-02-10 14:48:59 +0800183dummy := $(call unnest-vars,.., \
Daniel P. Berrange5b76dd12015-10-21 13:16:21 +0100184 authz-obj-y \
Fam Zhengcc475692014-02-10 14:48:59 +0800185 block-obj-y \
186 block-obj-m \
Marc-André Lureau32d955a2016-12-12 15:49:01 +0300187 chardev-obj-y \
Daniel P. Berrangefb377262015-09-02 10:57:27 +0100188 crypto-obj-y \
Daniel P. Berrange0c7012e2015-09-02 11:18:16 +0100189 qom-obj-y \
Daniel P. Berrange666a3af2015-02-27 16:19:33 +0000190 io-obj-y \
Fam Zhengcc475692014-02-10 14:48:59 +0800191 common-obj-y \
Marc-André Lureau675b9b52019-02-12 17:25:23 +0100192 common-obj-m)
Paolo Bonzinid608cc52014-04-29 17:49:25 +0200193all-obj-y += $(common-obj-y)
Daniel P. Berrange0c7012e2015-09-02 11:18:16 +0100194all-obj-y += $(qom-obj-y)
Daniel P. Berrange5b76dd12015-10-21 13:16:21 +0100195all-obj-$(CONFIG_SOFTMMU) += $(authz-obj-y)
Marc-André Lureau32d955a2016-12-12 15:49:01 +0300196all-obj-$(CONFIG_SOFTMMU) += $(block-obj-y) $(chardev-obj-y)
Daniel P. Berrangefb377262015-09-02 10:57:27 +0100197all-obj-$(CONFIG_SOFTMMU) += $(crypto-obj-y)
Daniel P. Berrange666a3af2015-02-27 16:19:33 +0000198all-obj-$(CONFIG_SOFTMMU) += $(io-obj-y)
Paolo Bonzini7fc51522012-05-29 09:33:59 +0200199
Paolo Bonzinie0e312f2019-01-23 14:56:01 +0800200ifdef CONFIG_SOFTMMU
Michael S. Tsirkina9ad5e12015-02-19 08:48:52 +0100201$(QEMU_PROG_BUILD): config-devices.mak
Paolo Bonzinie0e312f2019-01-23 14:56:01 +0800202endif
Michael S. Tsirkina9ad5e12015-02-19 08:48:52 +0100203
Paolo Bonziniebedb372017-09-19 16:20:31 +0200204COMMON_LDADDS = ../libqemuutil.a
Daniel P. Berrange0ab8ed12017-01-25 16:14:15 +0000205
Michael Tokarev5c40c732014-04-28 11:03:03 +0400206# build either PROG or PROGW
Alexander Bulekov7b733862020-02-19 23:10:58 -0500207$(QEMU_PROG_BUILD): $(all-obj-y) $(COMMON_LDADDS) $(softmmu-main-y)
Michael S. Tsirkina9ad5e12015-02-19 08:48:52 +0100208 $(call LINK, $(filter-out %.mak, $^))
Programmingkid4e340172015-05-19 09:11:17 +0100209ifdef CONFIG_DARWIN
Peter Maydell0bdb12c2016-10-04 17:27:21 +0100210 $(call quiet-command,Rez -append $(SRC_PATH)/pc-bios/qemu.rsrc -o $@,"REZ","$(TARGET_DIR)$@")
211 $(call quiet-command,SetFile -a C $@,"SETFILE","$(TARGET_DIR)$@")
Programmingkid4e340172015-05-19 09:11:17 +0100212endif
Juan Quintela16394482009-07-16 18:34:04 +0200213
Blue Swirl4c3b5a42011-01-20 20:54:21 +0000214gdbstub-xml.c: $(TARGET_XML_FILES) $(SRC_PATH)/scripts/feature_to_c.sh
Peter Maydell0bdb12c2016-10-04 17:27:21 +0100215 $(call quiet-command,rm -f $@ && $(SHELL) $(SRC_PATH)/scripts/feature_to_c.sh $@ $(TARGET_XML_FILES),"GEN","$(TARGET_DIR)$@")
pbrook56aebc82008-10-11 17:55:29 +0000216
Paolo Bonzini077de812016-06-07 13:27:04 +0200217hmp-commands.h: $(SRC_PATH)/hmp-commands.hx $(SRC_PATH)/scripts/hxtool
Peter Maydell0bdb12c2016-10-04 17:27:21 +0100218 $(call quiet-command,sh $(SRC_PATH)/scripts/hxtool -h < $< > $@,"GEN","$(TARGET_DIR)$@")
Blue Swirl23130862009-06-06 08:22:04 +0000219
Paolo Bonzini077de812016-06-07 13:27:04 +0200220hmp-commands-info.h: $(SRC_PATH)/hmp-commands-info.hx $(SRC_PATH)/scripts/hxtool
Peter Maydell0bdb12c2016-10-04 17:27:21 +0100221 $(call quiet-command,sh $(SRC_PATH)/scripts/hxtool -h < $< > $@,"GEN","$(TARGET_DIR)$@")
Pavel Butsykinda76ee72015-09-10 18:38:58 +0300222
Michael Muellerdced7ee2016-09-05 10:52:19 +0200223clean: clean-target
Peter Maydellb54fa7d2012-06-20 18:02:33 +0100224 rm -f *.a *~ $(PROGS)
225 rm -f $(shell find . -name '*.[od]')
Marc-André Lureau84289492016-09-12 13:19:11 +0400226 rm -f hmp-commands.h gdbstub-xml.c
Paolo Bonzini74970d32019-02-15 10:23:00 +0100227 rm -f trace/generated-helpers.c trace/generated-helpers.c-timestamp
Lluís6d8a7642011-08-31 20:30:43 +0200228ifdef CONFIG_TRACE_SYSTEMTAP
Daniel P. Berrangec276b172010-11-12 13:20:25 +0000229 rm -f *.stp
230endif
bellard1e43adf2003-09-30 20:54:24 +0000231
Alexander Bulekovc621dc32020-02-19 23:11:13 -0500232ifdef CONFIG_FUZZ
233include $(SRC_PATH)/tests/qtest/fuzz/Makefile.include
234include $(SRC_PATH)/tests/qtest/Makefile.include
235
236fuzz: fuzz-vars
237fuzz-vars: QEMU_CFLAGS := $(FUZZ_CFLAGS) $(QEMU_CFLAGS)
238fuzz-vars: QEMU_LDFLAGS := $(FUZZ_LDFLAGS) $(QEMU_LDFLAGS)
239fuzz-vars: $(QEMU_PROG_FUZZ)
240dummy := $(call unnest-vars,, fuzz-obj-y)
241
242
243$(QEMU_PROG_FUZZ): config-devices.mak $(all-obj-y) $(COMMON_LDADDS) $(fuzz-obj-y)
244 $(call LINK, $(filter-out %.mak, $^))
245
246endif
247
ths5fafdf22007-09-16 21:08:06 +0000248install: all
bellard9b14bb02004-03-26 22:43:34 +0000249ifneq ($(PROGS),)
Michael Tokarev0d659422014-06-22 10:55:23 +0400250 $(call install-prog,$(PROGS),$(DESTDIR)$(bindir))
bellard9b14bb02004-03-26 22:43:34 +0000251endif
Lluís6d8a7642011-08-31 20:30:43 +0200252ifdef CONFIG_TRACE_SYSTEMTAP
Eduardo Habkost6aae2a22012-04-18 16:55:41 -0300253 $(INSTALL_DIR) "$(DESTDIR)$(qemu_datadir)/../systemtap/tapset"
Alon Levyc14518e2013-06-14 15:19:07 +0100254 $(INSTALL_DATA) $(QEMU_PROG).stp-installed "$(DESTDIR)$(qemu_datadir)/../systemtap/tapset/$(QEMU_PROG).stp"
Stefan Hajnoczie0b2fd02014-06-22 21:46:07 +0800255 $(INSTALL_DATA) $(QEMU_PROG)-simpletrace.stp "$(DESTDIR)$(qemu_datadir)/../systemtap/tapset/$(QEMU_PROG)-simpletrace.stp"
Daniel P. Berrangé62dd1042019-01-23 12:00:16 +0000256 $(INSTALL_DATA) $(QEMU_PROG)-log.stp "$(DESTDIR)$(qemu_datadir)/../systemtap/tapset/$(QEMU_PROG)-log.stp"
Daniel P. Berrangec276b172010-11-12 13:20:25 +0000257endif
bellard626df762003-08-10 21:39:31 +0000258
Laurent Vivier3dff1992019-04-01 16:12:19 +0200259generated-files-y += config-target.h
260Makefile: $(generated-files-y)
Alex Bennée90e671a2019-04-30 14:44:10 +0100261
262# Reports/Analysis
263#
264# The target specific coverage report only cares about target specific
265# blobs and not the shared code.
266#
267
268%/coverage-report.html:
269 @mkdir -p $*
270 $(call quiet-command,\
271 gcovr -r $(SRC_PATH) --object-directory $(CURDIR) \
272 -p --html --html-details -o $@, \
273 "GEN", "coverage-report.html")
274
275.PHONY: coverage-report
276coverage-report: $(CURDIR)/reports/coverage/coverage-report.html