123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- #
- # Copyright (c) 2015-2022, Arm Limited and Contributors. All rights reserved.
- #
- # SPDX-License-Identifier: BSD-3-Clause
- #
- PLAT := none
- V ?= 0
- DEBUG := 0
- CRTTOOL ?= cert_create${BIN_EXT}
- BINARY := $(notdir ${CRTTOOL})
- COT := tbbr
- MAKE_HELPERS_DIRECTORY := ../../make_helpers/
- include ${MAKE_HELPERS_DIRECTORY}build_macros.mk
- include ${MAKE_HELPERS_DIRECTORY}build_env.mk
- include ${MAKE_HELPERS_DIRECTORY}defaults.mk
- ifneq (${PLAT},none)
- TF_PLATFORM_ROOT := ../../plat/
- include ${MAKE_HELPERS_DIRECTORY}plat_helpers.mk
- PLAT_CERT_CREATE_HELPER_MK := ${PLAT_DIR}/cert_create_tbbr.mk
- endif
- # Common source files.
- OBJECTS := src/cert.o \
- src/cmd_opt.o \
- src/ext.o \
- src/key.o \
- src/main.o \
- src/sha.o
- # Chain of trust.
- ifeq (${COT},tbbr)
- include src/tbbr/tbbr.mk
- else ifeq (${COT},dualroot)
- include src/dualroot/cot.mk
- else ifeq (${COT},cca)
- include src/cca/cot.mk
- else
- $(error Unknown chain of trust ${COT})
- endif
- ifneq (,$(wildcard ${PLAT_CERT_CREATE_HELPER_MK}))
- include ${PLAT_CERT_CREATE_HELPER_MK}
- endif
- # Select OpenSSL version flag according to the OpenSSL build selected
- # from setting the OPENSSL_DIR path.
- $(eval $(call SELECT_OPENSSL_API_VERSION))
- HOSTCCFLAGS := -Wall -std=c99
- ifeq (${DEBUG},1)
- HOSTCCFLAGS += -g -O0 -DDEBUG -DLOG_LEVEL=40
- else
- HOSTCCFLAGS += -O2 -DLOG_LEVEL=20
- endif
- ifeq (${V},0)
- Q := @
- else
- Q :=
- endif
- HOSTCCFLAGS += ${DEFINES}
- # USING_OPENSSL3 flag will be added to the HOSTCCFLAGS variable with the proper
- # computed value.
- HOSTCCFLAGS += -DUSING_OPENSSL3=$(USING_OPENSSL3)
- # Make soft links and include from local directory otherwise wrong headers
- # could get pulled in from firmware tree.
- INC_DIR += -I ./include -I ${PLAT_INCLUDE} -I ${OPENSSL_DIR}/include
- # Include library directories where OpenSSL library files are located.
- # For a normal installation (i.e.: when ${OPENSSL_DIR} = /usr or
- # /usr/local), binaries are located under the ${OPENSSL_DIR}/lib/
- # directory. However, for a local build of OpenSSL, the built binaries are
- # located under the main project directory (i.e.: ${OPENSSL_DIR}, not
- # ${OPENSSL_DIR}/lib/).
- LIB_DIR := -L ${OPENSSL_DIR}/lib -L ${OPENSSL_DIR}
- LIB := -lssl -lcrypto
- HOSTCC ?= gcc
- .PHONY: all clean realclean --openssl
- all: --openssl ${BINARY}
- ${BINARY}: ${OBJECTS} Makefile
- @echo " HOSTLD $@"
- @echo 'const char build_msg[] = "Built : "__TIME__", "__DATE__; \
- const char platform_msg[] = "${PLAT_MSG}";' | \
- ${HOSTCC} -c ${HOSTCCFLAGS} -xc - -o src/build_msg.o
- ${Q}${HOSTCC} src/build_msg.o ${OBJECTS} ${LIB_DIR} ${LIB} -o $@
- %.o: %.c
- @echo " HOSTCC $<"
- ${Q}${HOSTCC} -c ${HOSTCCFLAGS} ${INC_DIR} $< -o $@
- --openssl:
- ifeq ($(DEBUG),1)
- @echo "Selected OpenSSL version: ${OPENSSL_CURRENT_VER}"
- endif
- clean:
- $(call SHELL_DELETE_ALL, src/build_msg.o ${OBJECTS})
- realclean: clean
- $(call SHELL_DELETE,${BINARY})
|