]>
Commit | Line | Data |
---|---|---|
1 | ####################################################################### | |
2 | # Common libraries for tools and emulators | |
3 | stub-obj-y = stubs/ | |
4 | util-obj-y = util/ qobject/ qapi/ trace/ | |
5 | ||
6 | ####################################################################### | |
7 | # block-obj-y is code used by both qemu system emulation and qemu-img | |
8 | ||
9 | block-obj-y = async.o thread-pool.o | |
10 | block-obj-y += nbd.o block.o blockjob.o | |
11 | block-obj-y += main-loop.o iohandler.o qemu-timer.o | |
12 | block-obj-$(CONFIG_POSIX) += aio-posix.o | |
13 | block-obj-$(CONFIG_WIN32) += aio-win32.o | |
14 | block-obj-y += block/ | |
15 | block-obj-y += qapi-types.o qapi-visit.o | |
16 | ||
17 | block-obj-y += qemu-coroutine.o qemu-coroutine-lock.o qemu-coroutine-io.o | |
18 | block-obj-y += qemu-coroutine-sleep.o | |
19 | ifeq ($(CONFIG_UCONTEXT_COROUTINE),y) | |
20 | block-obj-$(CONFIG_POSIX) += coroutine-ucontext.o | |
21 | else | |
22 | ifeq ($(CONFIG_SIGALTSTACK_COROUTINE),y) | |
23 | block-obj-$(CONFIG_POSIX) += coroutine-sigaltstack.o | |
24 | else | |
25 | block-obj-$(CONFIG_POSIX) += coroutine-gthread.o | |
26 | endif | |
27 | endif | |
28 | block-obj-$(CONFIG_WIN32) += coroutine-win32.o | |
29 | ||
30 | ifeq ($(CONFIG_VIRTIO)$(CONFIG_VIRTFS)$(CONFIG_PCI),yyy) | |
31 | # Lots of the fsdev/9pcode is pulled in by vl.c via qemu_fsdev_add. | |
32 | # only pull in the actual virtio-9p device if we also enabled virtio. | |
33 | CONFIG_REALLY_VIRTFS=y | |
34 | endif | |
35 | ||
36 | ###################################################################### | |
37 | # smartcard | |
38 | ||
39 | libcacard-y += libcacard/cac.o libcacard/event.o | |
40 | libcacard-y += libcacard/vcard.o libcacard/vreader.o | |
41 | libcacard-y += libcacard/vcard_emul_nss.o | |
42 | libcacard-y += libcacard/vcard_emul_type.o | |
43 | libcacard-y += libcacard/card_7816.o | |
44 | ||
45 | ###################################################################### | |
46 | # Target independent part of system emulation. The long term path is to | |
47 | # suppress *all* target specific code in case of system emulation, i.e. a | |
48 | # single QEMU executable should support all CPUs and machines. | |
49 | ||
50 | ifeq ($(CONFIG_SOFTMMU),y) | |
51 | common-obj-y = $(block-obj-y) blockdev.o blockdev-nbd.o block/ | |
52 | common-obj-y += net/ | |
53 | common-obj-y += readline.o | |
54 | common-obj-y += qdev-monitor.o device-hotplug.o | |
55 | common-obj-$(CONFIG_WIN32) += os-win32.o | |
56 | common-obj-$(CONFIG_POSIX) += os-posix.o | |
57 | ||
58 | common-obj-$(CONFIG_LINUX) += fsdev/ | |
59 | ||
60 | common-obj-y += migration.o migration-tcp.o | |
61 | common-obj-y += qemu-char.o #aio.o | |
62 | common-obj-y += block-migration.o | |
63 | common-obj-y += page_cache.o xbzrle.o | |
64 | ||
65 | common-obj-$(CONFIG_POSIX) += migration-exec.o migration-unix.o migration-fd.o | |
66 | ||
67 | common-obj-$(CONFIG_SPICE) += spice-qemu-char.o | |
68 | ||
69 | common-obj-y += audio/ | |
70 | common-obj-y += hw/ | |
71 | ||
72 | common-obj-y += ui/ | |
73 | common-obj-y += bt-host.o bt-vhci.o | |
74 | ||
75 | common-obj-y += dma-helpers.o | |
76 | common-obj-y += vl.o | |
77 | common-obj-y += tpm/ | |
78 | ||
79 | common-obj-$(CONFIG_SLIRP) += slirp/ | |
80 | ||
81 | common-obj-y += backends/ | |
82 | ||
83 | common-obj-$(CONFIG_SECCOMP) += qemu-seccomp.o | |
84 | ||
85 | common-obj-$(CONFIG_SMARTCARD_NSS) += $(libcacard-y) | |
86 | ||
87 | ###################################################################### | |
88 | # qapi | |
89 | ||
90 | common-obj-y += qmp-marshal.o qapi-visit.o qapi-types.o | |
91 | common-obj-y += qmp.o hmp.o | |
92 | endif | |
93 | ||
94 | ####################################################################### | |
95 | # Target-independent parts used in system and user emulation | |
96 | common-obj-y += qemu-log.o | |
97 | common-obj-y += tcg-runtime.o | |
98 | common-obj-y += hw/ | |
99 | common-obj-y += qom/ | |
100 | common-obj-y += disas/ | |
101 | ||
102 | ###################################################################### | |
103 | # guest agent | |
104 | ||
105 | # FIXME: a few definitions from qapi-types.o/qapi-visit.o are needed | |
106 | # by libqemuutil.a. These should be moved to a separate .json schema. | |
107 | qga-obj-y = qga/ qapi-types.o qapi-visit.o | |
108 | ||
109 | vl.o: QEMU_CFLAGS+=$(GPROF_CFLAGS) | |
110 | ||
111 | vl.o: QEMU_CFLAGS+=$(SDL_CFLAGS) | |
112 | ||
113 | QEMU_CFLAGS+=$(GLIB_CFLAGS) | |
114 | ||
115 | nested-vars += \ | |
116 | stub-obj-y \ | |
117 | util-obj-y \ | |
118 | qga-obj-y \ | |
119 | block-obj-y \ | |
120 | common-obj-y | |
121 | dummy := $(call unnest-vars) |