1top_srcdir = ../../../..
2
3include ../lib.mk
4
5.PHONY: all clean
6
7CAN_BUILD_X86_64 := $(shell ../x86/check_cc.sh "$(CC)" \
8			    ../x86/trivial_64bit_program.c)
9
10ifndef OBJCOPY
11OBJCOPY := $(CROSS_COMPILE)objcopy
12endif
13
14INCLUDES := -I$(top_srcdir)/tools/include
15HOST_CFLAGS := -Wall -Werror -g $(INCLUDES) -fPIC -z noexecstack
16ENCL_CFLAGS := -Wall -Werror -static -nostdlib -nostartfiles -fPIC \
17	       -fno-stack-protector -mrdrnd $(INCLUDES)
18
19ifeq ($(CAN_BUILD_X86_64), 1)
20TEST_CUSTOM_PROGS := $(OUTPUT)/test_sgx
21TEST_FILES := $(OUTPUT)/test_encl.elf
22
23all: $(TEST_CUSTOM_PROGS) $(OUTPUT)/test_encl.elf
24endif
25
26$(OUTPUT)/test_sgx: $(OUTPUT)/main.o \
27		    $(OUTPUT)/load.o \
28		    $(OUTPUT)/sigstruct.o \
29		    $(OUTPUT)/call.o \
30		    $(OUTPUT)/sign_key.o
31	$(CC) $(HOST_CFLAGS) -o $@ $^ -lcrypto
32
33$(OUTPUT)/main.o: main.c
34	$(CC) $(HOST_CFLAGS) -c $< -o $@
35
36$(OUTPUT)/load.o: load.c
37	$(CC) $(HOST_CFLAGS) -c $< -o $@
38
39$(OUTPUT)/sigstruct.o: sigstruct.c
40	$(CC) $(HOST_CFLAGS) -c $< -o $@
41
42$(OUTPUT)/call.o: call.S
43	$(CC) $(HOST_CFLAGS) -c $< -o $@
44
45$(OUTPUT)/sign_key.o: sign_key.S
46	$(CC) $(HOST_CFLAGS) -c $< -o $@
47
48$(OUTPUT)/test_encl.elf: test_encl.lds test_encl.c test_encl_bootstrap.S
49	$(CC) $(ENCL_CFLAGS) -T $^ -o $@ -Wl,--build-id=none
50
51EXTRA_CLEAN := \
52	$(OUTPUT)/test_encl.elf \
53	$(OUTPUT)/load.o \
54	$(OUTPUT)/call.o \
55	$(OUTPUT)/main.o \
56	$(OUTPUT)/sigstruct.o \
57	$(OUTPUT)/test_sgx \
58	$(OUTPUT)/test_sgx.o \
59