a portable and fast pairing-based cryptography library
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
mcl/Makefile

85 lines
2.3 KiB

include common.mk
LIB_DIR=lib
9 years ago
OBJ_DIR=obj
EXE_DIR=bin
SRC_SRC=fp.cpp
TEST_SRC=fp_test.cpp ec_test.cpp fp_util_test.cpp window_method_test.cpp elgamal_test.cpp fp_tower_test.cpp gmp_test.cpp bn_test.cpp
9 years ago
ifeq ($(CPU),x86-64)
TEST_SRC+=fp_generator_test.cpp mont_fp_test.cpp
endif
SAMPLE_SRC=bench.cpp ecdh.cpp random.cpp rawbench.cpp vote.cpp
##################################################################
MCL_LIB=$(LIB_DIR)/libmcl.a
9 years ago
all: $(MCL_LIB)
ASM_SRC_TXT=mul.txt
9 years ago
LIB_OBJ=$(OBJ_DIR)/$(CPU).o $(OBJ_DIR)/fp.o
LLVM_VER=-3.6
LLVM_LLC=llc$(LLVM_VER)
LLVM_OPT=opt$(LLVM_VER)
GEN_EXE=src/gen
FUNC_LL=src/generated.ll
9 years ago
# CPU is used for llvm
# see $(LLVM_LLC) --version
LLVM_FLAGS=-march=$(CPU) -relocation-model=pic
9 years ago
HAS_BMI2=$(shell cat "/proc/cpuinfo" | grep bmi2 >/dev/null && echo "1")
ifeq ($(HAS_BMI2),1)
LLVM_FLAGS+=-mattr=bmi2
endif
$(MCL_LIB): $(LIB_OBJ) $(GEN_EXE)
$(MKDIR) $(LIB_DIR)
9 years ago
$(AR) $@ $(LIB_OBJ)
$(OBJ_DIR)/$(CPU).o: src/$(CPU).s
$(MKDIR) $(OBJ_DIR) $(EXE_DIR)
$(PRE)$(CXX) -c $< -o $@ $(CFLAGS)
src/base$(BIT).ll: $(addprefix src/, gen.py $(ASM_SRC_TXT)) $(FUNC_LL)
cd src && python gen.py $(notdir $(FUNC_LL)) $(BIT)
9 years ago
src/$(CPU).s: src/base$(BIT).ll
$(LLVM_OPT) -O3 -o - $< | $(LLVM_LLC) -O3 -o $@ $(LLVM_FLAGS)
$(GEN_EXE): src/gen.cpp src/llvm_gen.hpp
$(CXX) -o $@ $< $(CFLAGS) -O0
$(FUNC_LL): $(GEN_EXE)
$(GEN_EXE) > $(FUNC_LL)
9 years ago
##################################################################
VPATH=test sample src
.SUFFIXES: .cpp .d .exe
$(OBJ_DIR)/%.o: %.cpp
$(PRE)$(CXX) $(CFLAGS) -c $< -o $@ -MMD -MP -MF $(@:.o=.d)
$(EXE_DIR)/%.exe: $(OBJ_DIR)/%.o $(MCL_LIB)
$(PRE)$(CXX) $< -o $@ $(MCL_LIB) $(LDFLAGS)
SAMPLE_EXE=$(addprefix $(EXE_DIR)/,$(SAMPLE_SRC:.cpp=.exe))
sample: $(SAMPLE_EXE) $(MCL_LIB)
TEST_EXE=$(addprefix $(EXE_DIR)/,$(TEST_SRC:.cpp=.exe))
test: $(TEST_EXE)
@echo test $(TEST_EXE)
@sh -ec 'for i in $(TEST_EXE); do $$i|grep "ctest:name"; done' > result.txt
@grep -v "ng=0, exception=0" result.txt || echo "all unit tests are ok"
10 years ago
clean:
$(RM) $(MCL_LIB) src/base$(BIT).ll src/$(CPU).s $(OBJ_DIR)/* $(EXE_DIR)/*.exe $(GEN_EXE)
10 years ago
9 years ago
ALL_SRC=$(SRC_SRC) $(TEST_SRC) $(SAMPLE_SRC)
DEPEND_FILE=$(addprefix $(OBJ_DIR)/, $(ALL_SRC:.cpp=.d))
-include $(DEPEND_FILE)
10 years ago
9 years ago
# don't remove these files automatically
.SECONDARY: $(addprefix $(OBJ_DIR)/, $(ALL_SRC:.cpp=.o))