]>
Commit | Line | Data |
---|---|---|
3bc2f570 | 1 | ####################################################################### |
a372823a | 2 | # Common libraries for tools and emulators |
3bc2f570 | 3 | stub-obj-y = stubs/ |
ff667e2e | 4 | util-obj-y = util/ qobject/ qapi/ trace/ |
3bc2f570 | 5 | |
0e8c9214 AF |
6 | ####################################################################### |
7 | # block-obj-y is code used by both qemu system emulation and qemu-img | |
8 | ||
f157ebba PB |
9 | block-obj-y = async.o thread-pool.o |
10 | block-obj-y += nbd.o block.o blockjob.o | |
f157ebba PB |
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 | |
7456e4ce | 14 | block-obj-y += block/ |
576d5506 | 15 | block-obj-y += qapi-types.o qapi-visit.o |
0e8c9214 | 16 | |
84ecb7a6 PB |
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 | ||
9fe1ebeb | 30 | ifeq ($(CONFIG_VIRTIO)$(CONFIG_VIRTFS)$(CONFIG_PCI),yyy) |
01af7daf PB |
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 | |
74db920c | 35 | |
0e8c9214 | 36 | ###################################################################### |
050d9940 CWR |
37 | # Target independent part of system emulation. The long term path is to |
38 | # suppress *all* target specific code in case of system emulation, i.e. a | |
39 | # single QEMU executable should support all CPUs and machines. | |
0e8c9214 | 40 | |
6dd844db | 41 | common-obj-y = $(block-obj-y) blockdev.o blockdev-nbd.o block/ |
fd9400b3 | 42 | common-obj-y += net/ |
28ecbaee | 43 | common-obj-y += readline.o |
b0cb640a BS |
44 | common-obj-$(CONFIG_WIN32) += os-win32.o |
45 | common-obj-$(CONFIG_POSIX) += os-posix.o | |
254e5950 | 46 | |
ee20477d PB |
47 | common-obj-$(CONFIG_LINUX) += fsdev/ |
48 | extra-obj-$(CONFIG_LINUX) += fsdev/ | |
49 | ||
0d82d0e8 | 50 | common-obj-y += migration.o migration-tcp.o |
c5705a77 | 51 | common-obj-y += qemu-char.o #aio.o |
f157ebba | 52 | common-obj-y += block-migration.o |
9fb26641 | 53 | common-obj-y += page_cache.o |
0e8c9214 | 54 | |
0e8c9214 AF |
55 | common-obj-$(CONFIG_POSIX) += migration-exec.o migration-unix.o migration-fd.o |
56 | ||
8867aef0 | 57 | common-obj-$(CONFIG_SPICE) += spice-qemu-char.o |
b0b68fc6 PB |
58 | |
59 | common-obj-y += audio/ | |
3d5a3f9a | 60 | common-obj-y += hw/ |
6f991980 PB |
61 | extra-obj-y += hw/ |
62 | ||
8867aef0 | 63 | common-obj-y += ui/ |
3d5a3f9a | 64 | common-obj-y += bt-host.o bt-vhci.o |
3e230dd2 | 65 | |
c9159fe9 | 66 | common-obj-y += dma-helpers.o |
c9159fe9 SW |
67 | common-obj-y += qtest.o |
68 | common-obj-y += vl.o | |
0e8c9214 | 69 | |
4c696054 | 70 | common-obj-$(CONFIG_SLIRP) += slirp/ |
0e8c9214 | 71 | |
a9b7b2ad AL |
72 | common-obj-y += backends/ |
73 | ||
f794573e EO |
74 | ###################################################################### |
75 | # libseccomp | |
76 | ifeq ($(CONFIG_SECCOMP),y) | |
77 | common-obj-y += qemu-seccomp.o | |
78 | endif | |
79 | ||
111a38b0 RR |
80 | ###################################################################### |
81 | # smartcard | |
82 | ||
00c705fb PB |
83 | libcacard-y += libcacard/cac.o libcacard/event.o |
84 | libcacard-y += libcacard/vcard.o libcacard/vreader.o | |
85 | libcacard-y += libcacard/vcard_emul_nss.o | |
86 | libcacard-y += libcacard/vcard_emul_type.o | |
87 | libcacard-y += libcacard/card_7816.o | |
88 | ||
89 | common-obj-$(CONFIG_SMARTCARD_NSS) += $(libcacard-y) | |
111a38b0 | 90 | |
2345c77c MR |
91 | ###################################################################### |
92 | # qapi | |
93 | ||
ce008c1f | 94 | common-obj-y += qmp-marshal.o qapi-visit.o qapi-types.o |
48a32bed | 95 | common-obj-y += qmp.o hmp.o |
e3193601 | 96 | |
9444e9e6 PB |
97 | ####################################################################### |
98 | # Target-independent parts used in system and user emulation | |
99 | universal-obj-y = | |
100 | universal-obj-y += qemu-log.o | |
101 | universal-obj-y += tcg-runtime.o | |
102 | universal-obj-y += hw/ | |
103 | universal-obj-y += qom/ | |
104 | universal-obj-y += disas/ | |
ce008c1f | 105 | |
957f1f99 MR |
106 | ###################################################################### |
107 | # guest agent | |
108 | ||
59cacde8 PB |
109 | # FIXME: a few definitions from qapi-types.o/qapi-visit.o are needed |
110 | # by libqemuutil.a. These should be moved to a separate .json schema. | |
111 | qga-obj-y = qga/ qapi-types.o qapi-visit.o | |
957f1f99 | 112 | |
ad96090a BS |
113 | vl.o: QEMU_CFLAGS+=$(GPROF_CFLAGS) |
114 | ||
115 | vl.o: QEMU_CFLAGS+=$(SDL_CFLAGS) | |
116 | ||
14015304 AL |
117 | QEMU_CFLAGS+=$(GLIB_CFLAGS) |
118 | ||
7f07b9cb | 119 | nested-vars += \ |
3bc2f570 | 120 | stub-obj-y \ |
baacf047 | 121 | util-obj-y \ |
4eb7ba8a | 122 | qga-obj-y \ |
69758c22 | 123 | block-obj-y \ |
ee20477d | 124 | common-obj-y \ |
76cad711 | 125 | universal-obj-y \ |
ff667e2e | 126 | extra-obj-y |
99100dc3 | 127 | dummy := $(call unnest-vars) |