xref: /freebsd/sys/modules/vmm/Makefile (revision ed85203fb7a0334041db6da07e45ddda4caef13d)
1.include <kmod.opts.mk>
2
3KMOD=	vmm
4
5.if ${MACHINE_CPUARCH} == "amd64"
6.endif
7
8SRCS+=	acpi_if.h bus_if.h device_if.h pci_if.h pcib_if.h vnode_if.h
9
10CFLAGS+= -DVMM_KEEP_STATS
11CFLAGS+= -I${SRCTOP}/sys/${MACHINE}/vmm
12
13# generic vmm support
14.PATH: ${SRCTOP}/sys/dev/vmm ${SRCTOP}/sys/${MACHINE}/vmm
15
16SRCS+=	vmm.c			\
17	vmm_dev.c		\
18	vmm_dev_machdep.c	\
19	vmm_instruction_emul.c	\
20	vmm_mem.c		\
21	vmm_stat.c		\
22	vmm_vm.c
23
24.if ${MACHINE_CPUARCH} == "aarch64"
25CFLAGS+= -I${SRCTOP}/sys/${MACHINE}/vmm/io
26DPSRCS+=	assym.inc
27
28# TODO: Add the new EL2 code
29SRCS+=	vmm_arm64.c \
30	vmm_reset.c \
31	vmm_call.S \
32	vmm_handlers.c \
33	vmm_mmu.c \
34	vmm_vhe_exception.S \
35	vmm_vhe.c \
36	vmm_hyp_el2.S
37
38.PATH: ${SRCTOP}/sys/${MACHINE}/vmm/io
39SRCS+=	vgic.c \
40	vgic_if.h \
41	vgic_if.c \
42	vgic_v3.c \
43	vtimer.c
44
45CLEANFILES+=	vmm_nvhe_exception.o vmm_nvhe.o
46
47CLEANFILES+=	vmm_hyp_blob.elf.full
48CLEANFILES+=	vmm_hyp_blob.elf vmm_hyp_blob.bin
49
50vmm_nvhe_exception.o: vmm_nvhe_exception.S vmm_hyp_exception.S
51	${CC} -c -x assembler-with-cpp -DLOCORE \
52	    ${NOSAN_CFLAGS:N-mbranch-protection*} ${.IMPSRC} -o ${.TARGET} -fpie
53
54vmm_nvhe.o: vmm_nvhe.c vmm_hyp.c
55	${CC} -c ${NOSAN_CFLAGS:N-mbranch-protection*} ${.IMPSRC} \
56	    -o ${.TARGET} -fpie
57
58vmm_hyp_blob.elf.full:	vmm_nvhe_exception.o vmm_nvhe.o
59	${LD} -m ${LD_EMULATION} -Bdynamic -L ${SYSDIR}/conf -T ${SYSDIR}/conf/ldscript.arm64 \
60	    ${_LDFLAGS:N-zbti-report*} --no-warn-mismatch --warn-common --export-dynamic \
61	    --dynamic-linker /red/herring -X -o ${.TARGET} ${.ALLSRC} \
62	    --defsym=_start='0x0' --defsym=text_start='0x0'
63
64vmm_hyp_blob.elf:	vmm_hyp_blob.elf.full
65	${OBJCOPY} --strip-debug ${.ALLSRC} ${.TARGET}
66
67vmm_hyp_blob.bin:	vmm_hyp_blob.elf
68	${OBJCOPY} --output-target=binary ${.ALLSRC} ${.TARGET}
69
70vmm_hyp_el2.o:	vmm_hyp_blob.bin
71
72.elif ${MACHINE_CPUARCH} == "amd64"
73CFLAGS+= -I${SRCTOP}/sys/${MACHINE}/vmm/io
74DPSRCS+=	vmx_assym.h svm_assym.h
75DPSRCS+=	vmx_genassym.c svm_genassym.c offset.inc
76
77CFLAGS+= -I${SRCTOP}/sys/amd64/vmm/intel
78CFLAGS+= -I${SRCTOP}/sys/amd64/vmm/amd
79
80SRCS+=	opt_acpi.h		\
81	opt_bhyve_snapshot.h	\
82	opt_ddb.h
83
84SRCS+=	vmm_host.c	\
85	vmm_ioport.c	\
86	vmm_lapic.c	\
87	vmm_mem_machdep.c \
88	vmm_util.c	\
89	x86.c
90
91.PATH: ${SRCTOP}/sys/${MACHINE}/vmm/io
92SRCS+=	iommu.c		\
93	ppt.c           \
94	vatpic.c	\
95	vatpit.c	\
96	vhpet.c		\
97	vioapic.c	\
98	vlapic.c	\
99	vpmtmr.c	\
100	vrtc.c
101
102# intel-specific files
103.PATH: ${SRCTOP}/sys/amd64/vmm/intel
104SRCS+=	ept.c		\
105	vmcs.c		\
106	vmx_msr.c	\
107	vmx_support.S	\
108	vmx.c		\
109	vtd.c
110
111# amd-specific files
112.PATH: ${SRCTOP}/sys/amd64/vmm/amd
113SRCS+=	vmcb.c		\
114	amdviiommu.c	\
115	ivhd_if.c	\
116	ivhd_if.h	\
117	svm.c		\
118	svm_support.S	\
119	npt.c		\
120	ivrs_drv.c	\
121	amdvi_hw.c	\
122	svm_msr.c
123
124SRCS.BHYVE_SNAPSHOT=	vmm_snapshot.c
125
126CLEANFILES+=	vmx_assym.h vmx_genassym.o svm_assym.h svm_genassym.o
127
128OBJS_DEPEND_GUESS.vmx_support.o+= vmx_assym.h
129OBJS_DEPEND_GUESS.svm_support.o+= svm_assym.h
130
131vmx_assym.h:    vmx_genassym.o
132	sh ${SYSDIR}/kern/genassym.sh vmx_genassym.o > ${.TARGET}
133
134svm_assym.h:    svm_genassym.o
135	sh ${SYSDIR}/kern/genassym.sh svm_genassym.o > ${.TARGET}
136
137vmx_support.o:
138	${CC} -c -x assembler-with-cpp -DLOCORE ${CFLAGS} \
139	    ${.IMPSRC} -o ${.TARGET}
140
141svm_support.o:
142	${CC} -c -x assembler-with-cpp -DLOCORE ${CFLAGS} \
143	    ${.IMPSRC} -o ${.TARGET}
144
145hyp_genassym.o: offset.inc
146	${CC} -c ${NOSAN_CFLAGS:N-flto*:N-fno-common} -fcommon ${.IMPSRC}
147
148vmx_genassym.o: offset.inc
149	${CC} -c ${NOSAN_CFLAGS:N-flto*:N-fno-common} -fcommon ${.IMPSRC}
150
151svm_genassym.o: offset.inc
152	${CC} -c ${NOSAN_CFLAGS:N-flto*:N-fno-common} -fcommon ${.IMPSRC}
153
154.elif ${MACHINE_CPUARCH} == "riscv"
155
156SRCS+=	vmm_aplic.c	\
157	vmm_fence.c	\
158	vmm_riscv.c	\
159	vmm_sbi.c	\
160	vmm_switch.S	\
161	vmm_vtimer.c
162
163.endif
164
165.include <bsd.kmod.mk>
166