xref: /rk3399_ARM-atf/tools/cert_create/Makefile (revision a9d5c273c17662bc1b43eafb5a24bb93377c16ae)
16f971622SJuan Castillo#
23b24b66eSSandrine Bailleux# Copyright (c) 2015-2020, ARM Limited and Contributors. All rights reserved.
36f971622SJuan Castillo#
482cb2c1aSdp-arm# SPDX-License-Identifier: BSD-3-Clause
56f971622SJuan Castillo#
66f971622SJuan Castillo
76f971622SJuan CastilloPROJECT		:= cert_create
86f971622SJuan CastilloPLAT		:= none
9a9673900Sdp-armV		?= 0
106f971622SJuan CastilloDEBUG		:= 0
1142a45b51SEvan LloydBINARY		:= ${PROJECT}${BIN_EXT}
12ccbf890eSJuan CastilloOPENSSL_DIR	:= /usr
1343743ea5SSandrine BailleuxCOT		:= tbbr
146f971622SJuan Castillo
15231c1470SEvan LloydMAKE_HELPERS_DIRECTORY := ../../make_helpers/
16231c1470SEvan Lloydinclude ${MAKE_HELPERS_DIRECTORY}build_macros.mk
17e7f54dbdSEvan Lloydinclude ${MAKE_HELPERS_DIRECTORY}build_env.mk
18231c1470SEvan Lloyd
193b24b66eSSandrine Bailleux# Common source files.
203b24b66eSSandrine BailleuxOBJECTS := src/cert.o \
213b24b66eSSandrine Bailleux           src/cmd_opt.o \
223b24b66eSSandrine Bailleux           src/ext.o \
233b24b66eSSandrine Bailleux           src/key.o \
243b24b66eSSandrine Bailleux           src/main.o \
253b24b66eSSandrine Bailleux           src/sha.o
26bb41eb7aSMasahiro Yamada
2743743ea5SSandrine Bailleux# Chain of trust.
2843743ea5SSandrine Bailleuxifeq (${COT},tbbr)
293b24b66eSSandrine Bailleux  include src/tbbr/tbbr.mk
30*a9d5c273SSandrine Bailleuxelse ifeq (${COT},dualroot)
31*a9d5c273SSandrine Bailleux  include src/dualroot/cot.mk
3243743ea5SSandrine Bailleuxelse
3343743ea5SSandrine Bailleux  $(error Unknown chain of trust ${COT})
3443743ea5SSandrine Bailleuxendif
35231c1470SEvan Lloyd
363b24b66eSSandrine BailleuxHOSTCCFLAGS := -Wall -std=c99
376f971622SJuan Castillo
386f971622SJuan Castilloifeq (${DEBUG},1)
39750e8d80SAntonio Nino Diaz  HOSTCCFLAGS += -g -O0 -DDEBUG -DLOG_LEVEL=40
406f971622SJuan Castilloelse
41750e8d80SAntonio Nino Diaz  HOSTCCFLAGS += -O2 -DLOG_LEVEL=20
426f971622SJuan Castilloendif
433b24b66eSSandrine Bailleux
446f971622SJuan Castilloifeq (${V},0)
456f971622SJuan Castillo  Q := @
466f971622SJuan Castilloelse
476f971622SJuan Castillo  Q :=
486f971622SJuan Castilloendif
496f971622SJuan Castillo
50750e8d80SAntonio Nino DiazHOSTCCFLAGS += ${DEFINES}
51bb41eb7aSMasahiro Yamada
526f971622SJuan Castillo# Make soft links and include from local directory otherwise wrong headers
536f971622SJuan Castillo# could get pulled in from firmware tree.
54ccbf890eSJuan CastilloINC_DIR := -I ./include -I ${PLAT_INCLUDE} -I ${OPENSSL_DIR}/include
55ccbf890eSJuan CastilloLIB_DIR := -L ${OPENSSL_DIR}/lib
566f971622SJuan CastilloLIB := -lssl -lcrypto
576f971622SJuan Castillo
5872610c41Sdp-armHOSTCC ?= gcc
596f971622SJuan Castillo
60aeb25668SEvan Lloyd.PHONY: all clean realclean
616f971622SJuan Castillo
626f971622SJuan Castilloall: clean ${BINARY}
636f971622SJuan Castillo
646f971622SJuan Castillo${BINARY}: ${OBJECTS} Makefile
65750e8d80SAntonio Nino Diaz	@echo "  HOSTLD  $@"
666f971622SJuan Castillo	@echo 'const char build_msg[] = "Built : "__TIME__", "__DATE__; \
67bb41eb7aSMasahiro Yamada                const char platform_msg[] = "${PLAT_MSG}";' | \
68750e8d80SAntonio Nino Diaz                ${HOSTCC} -c ${HOSTCCFLAGS} -xc - -o src/build_msg.o
6972610c41Sdp-arm	${Q}${HOSTCC} src/build_msg.o ${OBJECTS} ${LIB_DIR} ${LIB} -o $@
706f971622SJuan Castillo
716f971622SJuan Castillo%.o: %.c
72750e8d80SAntonio Nino Diaz	@echo "  HOSTCC  $<"
73750e8d80SAntonio Nino Diaz	${Q}${HOSTCC} -c ${HOSTCCFLAGS} ${INC_DIR} $< -o $@
746f971622SJuan Castillo
756f971622SJuan Castilloclean:
76f1477d4aSEvan Lloyd	$(call SHELL_DELETE_ALL, src/build_msg.o ${OBJECTS})
776f971622SJuan Castillo
786f971622SJuan Castillorealclean: clean
79f1477d4aSEvan Lloyd	$(call SHELL_DELETE,${BINARY})
80f1477d4aSEvan Lloyd
81