]>
Commit | Line | Data |
---|---|---|
1 | ####################################################################### | |
2 | # Target-independent parts used in system and user emulation | |
3 | universal-obj-y = | |
4 | universal-obj-y += qemu-log.o | |
5 | ||
6 | ####################################################################### | |
7 | # QObject | |
8 | qobject-obj-y = qint.o qstring.o qdict.o qlist.o qfloat.o qbool.o | |
9 | qobject-obj-y += qjson.o json-lexer.o json-streamer.o json-parser.o | |
10 | qobject-obj-y += qerror.o error.o qemu-error.o | |
11 | ||
12 | universal-obj-y += $(qobject-obj-y) | |
13 | ||
14 | ####################################################################### | |
15 | # QOM | |
16 | qom-obj-y = qom/ | |
17 | ||
18 | universal-obj-y += $(qom-obj-y) | |
19 | ||
20 | ####################################################################### | |
21 | # oslib-obj-y is code depending on the OS (win32 vs posix) | |
22 | oslib-obj-y = osdep.o | |
23 | oslib-obj-$(CONFIG_WIN32) += oslib-win32.o qemu-thread-win32.o | |
24 | oslib-obj-$(CONFIG_POSIX) += oslib-posix.o qemu-thread-posix.o | |
25 | ||
26 | ####################################################################### | |
27 | # coroutines | |
28 | coroutine-obj-y = qemu-coroutine.o qemu-coroutine-lock.o qemu-coroutine-io.o | |
29 | coroutine-obj-y += qemu-coroutine-sleep.o | |
30 | ifeq ($(CONFIG_UCONTEXT_COROUTINE),y) | |
31 | coroutine-obj-$(CONFIG_POSIX) += coroutine-ucontext.o | |
32 | else | |
33 | ifeq ($(CONFIG_SIGALTSTACK_COROUTINE),y) | |
34 | coroutine-obj-$(CONFIG_POSIX) += coroutine-sigaltstack.o | |
35 | else | |
36 | coroutine-obj-$(CONFIG_POSIX) += coroutine-gthread.o | |
37 | endif | |
38 | endif | |
39 | coroutine-obj-$(CONFIG_WIN32) += coroutine-win32.o | |
40 | ||
41 | ####################################################################### | |
42 | # block-obj-y is code used by both qemu system emulation and qemu-img | |
43 | ||
44 | block-obj-y = cutils.o iov.o cache-utils.o qemu-option.o module.o async.o | |
45 | block-obj-y += nbd.o block.o aio.o aes.o qemu-config.o qemu-progress.o qemu-sockets.o | |
46 | block-obj-y += $(coroutine-obj-y) $(qobject-obj-y) $(version-obj-y) | |
47 | block-obj-$(CONFIG_POSIX) += posix-aio-compat.o | |
48 | block-obj-$(CONFIG_LINUX_AIO) += linux-aio.o | |
49 | block-obj-y += block/ | |
50 | ||
51 | ifeq ($(CONFIG_VIRTIO)$(CONFIG_VIRTFS)$(CONFIG_PCI),yyy) | |
52 | # Lots of the fsdev/9pcode is pulled in by vl.c via qemu_fsdev_add. | |
53 | # only pull in the actual virtio-9p device if we also enabled virtio. | |
54 | CONFIG_REALLY_VIRTFS=y | |
55 | endif | |
56 | ||
57 | ###################################################################### | |
58 | # Target independent part of system emulation. The long term path is to | |
59 | # suppress *all* target specific code in case of system emulation, i.e. a | |
60 | # single QEMU executable should support all CPUs and machines. | |
61 | ||
62 | common-obj-y = $(block-obj-y) blockdev.o | |
63 | common-obj-y += net.o net/ | |
64 | common-obj-y += qom/ | |
65 | common-obj-y += readline.o console.o cursor.o | |
66 | common-obj-y += $(oslib-obj-y) | |
67 | common-obj-$(CONFIG_WIN32) += os-win32.o | |
68 | common-obj-$(CONFIG_POSIX) += os-posix.o | |
69 | ||
70 | common-obj-$(CONFIG_LINUX) += fsdev/ | |
71 | extra-obj-$(CONFIG_LINUX) += fsdev/ | |
72 | ||
73 | common-obj-y += tcg-runtime.o host-utils.o main-loop.o | |
74 | common-obj-y += input.o | |
75 | common-obj-y += buffered_file.o migration.o migration-tcp.o | |
76 | common-obj-y += qemu-char.o #aio.o | |
77 | common-obj-y += block-migration.o iohandler.o | |
78 | common-obj-y += pflib.o | |
79 | common-obj-y += bitmap.o bitops.o | |
80 | common-obj-y += page_cache.o | |
81 | ||
82 | common-obj-$(CONFIG_POSIX) += migration-exec.o migration-unix.o migration-fd.o | |
83 | common-obj-$(CONFIG_WIN32) += version.o | |
84 | ||
85 | common-obj-$(CONFIG_SPICE) += spice-qemu-char.o | |
86 | ||
87 | common-obj-y += audio/ | |
88 | common-obj-y += hw/ | |
89 | common-obj-y += ui/ | |
90 | common-obj-y += bt-host.o bt-vhci.o | |
91 | ||
92 | common-obj-y += iov.o acl.o | |
93 | common-obj-$(CONFIG_POSIX) += compatfd.o | |
94 | common-obj-y += notify.o event_notifier.o | |
95 | common-obj-y += qemu-timer.o qemu-timer-common.o | |
96 | ||
97 | common-obj-$(CONFIG_SLIRP) += slirp/ | |
98 | ||
99 | ###################################################################### | |
100 | # libuser | |
101 | ||
102 | user-obj-y = | |
103 | user-obj-y += envlist.o path.o | |
104 | user-obj-y += tcg-runtime.o host-utils.o | |
105 | user-obj-y += cutils.o iov.o cache-utils.o | |
106 | user-obj-y += module.o | |
107 | user-obj-y += qemu-user.o | |
108 | user-obj-y += $(trace-obj-y) | |
109 | user-obj-y += qom/ | |
110 | ||
111 | ###################################################################### | |
112 | # libhw | |
113 | ||
114 | hw-obj-y = vl.o dma-helpers.o qtest.o hw/ | |
115 | ||
116 | ###################################################################### | |
117 | # libdis | |
118 | # NOTE: the disassembler code is only needed for debugging | |
119 | ||
120 | libdis-y = | |
121 | libdis-$(CONFIG_ALPHA_DIS) += alpha-dis.o | |
122 | libdis-$(CONFIG_ARM_DIS) += arm-dis.o | |
123 | libdis-$(CONFIG_CRIS_DIS) += cris-dis.o | |
124 | libdis-$(CONFIG_HPPA_DIS) += hppa-dis.o | |
125 | libdis-$(CONFIG_I386_DIS) += i386-dis.o | |
126 | libdis-$(CONFIG_IA64_DIS) += ia64-dis.o | |
127 | libdis-$(CONFIG_M68K_DIS) += m68k-dis.o | |
128 | libdis-$(CONFIG_MICROBLAZE_DIS) += microblaze-dis.o | |
129 | libdis-$(CONFIG_MIPS_DIS) += mips-dis.o | |
130 | libdis-$(CONFIG_PPC_DIS) += ppc-dis.o | |
131 | libdis-$(CONFIG_S390_DIS) += s390-dis.o | |
132 | libdis-$(CONFIG_SH4_DIS) += sh4-dis.o | |
133 | libdis-$(CONFIG_SPARC_DIS) += sparc-dis.o | |
134 | libdis-$(CONFIG_LM32_DIS) += lm32-dis.o | |
135 | ||
136 | ###################################################################### | |
137 | # trace | |
138 | ||
139 | ifeq ($(TRACE_BACKEND),dtrace) | |
140 | TRACE_H_EXTRA_DEPS=trace-dtrace.h | |
141 | endif | |
142 | trace.h: trace.h-timestamp $(TRACE_H_EXTRA_DEPS) | |
143 | trace.h-timestamp: $(SRC_PATH)/trace-events $(BUILD_DIR)/config-host.mak | |
144 | $(call quiet-command,$(TRACETOOL) \ | |
145 | --format=h \ | |
146 | --backend=$(TRACE_BACKEND) \ | |
147 | < $< > $@," GEN trace.h") | |
148 | @cmp -s $@ trace.h || cp $@ trace.h | |
149 | ||
150 | trace.c: trace.c-timestamp | |
151 | trace.c-timestamp: $(SRC_PATH)/trace-events $(BUILD_DIR)/config-host.mak | |
152 | $(call quiet-command,$(TRACETOOL) \ | |
153 | --format=c \ | |
154 | --backend=$(TRACE_BACKEND) \ | |
155 | < $< > $@," GEN trace.c") | |
156 | @cmp -s $@ trace.c || cp $@ trace.c | |
157 | ||
158 | trace.o: trace.c $(GENERATED_HEADERS) | |
159 | ||
160 | trace-dtrace.h: trace-dtrace.dtrace | |
161 | $(call quiet-command,dtrace -o $@ -h -s $<, " GEN trace-dtrace.h") | |
162 | ||
163 | # Normal practice is to name DTrace probe file with a '.d' extension | |
164 | # but that gets picked up by QEMU's Makefile as an external dependency | |
165 | # rule file. So we use '.dtrace' instead | |
166 | trace-dtrace.dtrace: trace-dtrace.dtrace-timestamp | |
167 | trace-dtrace.dtrace-timestamp: $(SRC_PATH)/trace-events $(BUILD_DIR)/config-host.mak | |
168 | $(call quiet-command,$(TRACETOOL) \ | |
169 | --format=d \ | |
170 | --backend=$(TRACE_BACKEND) \ | |
171 | < $< > $@," GEN trace-dtrace.dtrace") | |
172 | @cmp -s $@ trace-dtrace.dtrace || cp $@ trace-dtrace.dtrace | |
173 | ||
174 | trace-dtrace.o: trace-dtrace.dtrace $(GENERATED_HEADERS) | |
175 | $(call quiet-command,dtrace -o $@ -G -s $<, " GEN trace-dtrace.o") | |
176 | ||
177 | ifeq ($(LIBTOOL),) | |
178 | trace-dtrace.lo: trace-dtrace.dtrace | |
179 | @echo "missing libtool. please install and rerun configure."; exit 1 | |
180 | else | |
181 | trace-dtrace.lo: trace-dtrace.dtrace | |
182 | $(call quiet-command,$(LIBTOOL) --mode=compile --tag=CC dtrace -o $@ -G -s $<, " lt GEN trace-dtrace.o") | |
183 | endif | |
184 | ||
185 | trace/simple.o: trace/simple.c $(GENERATED_HEADERS) | |
186 | ||
187 | trace-obj-$(CONFIG_TRACE_DTRACE) += trace-dtrace.o | |
188 | ifneq ($(TRACE_BACKEND),dtrace) | |
189 | trace-obj-y = trace.o | |
190 | endif | |
191 | ||
192 | trace-obj-$(CONFIG_TRACE_DEFAULT) += trace/default.o | |
193 | trace-obj-$(CONFIG_TRACE_SIMPLE) += trace/simple.o | |
194 | trace-obj-$(CONFIG_TRACE_SIMPLE) += qemu-timer-common.o | |
195 | trace-obj-$(CONFIG_TRACE_STDERR) += trace/stderr.o | |
196 | trace-obj-y += trace/control.o | |
197 | ||
198 | $(trace-obj-y): $(GENERATED_HEADERS) | |
199 | ||
200 | ###################################################################### | |
201 | # smartcard | |
202 | ||
203 | libcacard-y += libcacard/cac.o libcacard/event.o | |
204 | libcacard-y += libcacard/vcard.o libcacard/vreader.o | |
205 | libcacard-y += libcacard/vcard_emul_nss.o | |
206 | libcacard-y += libcacard/vcard_emul_type.o | |
207 | libcacard-y += libcacard/card_7816.o | |
208 | ||
209 | common-obj-$(CONFIG_SMARTCARD_NSS) += $(libcacard-y) | |
210 | ||
211 | ###################################################################### | |
212 | # qapi | |
213 | ||
214 | qapi-obj-y = qapi/ | |
215 | ||
216 | common-obj-y += qmp-marshal.o qapi-visit.o qapi-types.o | |
217 | common-obj-y += qmp.o hmp.o | |
218 | ||
219 | universal-obj-y += $(qapi-obj-y) | |
220 | ||
221 | ###################################################################### | |
222 | # guest agent | |
223 | ||
224 | qga-obj-y = qga/ qemu-ga.o module.o | |
225 | qga-obj-$(CONFIG_WIN32) += oslib-win32.o | |
226 | qga-obj-$(CONFIG_POSIX) += oslib-posix.o qemu-sockets.o qemu-option.o | |
227 | ||
228 | vl.o: QEMU_CFLAGS+=$(GPROF_CFLAGS) | |
229 | ||
230 | vl.o: QEMU_CFLAGS+=$(SDL_CFLAGS) | |
231 | ||
232 | QEMU_CFLAGS+=$(GLIB_CFLAGS) | |
233 | ||
234 | nested-vars += \ | |
235 | hw-obj-y \ | |
236 | qga-obj-y \ | |
237 | block-obj-y \ | |
238 | qom-obj-y \ | |
239 | qapi-obj-y \ | |
240 | user-obj-y \ | |
241 | common-obj-y \ | |
242 | extra-obj-y | |
243 | dummy := $(call unnest-vars) |