cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

Makefile (8670B)


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