target/riscv: Convert RVXI csr insns to decodetree
[qemu/ar7.git] / Makefile.target
blobd8048aab8f2db4b16a47d651751d924bc0b6d130
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 += -I../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 # Makefile Tests
43 ifdef CONFIG_USER_ONLY
44 include $(SRC_PATH)/tests/tcg/Makefile.include
45 endif
47 config-target.h: config-target.h-timestamp
48 config-target.h-timestamp: config-target.mak
50 ifdef CONFIG_TRACE_SYSTEMTAP
51 stap: $(QEMU_PROG).stp-installed $(QEMU_PROG).stp $(QEMU_PROG)-simpletrace.stp $(QEMU_PROG)-log.stp
53 ifdef CONFIG_USER_ONLY
54 TARGET_TYPE=user
55 else
56 TARGET_TYPE=system
57 endif
59 tracetool-y = $(SRC_PATH)/scripts/tracetool.py
60 tracetool-y += $(shell find $(SRC_PATH)/scripts/tracetool -name "*.py")
62 $(QEMU_PROG).stp-installed: $(BUILD_DIR)/trace-events-all $(tracetool-y)
63         $(call quiet-command,$(TRACETOOL) \
64                 --group=all \
65                 --format=stap \
66                 --backends=$(TRACE_BACKENDS) \
67                 --binary=$(bindir)/$(QEMU_PROG) \
68                 --target-name=$(TARGET_NAME) \
69                 --target-type=$(TARGET_TYPE) \
70                 $< > $@,"GEN","$(TARGET_DIR)$(QEMU_PROG).stp-installed")
72 $(QEMU_PROG).stp: $(BUILD_DIR)/trace-events-all $(tracetool-y)
73         $(call quiet-command,$(TRACETOOL) \
74                 --group=all \
75                 --format=stap \
76                 --backends=$(TRACE_BACKENDS) \
77                 --binary=$(realpath .)/$(QEMU_PROG) \
78                 --target-name=$(TARGET_NAME) \
79                 --target-type=$(TARGET_TYPE) \
80                 $< > $@,"GEN","$(TARGET_DIR)$(QEMU_PROG).stp")
82 $(QEMU_PROG)-simpletrace.stp: $(BUILD_DIR)/trace-events-all $(tracetool-y)
83         $(call quiet-command,$(TRACETOOL) \
84                 --group=all \
85                 --format=simpletrace-stap \
86                 --backends=$(TRACE_BACKENDS) \
87                 --probe-prefix=qemu.$(TARGET_TYPE).$(TARGET_NAME) \
88                 $< > $@,"GEN","$(TARGET_DIR)$(QEMU_PROG)-simpletrace.stp")
90 $(QEMU_PROG)-log.stp: $(BUILD_DIR)/trace-events-all $(tracetool-y)
91         $(call quiet-command,$(TRACETOOL) \
92                 --group=all \
93                 --format=log-stap \
94                 --backends=$(TRACE_BACKENDS) \
95                 --probe-prefix=qemu.$(TARGET_TYPE).$(TARGET_NAME) \
96                 $< > $@,"GEN","$(TARGET_DIR)$(QEMU_PROG)-log.stp")
98 else
99 stap:
100 endif
101 .PHONY: stap
103 all: $(PROGS) stap
105 # Dummy command so that make thinks it has done something
106         @true
108 obj-y += trace/
110 #########################################################
111 # cpu emulator library
112 obj-y += exec.o
113 obj-y += accel/
114 obj-$(CONFIG_TCG) += tcg/tcg.o tcg/tcg-op.o tcg/tcg-op-vec.o tcg/tcg-op-gvec.o
115 obj-$(CONFIG_TCG) += tcg/tcg-common.o tcg/optimize.o
116 obj-$(CONFIG_TCG_INTERPRETER) += tcg/tci.o
117 obj-$(CONFIG_TCG_INTERPRETER) += disas/tci.o
118 obj-$(CONFIG_TCG) += fpu/softfloat.o
119 obj-y += target/$(TARGET_BASE_ARCH)/
120 obj-y += disas.o
121 obj-$(call notempty,$(TARGET_XML_FILES)) += gdbstub-xml.o
123 #########################################################
124 # Linux user emulator target
126 ifdef CONFIG_LINUX_USER
128 QEMU_CFLAGS+=-I$(SRC_PATH)/linux-user/$(TARGET_ABI_DIR) \
129              -I$(SRC_PATH)/linux-user/host/$(ARCH) \
130              -I$(SRC_PATH)/linux-user
132 obj-y += linux-user/
133 obj-y += gdbstub.o thunk.o
135 endif #CONFIG_LINUX_USER
137 #########################################################
138 # BSD user emulator target
140 ifdef CONFIG_BSD_USER
142 QEMU_CFLAGS+=-I$(SRC_PATH)/bsd-user -I$(SRC_PATH)/bsd-user/$(TARGET_ABI_DIR) \
143                          -I$(SRC_PATH)/bsd-user/$(HOST_VARIANT_DIR)
145 obj-y += bsd-user/
146 obj-y += gdbstub.o
148 endif #CONFIG_BSD_USER
150 #########################################################
151 # System emulator target
152 ifdef CONFIG_SOFTMMU
153 obj-y += arch_init.o cpus.o monitor.o gdbstub.o balloon.o ioport.o numa.o
154 obj-y += qtest.o
155 obj-y += hw/
156 obj-y += qapi/
157 obj-y += memory.o
158 obj-y += memory_mapping.o
159 obj-y += dump.o
160 obj-$(TARGET_X86_64) += win_dump.o
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 += hmp-commands.h hmp-commands-info.h
173 endif # CONFIG_SOFTMMU
175 dummy := $(call unnest-vars,,obj-y)
176 all-obj-y := $(obj-y)
178 include $(SRC_PATH)/Makefile.objs
179 dummy := $(call unnest-vars,.., \
180                authz-obj-y \
181                block-obj-y \
182                block-obj-m \
183                chardev-obj-y \
184                crypto-obj-y \
185                crypto-aes-obj-y \
186                qom-obj-y \
187                io-obj-y \
188                common-obj-y \
189                common-obj-m)
190 all-obj-y += $(common-obj-y)
191 all-obj-y += $(qom-obj-y)
192 all-obj-$(CONFIG_SOFTMMU) += $(authz-obj-y)
193 all-obj-$(CONFIG_SOFTMMU) += $(block-obj-y) $(chardev-obj-y)
194 all-obj-$(CONFIG_USER_ONLY) += $(crypto-aes-obj-y)
195 all-obj-$(CONFIG_SOFTMMU) += $(crypto-obj-y)
196 all-obj-$(CONFIG_SOFTMMU) += $(io-obj-y)
198 ifdef CONFIG_SOFTMMU
199 $(QEMU_PROG_BUILD): config-devices.mak
200 endif
202 COMMON_LDADDS = ../libqemuutil.a
204 # build either PROG or PROGW
205 $(QEMU_PROG_BUILD): $(all-obj-y) $(COMMON_LDADDS)
206         $(call LINK, $(filter-out %.mak, $^))
207 ifdef CONFIG_DARWIN
208         $(call quiet-command,Rez -append $(SRC_PATH)/pc-bios/qemu.rsrc -o $@,"REZ","$(TARGET_DIR)$@")
209         $(call quiet-command,SetFile -a C $@,"SETFILE","$(TARGET_DIR)$@")
210 endif
212 gdbstub-xml.c: $(TARGET_XML_FILES) $(SRC_PATH)/scripts/feature_to_c.sh
213         $(call quiet-command,rm -f $@ && $(SHELL) $(SRC_PATH)/scripts/feature_to_c.sh $@ $(TARGET_XML_FILES),"GEN","$(TARGET_DIR)$@")
215 hmp-commands.h: $(SRC_PATH)/hmp-commands.hx $(SRC_PATH)/scripts/hxtool
216         $(call quiet-command,sh $(SRC_PATH)/scripts/hxtool -h < $< > $@,"GEN","$(TARGET_DIR)$@")
218 hmp-commands-info.h: $(SRC_PATH)/hmp-commands-info.hx $(SRC_PATH)/scripts/hxtool
219         $(call quiet-command,sh $(SRC_PATH)/scripts/hxtool -h < $< > $@,"GEN","$(TARGET_DIR)$@")
221 clean: clean-target
222         rm -f *.a *~ $(PROGS)
223         rm -f $(shell find . -name '*.[od]')
224         rm -f hmp-commands.h gdbstub-xml.c
225         rm -f trace/generated-helpers.c trace/generated-helpers.c-timestamp
226 ifdef CONFIG_TRACE_SYSTEMTAP
227         rm -f *.stp
228 endif
230 install: all
231 ifneq ($(PROGS),)
232         $(call install-prog,$(PROGS),$(DESTDIR)$(bindir))
233 endif
234 ifdef CONFIG_TRACE_SYSTEMTAP
235         $(INSTALL_DIR) "$(DESTDIR)$(qemu_datadir)/../systemtap/tapset"
236         $(INSTALL_DATA) $(QEMU_PROG).stp-installed "$(DESTDIR)$(qemu_datadir)/../systemtap/tapset/$(QEMU_PROG).stp"
237         $(INSTALL_DATA) $(QEMU_PROG)-simpletrace.stp "$(DESTDIR)$(qemu_datadir)/../systemtap/tapset/$(QEMU_PROG)-simpletrace.stp"
238         $(INSTALL_DATA) $(QEMU_PROG)-log.stp "$(DESTDIR)$(qemu_datadir)/../systemtap/tapset/$(QEMU_PROG)-log.stp"
239 endif
241 GENERATED_FILES += config-target.h
242 Makefile: $(GENERATED_FILES)