Makefile 1.3 KB

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