Makefile 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257
  1. # SPDX-License-Identifier: GPL-2.0-only
  2. include ../../../build/Build.include
  3. all:
  4. top_srcdir = ../../../..
  5. include $(top_srcdir)/scripts/subarch.include
  6. ARCH ?= $(SUBARCH)
  7. # For cross-builds to work, UNAME_M has to map to ARCH and arch specific
  8. # directories and targets in this Makefile. "uname -m" doesn't map to
  9. # arch specific sub-directory names.
  10. #
  11. # UNAME_M variable to used to run the compiles pointing to the right arch
  12. # directories and build the right targets for these supported architectures.
  13. #
  14. # TEST_GEN_PROGS and LIBKVM are set using UNAME_M variable.
  15. # LINUX_TOOL_ARCH_INCLUDE is set using ARCH variable.
  16. #
  17. # x86_64 targets are named to include x86_64 as a suffix and directories
  18. # for includes are in x86_64 sub-directory. s390x and aarch64 follow the
  19. # same convention. "uname -m" doesn't result in the correct mapping for
  20. # s390x and aarch64.
  21. #
  22. # No change necessary for x86_64
  23. UNAME_M := $(shell uname -m)
  24. # Set UNAME_M for arm64 compile/install to work
  25. ifeq ($(ARCH),arm64)
  26. UNAME_M := aarch64
  27. endif
  28. # Set UNAME_M s390x compile/install to work
  29. ifeq ($(ARCH),s390)
  30. UNAME_M := s390x
  31. endif
  32. # Set UNAME_M riscv compile/install to work
  33. ifeq ($(ARCH),riscv)
  34. UNAME_M := riscv
  35. endif
  36. LIBKVM += lib/assert.c
  37. LIBKVM += lib/elf.c
  38. LIBKVM += lib/guest_modes.c
  39. LIBKVM += lib/io.c
  40. LIBKVM += lib/kvm_util.c
  41. LIBKVM += lib/perf_test_util.c
  42. LIBKVM += lib/rbtree.c
  43. LIBKVM += lib/sparsebit.c
  44. LIBKVM += lib/test_util.c
  45. LIBKVM_STRING += lib/string_override.c
  46. LIBKVM_x86_64 += lib/x86_64/apic.c
  47. LIBKVM_x86_64 += lib/x86_64/handlers.S
  48. LIBKVM_x86_64 += lib/x86_64/perf_test_util.c
  49. LIBKVM_x86_64 += lib/x86_64/processor.c
  50. LIBKVM_x86_64 += lib/x86_64/svm.c
  51. LIBKVM_x86_64 += lib/x86_64/ucall.c
  52. LIBKVM_x86_64 += lib/x86_64/vmx.c
  53. LIBKVM_aarch64 += lib/aarch64/gic.c
  54. LIBKVM_aarch64 += lib/aarch64/gic_v3.c
  55. LIBKVM_aarch64 += lib/aarch64/handlers.S
  56. LIBKVM_aarch64 += lib/aarch64/processor.c
  57. LIBKVM_aarch64 += lib/aarch64/spinlock.c
  58. LIBKVM_aarch64 += lib/aarch64/ucall.c
  59. LIBKVM_aarch64 += lib/aarch64/vgic.c
  60. LIBKVM_s390x += lib/s390x/diag318_test_handler.c
  61. LIBKVM_s390x += lib/s390x/processor.c
  62. LIBKVM_s390x += lib/s390x/ucall.c
  63. LIBKVM_riscv += lib/riscv/processor.c
  64. LIBKVM_riscv += lib/riscv/ucall.c
  65. # Non-compiled test targets
  66. TEST_PROGS_x86_64 += x86_64/nx_huge_pages_test.sh
  67. # Compiled test targets
  68. TEST_GEN_PROGS_x86_64 = x86_64/cpuid_test
  69. TEST_GEN_PROGS_x86_64 += x86_64/cr4_cpuid_sync_test
  70. TEST_GEN_PROGS_x86_64 += x86_64/get_msr_index_features
  71. TEST_GEN_PROGS_x86_64 += x86_64/evmcs_test
  72. TEST_GEN_PROGS_x86_64 += x86_64/emulator_error_test
  73. TEST_GEN_PROGS_x86_64 += x86_64/fix_hypercall_test
  74. TEST_GEN_PROGS_x86_64 += x86_64/hyperv_clock
  75. TEST_GEN_PROGS_x86_64 += x86_64/hyperv_cpuid
  76. TEST_GEN_PROGS_x86_64 += x86_64/hyperv_features
  77. TEST_GEN_PROGS_x86_64 += x86_64/hyperv_svm_test
  78. TEST_GEN_PROGS_x86_64 += x86_64/kvm_clock_test
  79. TEST_GEN_PROGS_x86_64 += x86_64/kvm_pv_test
  80. TEST_GEN_PROGS_x86_64 += x86_64/mmio_warning_test
  81. TEST_GEN_PROGS_x86_64 += x86_64/monitor_mwait_test
  82. TEST_GEN_PROGS_x86_64 += x86_64/nested_exceptions_test
  83. TEST_GEN_PROGS_x86_64 += x86_64/platform_info_test
  84. TEST_GEN_PROGS_x86_64 += x86_64/pmu_event_filter_test
  85. TEST_GEN_PROGS_x86_64 += x86_64/set_boot_cpu_id
  86. TEST_GEN_PROGS_x86_64 += x86_64/set_sregs_test
  87. TEST_GEN_PROGS_x86_64 += x86_64/smm_test
  88. TEST_GEN_PROGS_x86_64 += x86_64/state_test
  89. TEST_GEN_PROGS_x86_64 += x86_64/vmx_preemption_timer_test
  90. TEST_GEN_PROGS_x86_64 += x86_64/svm_vmcall_test
  91. TEST_GEN_PROGS_x86_64 += x86_64/svm_int_ctl_test
  92. TEST_GEN_PROGS_x86_64 += x86_64/svm_nested_shutdown_test
  93. TEST_GEN_PROGS_x86_64 += x86_64/svm_nested_soft_inject_test
  94. TEST_GEN_PROGS_x86_64 += x86_64/tsc_scaling_sync
  95. TEST_GEN_PROGS_x86_64 += x86_64/sync_regs_test
  96. TEST_GEN_PROGS_x86_64 += x86_64/ucna_injection_test
  97. TEST_GEN_PROGS_x86_64 += x86_64/userspace_io_test
  98. TEST_GEN_PROGS_x86_64 += x86_64/userspace_msr_exit_test
  99. TEST_GEN_PROGS_x86_64 += x86_64/vmx_apic_access_test
  100. TEST_GEN_PROGS_x86_64 += x86_64/vmx_close_while_nested_test
  101. TEST_GEN_PROGS_x86_64 += x86_64/vmx_dirty_log_test
  102. TEST_GEN_PROGS_x86_64 += x86_64/vmx_exception_with_invalid_guest_state
  103. TEST_GEN_PROGS_x86_64 += x86_64/vmx_msrs_test
  104. TEST_GEN_PROGS_x86_64 += x86_64/vmx_invalid_nested_guest_state
  105. TEST_GEN_PROGS_x86_64 += x86_64/vmx_set_nested_state_test
  106. TEST_GEN_PROGS_x86_64 += x86_64/vmx_tsc_adjust_test
  107. TEST_GEN_PROGS_x86_64 += x86_64/vmx_nested_tsc_scaling_test
  108. TEST_GEN_PROGS_x86_64 += x86_64/xapic_ipi_test
  109. TEST_GEN_PROGS_x86_64 += x86_64/xapic_state_test
  110. TEST_GEN_PROGS_x86_64 += x86_64/xss_msr_test
  111. TEST_GEN_PROGS_x86_64 += x86_64/debug_regs
  112. TEST_GEN_PROGS_x86_64 += x86_64/tsc_msrs_test
  113. TEST_GEN_PROGS_x86_64 += x86_64/vmx_pmu_caps_test
  114. TEST_GEN_PROGS_x86_64 += x86_64/xen_shinfo_test
  115. TEST_GEN_PROGS_x86_64 += x86_64/xen_vmcall_test
  116. TEST_GEN_PROGS_x86_64 += x86_64/sev_migrate_tests
  117. TEST_GEN_PROGS_x86_64 += x86_64/amx_test
  118. TEST_GEN_PROGS_x86_64 += x86_64/max_vcpuid_cap_test
  119. TEST_GEN_PROGS_x86_64 += x86_64/triple_fault_event_test
  120. TEST_GEN_PROGS_x86_64 += access_tracking_perf_test
  121. TEST_GEN_PROGS_x86_64 += demand_paging_test
  122. TEST_GEN_PROGS_x86_64 += dirty_log_test
  123. TEST_GEN_PROGS_x86_64 += dirty_log_perf_test
  124. TEST_GEN_PROGS_x86_64 += hardware_disable_test
  125. TEST_GEN_PROGS_x86_64 += kvm_create_max_vcpus
  126. TEST_GEN_PROGS_x86_64 += kvm_page_table_test
  127. TEST_GEN_PROGS_x86_64 += max_guest_memory_test
  128. TEST_GEN_PROGS_x86_64 += memslot_modification_stress_test
  129. TEST_GEN_PROGS_x86_64 += memslot_perf_test
  130. TEST_GEN_PROGS_x86_64 += rseq_test
  131. TEST_GEN_PROGS_x86_64 += set_memory_region_test
  132. TEST_GEN_PROGS_x86_64 += steal_time
  133. TEST_GEN_PROGS_x86_64 += kvm_binary_stats_test
  134. TEST_GEN_PROGS_x86_64 += system_counter_offset_test
  135. # Compiled outputs used by test targets
  136. TEST_GEN_PROGS_EXTENDED_x86_64 += x86_64/nx_huge_pages_test
  137. TEST_GEN_PROGS_aarch64 += aarch64/aarch32_id_regs
  138. TEST_GEN_PROGS_aarch64 += aarch64/arch_timer
  139. TEST_GEN_PROGS_aarch64 += aarch64/debug-exceptions
  140. TEST_GEN_PROGS_aarch64 += aarch64/get-reg-list
  141. TEST_GEN_PROGS_aarch64 += aarch64/hypercalls
  142. TEST_GEN_PROGS_aarch64 += aarch64/psci_test
  143. TEST_GEN_PROGS_aarch64 += aarch64/vcpu_width_config
  144. TEST_GEN_PROGS_aarch64 += aarch64/vgic_init
  145. TEST_GEN_PROGS_aarch64 += aarch64/vgic_irq
  146. TEST_GEN_PROGS_aarch64 += demand_paging_test
  147. TEST_GEN_PROGS_aarch64 += dirty_log_test
  148. TEST_GEN_PROGS_aarch64 += dirty_log_perf_test
  149. TEST_GEN_PROGS_aarch64 += kvm_create_max_vcpus
  150. TEST_GEN_PROGS_aarch64 += kvm_page_table_test
  151. TEST_GEN_PROGS_aarch64 += memslot_modification_stress_test
  152. TEST_GEN_PROGS_aarch64 += memslot_perf_test
  153. TEST_GEN_PROGS_aarch64 += rseq_test
  154. TEST_GEN_PROGS_aarch64 += set_memory_region_test
  155. TEST_GEN_PROGS_aarch64 += steal_time
  156. TEST_GEN_PROGS_aarch64 += kvm_binary_stats_test
  157. TEST_GEN_PROGS_s390x = s390x/memop
  158. TEST_GEN_PROGS_s390x += s390x/resets
  159. TEST_GEN_PROGS_s390x += s390x/sync_regs_test
  160. TEST_GEN_PROGS_s390x += s390x/tprot
  161. TEST_GEN_PROGS_s390x += demand_paging_test
  162. TEST_GEN_PROGS_s390x += dirty_log_test
  163. TEST_GEN_PROGS_s390x += kvm_create_max_vcpus
  164. TEST_GEN_PROGS_s390x += kvm_page_table_test
  165. TEST_GEN_PROGS_s390x += rseq_test
  166. TEST_GEN_PROGS_s390x += set_memory_region_test
  167. TEST_GEN_PROGS_s390x += kvm_binary_stats_test
  168. TEST_GEN_PROGS_riscv += demand_paging_test
  169. TEST_GEN_PROGS_riscv += dirty_log_test
  170. TEST_GEN_PROGS_riscv += kvm_create_max_vcpus
  171. TEST_GEN_PROGS_riscv += kvm_page_table_test
  172. TEST_GEN_PROGS_riscv += set_memory_region_test
  173. TEST_GEN_PROGS_riscv += kvm_binary_stats_test
  174. TEST_PROGS += $(TEST_PROGS_$(UNAME_M))
  175. TEST_GEN_PROGS += $(TEST_GEN_PROGS_$(UNAME_M))
  176. TEST_GEN_PROGS_EXTENDED += $(TEST_GEN_PROGS_EXTENDED_$(UNAME_M))
  177. LIBKVM += $(LIBKVM_$(UNAME_M))
  178. INSTALL_HDR_PATH = $(top_srcdir)/usr
  179. LINUX_HDR_PATH = $(INSTALL_HDR_PATH)/include/
  180. LINUX_TOOL_INCLUDE = $(top_srcdir)/tools/include
  181. ifeq ($(ARCH),x86_64)
  182. LINUX_TOOL_ARCH_INCLUDE = $(top_srcdir)/tools/arch/x86/include
  183. else
  184. LINUX_TOOL_ARCH_INCLUDE = $(top_srcdir)/tools/arch/$(ARCH)/include
  185. endif
  186. CFLAGS += -Wall -Wstrict-prototypes -Wuninitialized -O2 -g -std=gnu99 \
  187. -fno-stack-protector -fno-PIE -I$(LINUX_TOOL_INCLUDE) \
  188. -I$(LINUX_TOOL_ARCH_INCLUDE) -I$(LINUX_HDR_PATH) -Iinclude \
  189. -I$(<D) -Iinclude/$(UNAME_M) -I ../rseq -I.. $(EXTRA_CFLAGS) \
  190. $(KHDR_INCLUDES)
  191. no-pie-option := $(call try-run, echo 'int main() { return 0; }' | \
  192. $(CC) -Werror -no-pie -x c - -o "$$TMP", -no-pie)
  193. # On s390, build the testcases KVM-enabled
  194. pgste-option = $(call try-run, echo 'int main() { return 0; }' | \
  195. $(CC) -Werror -Wl$(comma)--s390-pgste -x c - -o "$$TMP",-Wl$(comma)--s390-pgste)
  196. LDLIBS += -ldl
  197. LDFLAGS += -pthread $(no-pie-option) $(pgste-option)
  198. # After inclusion, $(OUTPUT) is defined and
  199. # $(TEST_GEN_PROGS) starts with $(OUTPUT)/
  200. include ../lib.mk
  201. LIBKVM_C := $(filter %.c,$(LIBKVM))
  202. LIBKVM_S := $(filter %.S,$(LIBKVM))
  203. LIBKVM_C_OBJ := $(patsubst %.c, $(OUTPUT)/%.o, $(LIBKVM_C))
  204. LIBKVM_S_OBJ := $(patsubst %.S, $(OUTPUT)/%.o, $(LIBKVM_S))
  205. LIBKVM_STRING_OBJ := $(patsubst %.c, $(OUTPUT)/%.o, $(LIBKVM_STRING))
  206. LIBKVM_OBJS = $(LIBKVM_C_OBJ) $(LIBKVM_S_OBJ) $(LIBKVM_STRING_OBJ)
  207. EXTRA_CLEAN += $(LIBKVM_OBJS) cscope.*
  208. x := $(shell mkdir -p $(sort $(dir $(LIBKVM_C_OBJ) $(LIBKVM_S_OBJ))))
  209. $(LIBKVM_C_OBJ): $(OUTPUT)/%.o: %.c
  210. $(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c $< -o $@
  211. $(LIBKVM_S_OBJ): $(OUTPUT)/%.o: %.S
  212. $(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c $< -o $@
  213. # Compile the string overrides as freestanding to prevent the compiler from
  214. # generating self-referential code, e.g. without "freestanding" the compiler may
  215. # "optimize" memcmp() by invoking memcmp(), thus causing infinite recursion.
  216. $(LIBKVM_STRING_OBJ): $(OUTPUT)/%.o: %.c
  217. $(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c -ffreestanding $< -o $@
  218. x := $(shell mkdir -p $(sort $(dir $(TEST_GEN_PROGS))))
  219. $(TEST_GEN_PROGS): $(LIBKVM_OBJS)
  220. $(TEST_GEN_PROGS_EXTENDED): $(LIBKVM_OBJS)
  221. cscope: include_paths = $(LINUX_TOOL_INCLUDE) $(LINUX_HDR_PATH) include lib ..
  222. cscope:
  223. $(RM) cscope.*
  224. (find $(include_paths) -name '*.h' \
  225. -exec realpath --relative-base=$(PWD) {} \;; \
  226. find . -name '*.c' \
  227. -exec realpath --relative-base=$(PWD) {} \;) | sort -u > cscope.files
  228. cscope -b