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