68 lines
1.9 KiB
Makefile
68 lines
1.9 KiB
Makefile
MAIN_MAKEFILE := $(firstword $(MAKEFILE_LIST))
|
|
INCLUDE_MAKEFILE := $(lastword $(MAKEFILE_LIST))
|
|
CUR_DIR := $(shell dirname $(realpath $(MAIN_MAKEFILE)))
|
|
PROJECT_DIR := $(realpath $(CUR_DIR)/../../)
|
|
|
|
CC := /usr/local/occlum/bin/musl-clang
|
|
C_SRCS := $(wildcard *.c)
|
|
S_FILES := $(C_SRCS:%.c=%.S)
|
|
C_OBJS := $(C_SRCS:%.c=%.o)
|
|
FS_PATH := ../fs
|
|
BIN_NAME := $(shell basename $(CUR_DIR))
|
|
BIN_FS_PATH := /$(BIN_NAME)
|
|
BIN_PATH := $(FS_PATH)/$(BIN_FS_PATH)
|
|
OBJDUMP_FILE := bin.objdump
|
|
READELF_FILE := bin.readelf
|
|
|
|
CLANG_BIN_PATH := $(shell clang -print-prog-name=clang)
|
|
LLVM_PATH := $(abspath $(dir $(CLANG_BIN_PATH))../)
|
|
|
|
C_FLAGS = -Wall -O0 $(EXTRA_C_FLAGS)
|
|
C_FLAGS += -Xclang -load -Xclang $(LLVM_PATH)/lib/LLVMMDSFIIRInserter.so
|
|
LINK_FLAGS = $(C_FLAGS) $(EXTRA_LINK_FLAGS)
|
|
|
|
.PHONY: all test debug clean
|
|
|
|
#############################################################################
|
|
# Build
|
|
#############################################################################
|
|
|
|
all: $(BIN_PATH)
|
|
|
|
$(BIN_PATH): $(BIN_NAME)
|
|
@mkdir -p $(shell dirname $@)
|
|
@cp $^ $@
|
|
@echo "COPY => $@"
|
|
|
|
debug: $(OBJDUMP_FILE) $(READELF_FILE)
|
|
|
|
$(OBJDUMP_FILE): $(BIN_NAME)
|
|
@objdump -d $(BIN_NAME) > $(OBJDUMP_FILE)
|
|
@echo "OBJDUMP => $@"
|
|
|
|
$(READELF_FILE): $(BIN_NAME)
|
|
@readelf -a -d $(BIN_NAME) > $(READELF_FILE)
|
|
@echo "READELF => $@"
|
|
|
|
$(BIN_NAME): $(C_OBJS)
|
|
@$(CC) $^ $(LINK_FLAGS) -o $(BIN_NAME)
|
|
@echo "LINK => $@"
|
|
|
|
$(C_OBJS): %.o: %.c
|
|
@$(CC) $(C_FLAGS) -c $< -o $@
|
|
@echo "CC <= $@"
|
|
|
|
#############################################################################
|
|
# Test
|
|
#############################################################################
|
|
|
|
test: $(BIN_ENC_NAME)
|
|
@cd $(CUR_DIR)/.. && RUST_BACKTRACE=1 ./pal $(BIN_FS_PATH) $(BIN_ARGS)
|
|
|
|
#############################################################################
|
|
# Misc
|
|
#############################################################################
|
|
|
|
clean:
|
|
@-$(RM) -f *.o *.S $(BIN_NAME) $(BIN_ENC_NAME) $(OBJDUMP_FILE) $(READELF_FILE)
|