2adcba79e6
Add a selftest for SGX. It is a trivial test where a simple enclave copies one 64-bit word of memory between two memory locations, but ensures that all SGX hardware and software infrastructure is functioning. Signed-off-by: Jarkko Sakkinen <jarkko@kernel.org> Signed-off-by: Borislav Petkov <bp@suse.de> Acked-by: Jethro Beekman <jethro@fortanix.com> Cc: linux-kselftest@vger.kernel.org Link: https://lkml.kernel.org/r/20201112220135.165028-21-jarkko@kernel.org
54 lines
1.2 KiB
Makefile
54 lines
1.2 KiB
Makefile
top_srcdir = ../../../..
|
|
|
|
include ../lib.mk
|
|
|
|
.PHONY: all clean
|
|
|
|
CAN_BUILD_X86_64 := $(shell ../x86/check_cc.sh $(CC) \
|
|
../x86/trivial_64bit_program.c)
|
|
|
|
ifndef OBJCOPY
|
|
OBJCOPY := $(CROSS_COMPILE)objcopy
|
|
endif
|
|
|
|
INCLUDES := -I$(top_srcdir)/tools/include
|
|
HOST_CFLAGS := -Wall -Werror -g $(INCLUDES) -fPIC -z noexecstack
|
|
ENCL_CFLAGS := -Wall -Werror -static -nostdlib -nostartfiles -fPIC \
|
|
-fno-stack-protector -mrdrnd $(INCLUDES)
|
|
|
|
TEST_CUSTOM_PROGS := $(OUTPUT)/test_sgx
|
|
|
|
ifeq ($(CAN_BUILD_X86_64), 1)
|
|
all: $(TEST_CUSTOM_PROGS) $(OUTPUT)/test_encl.elf
|
|
endif
|
|
|
|
$(OUTPUT)/test_sgx: $(OUTPUT)/main.o \
|
|
$(OUTPUT)/load.o \
|
|
$(OUTPUT)/sigstruct.o \
|
|
$(OUTPUT)/call.o
|
|
$(CC) $(HOST_CFLAGS) -o $@ $^ -lcrypto
|
|
|
|
$(OUTPUT)/main.o: main.c
|
|
$(CC) $(HOST_CFLAGS) -c $< -o $@
|
|
|
|
$(OUTPUT)/load.o: load.c
|
|
$(CC) $(HOST_CFLAGS) -c $< -o $@
|
|
|
|
$(OUTPUT)/sigstruct.o: sigstruct.c
|
|
$(CC) $(HOST_CFLAGS) -c $< -o $@
|
|
|
|
$(OUTPUT)/call.o: call.S
|
|
$(CC) $(HOST_CFLAGS) -c $< -o $@
|
|
|
|
$(OUTPUT)/test_encl.elf: test_encl.lds test_encl.c test_encl_bootstrap.S
|
|
$(CC) $(ENCL_CFLAGS) -T $^ -o $@
|
|
|
|
EXTRA_CLEAN := \
|
|
$(OUTPUT)/test_encl.elf \
|
|
$(OUTPUT)/load.o \
|
|
$(OUTPUT)/call.o \
|
|
$(OUTPUT)/main.o \
|
|
$(OUTPUT)/sigstruct.o \
|
|
$(OUTPUT)/test_sgx \
|
|
$(OUTPUT)/test_sgx.o \
|