corda/psw/ae/aesm_service/Makefile
Angie Chinchilla 9441de4c38 Initial release of Intel SGX for Linux.
This release is used in conjunction with the linux-sgx-driver Intial release:
https://github.com/01org/linux-sgx-driver
commit-id: 0e865ce5e6b297a787bcdc12d98bada8174be6d7

Intel-id: 33399

Signed-off-by: Angie Chinchilla <angie.v.chinchilla@intel.com>
2016-06-23 18:51:53 -04:00

326 lines
12 KiB
Makefile

#
# Copyright (C) 2011-2016 Intel Corporation. All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
#
# * Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
# * Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in
# the documentation and/or other materials provided with the
# distribution.
# * Neither the name of Intel Corporation nor the names of its
# contributors may be used to endorse or promote products derived
# from this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
#
TOP_DIR = ../../..
include $(TOP_DIR)/buildenv.mk
IPC_COMMON_DIR := ../common/
IPC_COMMON_SRC_DIR := $(IPC_COMMON_DIR)/src
IPC_COMMON_INC_DIR := $(IPC_COMMON_DIR)/inc
IPC_COMMON_PROTO_DIR := source/protobuf
AESM_WRAPPER_DIR := $(LINUX_PSW_DIR)/ae/aesm_service/source/aesm_wrapper
AESM_SRC_DIR := $(AESM_WRAPPER_DIR)/src
AESM_INC_DIR := $(AESM_WRAPPER_DIR)/inc
AESM_APPLICATION := $(LINUX_PSW_DIR)/ae/aesm_service/source/aesm/application
AESM_EXTENSION := $(LINUX_PSW_DIR)/ae/aesm_service/source/aesm/extension
INCLUDE += -I$(COMMON_DIR)/inc \
-I$(COMMON_DIR)/inc/internal \
-I./include \
-I./include/oal \
-I./source/ \
-I./source/aesm_wrapper/inc
INCLUDE += -I$(LINUX_SDK_DIR)/tseal
INCLUDE += -I$(LINUX_PSW_DIR)/ae/aesm_service/source/aesm/application/
INCLUDE += -I$(LINUX_PSW_DIR)/ae/aesm_service/source/aesm/extension/
INCLUDE += -I$(LINUX_PSW_DIR)/ae/aesm_service/source/epid_provision/
INCLUDE += -I$(LINUX_PSW_DIR)/ae/aesm_service/source/le/
INCLUDE += -I$(LINUX_PSW_DIR)/ae/aesm_service/source/network/
INCLUDE += -I$(LINUX_PSW_DIR)/ae/aesm_service/source/oal/
INCLUDE += -I$(LINUX_PSW_DIR)/ae/aesm_service/source/protobuf/
INCLUDE += -I$(LINUX_PSW_DIR)/ae/aesm_service/source/pve/
INCLUDE += -I$(LINUX_PSW_DIR)/ae/aesm_service/source/qe/
INCLUDE += -I$(LINUX_PSW_DIR)/ae/aesm_service/source/storage/
INCLUDE += -I$(LINUX_PSW_DIR)/ae/data/constants/linux
INCLUDE += -I$(LINUX_PSW_DIR)/ae/inc \
-I$(LINUX_PSW_DIR)/ae/inc/internal \
-I$(LINUX_PSW_DIR)/ae/common
INCLUDE += -I$(LINUX_PSW_DIR)/ae/aesm_service/source/epid_provision
INCLUDE += -I$(LINUX_EXTERNAL_DIR)/epid/inc
INCLUDE += -I$(LINUX_EXTERNAL_DIR)/crypto_px/include/ \
-I$(LINUX_EXTERNAL_DIR)/tinyxml/ \
-I$(LINUX_EXTERNAL_DIR)/ \
-I$(LINUX_EXTERNAL_DIR)/rdrand \
-I$(IPC_COMMON_INC_DIR) \
-I$(AESM_INC_DIR) \
-I$(IPC_COMMON_PROTO_DIR)
EDGER8R := $(LINUX_SDK_DIR)/edger8r/linux/_build/Edger8r.native
PROTPBUF_CXXFLAGS := -fstack-protector -fPIC -Wall -Werror
ifdef DEBUG
PROTPBUF_CXXFLAGS += -ggdb -DDEBUG -UNDEBUG
else
PROTPBUF_CXXFLAGS += -O2 -UDEBUG -DNDEBUG
endif
ifeq ($(ARCH), x86)
PROTPBUF_CXXFLAGS += -m32
else
PROTPBUF_CXXFLAGS += -m64
endif
ifdef PROFILE
CXXFLAGS += -D_PROFILE_
CFLAGS += -D_PROFILE_
endif
CXXFLAGS += -fPIC
CFLAGS := $(filter-out -fPIC -Werror, $(CFLAGS))
LINUX_SE_WRAPPER = $(COMMON_DIR)/se_wrapper
ifdef DEBUG
CXXFLAGS += -DDBG_LOG
CFLAGS += -DDBG_LOG
endif
URTSLIB := -lurts_internal
TRTSLIB := -lsgx_trts
WHITE_LIST_FILE := $(LINUX_PSW_DIR)/ae/data/prebuilt/white_list_cert_to_be_verify.bin
TCRYPTO_LIBDIR := $(LINUX_SDK_DIR)/tlibcrypto
PROTOBUF_LIBDIR := $(LINUX_PROTOBUF)/intel64
VTUNE_LIBDIR := $(LINUX_EXTERNAL_DIR)/vtune/linux/sdk/src/ittnotify
RDRAND_LIBDIR :=$(LINUX_EXTERNAL_DIR)/rdrand/src
RDRAND_MAKEFILE := $(RDRAND_LIBDIR)/Makefile
ifeq ($(ARCH), x86)
PROTOBUF_LIBDIR = $(LINUX_PROTOBUF)/ia32
endif
EXTERNAL_LIB += -L$(TCRYPTO_LIBDIR) -lsgx_tcrypto
EXTERNAL_LIB += -lprotobuf -lrt
EXTERNAL_LIB += -lcrypto
EXTERNAL_LIB += $(shell curl-config --libs)
EXTERNAL_LIB += -L$(LINUX_SE_WRAPPER) -lwrapper -lrt
EXTERNAL_LIB += -L$(RDRAND_LIBDIR) -lrdrand
EXTERNAL_LIB += -L$(VTUNE_LIBDIR) -littnotify
vpath %.cpp $(COMMON_DIR)/src $(LINUX_EXTERNAL_DIR)/tinyxml ./source/epid_provision $(LINUX_PSW_DIR)/ae/common $(AESM_APPLICATION) $(AESM_EXTENSION) $(AESM_SRC_DIR) $(IPC_COMMON_PROTO_DIR) $(COMMON_DIR)/src $(TOP_DIR)/sdk/tseal
vpath %.cc $(IPC_COMMON_PROTO_DIR)
vpath %.c $(TOP_DIR)/sdk/tlibc/string
COMMON_SRC := tinyxmlparser.cpp \
tinyxmlerror.cpp \
tinyxml.cpp \
tinystr.cpp \
./source/le/LEClass.cpp \
./source/oal/aesm_util.cpp \
./source/storage/persistent_storage_table.cpp \
aesm_logic.cpp \
./source/oal/oal_power.cpp \
aesm_rand.cpp \
ipp_bn.cpp \
ipp_rsa_pub_key.cpp \
./source/oal/error_report.cpp \
./source/oal/internal_log.cpp \
sgx_memset_s.cpp \
sgx_read_rand.cpp \
sgx_profile.cpp \
tSeal_util.cpp \
./source/oal/aesm_thread.cpp \
event_strings.cpp
COMMON_SRC += ./source/qe/QEClass.cpp \
./source/pve/PVEClass.cpp \
aesm_encode.cpp \
aesm_epid_blob.cpp \
epid_provision_msg1.cpp \
epid_provision_msg2.cpp \
epid_provision_msg4.cpp \
epid_endpoint_selection.cpp \
epid_utility.cpp \
type_length_value.cpp \
./source/qe/qe_logic.cpp \
./source/pve/pve_logic.cpp \
platform_info_logic.cpp \
pve_pub_key.cpp \
pek_pub_key.cpp \
./source/network/network_encoding_wrapper.cpp \
endpoint_select_info.cpp \
aesm_ecdsa.cpp \
se_sig_rl.cpp \
aesm_long_lived_thread.cpp
COMMON_OBJ := $(COMMON_SRC:.cpp=.o)
IPC_SRC := $(IPC_COMMON_SRC_DIR)/AECloseSessionRequest.cpp \
$(IPC_COMMON_SRC_DIR)/AEGetQuoteResponse.cpp \
$(IPC_COMMON_SRC_DIR)/AECloseSessionResponse.cpp \
$(IPC_COMMON_SRC_DIR)/AEInitQuoteRequest.cpp \
$(IPC_COMMON_SRC_DIR)/AECreateSessionRequest.cpp \
$(IPC_COMMON_SRC_DIR)/AEInitQuoteResponse.cpp \
$(IPC_COMMON_SRC_DIR)/AECreateSessionResponse.cpp \
$(IPC_COMMON_SRC_DIR)/AEInvokeServiceRequest.cpp \
$(IPC_COMMON_SRC_DIR)/AEExchangeReportRequest.cpp \
$(IPC_COMMON_SRC_DIR)/AEInvokeServiceResponse.cpp \
$(IPC_COMMON_SRC_DIR)/AEExchangeReportResponse.cpp \
$(IPC_COMMON_SRC_DIR)/ProtobufSerializer.cpp \
$(IPC_COMMON_SRC_DIR)/AEGetLaunchTokenRequest.cpp \
$(IPC_COMMON_SRC_DIR)/AEGetPsCapRequest.cpp \
$(IPC_COMMON_SRC_DIR)/AEGetPsCapResponse.cpp \
$(IPC_COMMON_SRC_DIR)/AEReportAttestationRequest.cpp \
$(IPC_COMMON_SRC_DIR)/AEReportAttestationResponse.cpp \
$(IPC_COMMON_SRC_DIR)/SocketTransporter.cpp \
$(IPC_COMMON_SRC_DIR)/AEGetLaunchTokenResponse.cpp \
$(IPC_COMMON_SRC_DIR)/UnixCommunicationSocket.cpp \
$(IPC_COMMON_SRC_DIR)/NonBlockingUnixCommunicationSocket.cpp \
$(IPC_COMMON_SRC_DIR)/AEGetQuoteRequest.cpp \
$(IPC_COMMON_SRC_DIR)/UnixSocketFactory.cpp \
$(IPC_COMMON_SRC_DIR)/NonBlockingUnixSocketFactory.cpp
PROTOBUF_SRC := messages.pb.cc
AESM_SRC := AESMLogicWrapper.cpp \
CAESMServer.cpp \
main.cpp \
Thread.cpp \
AESMWorkerThread.cpp \
AESMQueueManager.cpp \
CSelector.cpp \
UnixServerSocket.cpp \
./source/oal/aesm_util.cpp \
aesm_config.cpp
AESM_SRC += aesm_http_msg.cpp
CSRC := $(wildcard *.c)
MEMCMPSRC := consttime_memequal.c
OBJ := $(IPC_SRC:.cpp=.o) \
$(CSRC:.c=.o) \
$(MEMCMPSRC:.c=.o) \
$(AESM_SRC:.cpp=.o) \
$(PROTOBUF_SRC:.cc=.o)
LDUFLAGS := -pthread -L$(BUILD_DIR) $(URTSLIB)
APPNAME := aesm_service
LIBNAME := libaesm_service_common.a
.PHONY: all
all: $(APPNAME) copy_data_file | $(BUILD_DIR)
@$(CP) $< $|
copy_data_file:
@$(MKDIR) -p data
@$(CP) $(WHITE_LIST_FILE) data/white_list_cert_to_be_verify.bin
sgx_tcrypto:
$(MAKE) -C $(TCRYPTO_LIBDIR)
$(LIBNAME): $(COMMON_OBJ)
$(AR) rcs $@ $^
%.o :%.cpp
$(CXX) $(CXXFLAGS) $(INCLUDE) -c $< -o $@
%.o :%.cc
$(CXX) $(CXXFLAGS) $(INCLUDE) -c $< -o $@
consttime_memequal.o :consttime_memequal.c
$(CC) $(filter-out -O2,$(CFLAGS)) -fPIC -O1 $(INCLUDE) -c $< -o $@
$(APPNAME): $(OBJ) $(LIBNAME) sgx_tcrypto -lrdrand
$(CXX) $(CXXFLAGS) $(OBJ) $(LIBNAME) $(LDUFLAGS) $(EXTERNAL_LIB) -o $@ -ldl
$(IPC_SRC): PROTPBUF
./source/le/LEClass.o: ${AESM_EXTENSION}/launch_enclave_u.c
./source/pve/PVEClass.o: ${AESM_EXTENSION}/provision_enclave_u.c
./source/qe/QEClass.o: ${AESM_EXTENSION}/quoting_enclave_u.c
uecall_bridge.o: ${AESM_EXTENSION}/pse_pr_u.c
-lrdrand: $(RDRAND_MAKEFILE)
$(MAKE) -C $(RDRAND_LIBDIR)
$(RDRAND_MAKEFILE):
ifeq ($(ARCH), x86)
@cd $(RDRAND_LIBDIR);./configure
else
@cd $(RDRAND_LIBDIR);./configure CFLAGS=-fPIC
endif
${AESM_EXTENSION}/launch_enclave_u.c: ${LINUX_PSW_DIR}/ae/le/launch_enclave.edl
@$(EDGER8R) --untrusted --untrusted-dir ${AESM_EXTENSION} $<
${AESM_EXTENSION}/provision_enclave_u.c: ${LINUX_PSW_DIR}/ae/pve/provision_enclave.edl
@$(EDGER8R) --untrusted --untrusted-dir ${AESM_EXTENSION} $<
${AESM_EXTENSION}/quoting_enclave_u.c: ${LINUX_PSW_DIR}/ae/qe/quoting_enclave.edl
@$(EDGER8R) --untrusted --untrusted-dir ${AESM_EXTENSION} $<
${AESM_EXTENSION}/pse_pr_u.c: ${LINUX_PSW_DIR}/ae/pse/pse_pr/pse_pr.edl
@$(EDGER8R) --untrusted --untrusted-dir ${AESM_EXTENSION} $<
.PHONY: PROTPBUF
PROTPBUF:
$(MAKE) -C $(IPC_COMMON_PROTO_DIR)
(test -f messages.pb.o) || ($(CXX) $(PROTPBUF_CXXFLAGS) -c $(IPC_COMMON_PROTO_DIR)/messages.pb.cc -o messages.pb.o)
.PHONY: urts
urts:
$(MAKE) -C $(LINUX_PSW_DIR)/urts/linux
$(BUILD_DIR):
@$(MKDIR) $@
.PHONY: clean
clean:
@$(RM) *.o $(IPC_COMMON_SRC_DIR)/*.o
@$(RM) -r data
@$(RM) $(APPNAME)
@$(RM) $(LIBNAME)
$(MAKE) -C $(IPC_COMMON_PROTO_DIR) clean
@$(RM) source/le/*.o
@$(RM) source/pve/*.o
@$(RM) source/pve/*.o
@$(RM) source/network/*.o
@$(RM) source/oal/*.o
@$(RM) source/qe/*.o
@$(RM) source/qe/*.o
@$(RM) source/storage/*.o
@$(RM) $(AESM_EXTENSION)/*_u.c $(AESM_EXTENSION)/*_u.h
ifeq ($(RDRAND_MAKEFILE), $(wildcard $(RDRAND_MAKEFILE)))
@$(MAKE) distclean -C $(RDRAND_LIBDIR)
endif
.PHONY: rebuild
rebuild: clean all