0001 top_srcdir = ../../../..
0002
0003 include ../lib.mk
0004
0005 .PHONY: all clean
0006
0007 CAN_BUILD_X86_64 := $(shell ../x86/check_cc.sh "$(CC)" \
0008 ../x86/trivial_64bit_program.c)
0009
0010 ifndef OBJCOPY
0011 OBJCOPY := $(CROSS_COMPILE)objcopy
0012 endif
0013
0014 INCLUDES := -I$(top_srcdir)/tools/include
0015 HOST_CFLAGS := -Wall -Werror -g $(INCLUDES) -fPIC -z noexecstack
0016 ENCL_CFLAGS := -Wall -Werror -static -nostdlib -nostartfiles -fPIC \
0017 -fno-stack-protector -mrdrnd $(INCLUDES)
0018
0019 TEST_CUSTOM_PROGS := $(OUTPUT)/test_sgx
0020
0021 ifeq ($(CAN_BUILD_X86_64), 1)
0022 all: $(TEST_CUSTOM_PROGS) $(OUTPUT)/test_encl.elf
0023 endif
0024
0025 $(OUTPUT)/test_sgx: $(OUTPUT)/main.o \
0026 $(OUTPUT)/load.o \
0027 $(OUTPUT)/sigstruct.o \
0028 $(OUTPUT)/call.o \
0029 $(OUTPUT)/sign_key.o
0030 $(CC) $(HOST_CFLAGS) -o $@ $^ -lcrypto
0031
0032 $(OUTPUT)/main.o: main.c
0033 $(CC) $(HOST_CFLAGS) -c $< -o $@
0034
0035 $(OUTPUT)/load.o: load.c
0036 $(CC) $(HOST_CFLAGS) -c $< -o $@
0037
0038 $(OUTPUT)/sigstruct.o: sigstruct.c
0039 $(CC) $(HOST_CFLAGS) -c $< -o $@
0040
0041 $(OUTPUT)/call.o: call.S
0042 $(CC) $(HOST_CFLAGS) -c $< -o $@
0043
0044 $(OUTPUT)/sign_key.o: sign_key.S
0045 $(CC) $(HOST_CFLAGS) -c $< -o $@
0046
0047 $(OUTPUT)/test_encl.elf: test_encl.lds test_encl.c test_encl_bootstrap.S
0048 $(CC) $(ENCL_CFLAGS) -T $^ -o $@ -Wl,--build-id=none
0049
0050 EXTRA_CLEAN := \
0051 $(OUTPUT)/test_encl.elf \
0052 $(OUTPUT)/load.o \
0053 $(OUTPUT)/call.o \
0054 $(OUTPUT)/main.o \
0055 $(OUTPUT)/sigstruct.o \
0056 $(OUTPUT)/test_sgx \
0057 $(OUTPUT)/test_sgx.o \