xref: /rk3399_ARM-atf/tools/cert_create/Makefile (revision fafd3ec9c954cbc5430dc24bdf5c46b97034c832)
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 CastilloPLAT		:= none
8a9673900Sdp-armV		?= 0
96f971622SJuan CastilloDEBUG		:= 0
10*fafd3ec9SManish V BadarkheBINARY		:= $(notdir ${CRTTOOL})
11ccbf890eSJuan CastilloOPENSSL_DIR	:= /usr
1243743ea5SSandrine BailleuxCOT		:= tbbr
136f971622SJuan Castillo
14231c1470SEvan LloydMAKE_HELPERS_DIRECTORY := ../../make_helpers/
15231c1470SEvan Lloydinclude ${MAKE_HELPERS_DIRECTORY}build_macros.mk
16e7f54dbdSEvan Lloydinclude ${MAKE_HELPERS_DIRECTORY}build_env.mk
17231c1470SEvan Lloyd
183b24b66eSSandrine Bailleux# Common source files.
193b24b66eSSandrine BailleuxOBJECTS := src/cert.o \
203b24b66eSSandrine Bailleux           src/cmd_opt.o \
213b24b66eSSandrine Bailleux           src/ext.o \
223b24b66eSSandrine Bailleux           src/key.o \
233b24b66eSSandrine Bailleux           src/main.o \
243b24b66eSSandrine Bailleux           src/sha.o
25bb41eb7aSMasahiro Yamada
2643743ea5SSandrine Bailleux# Chain of trust.
2743743ea5SSandrine Bailleuxifeq (${COT},tbbr)
283b24b66eSSandrine Bailleux  include src/tbbr/tbbr.mk
29a9d5c273SSandrine Bailleuxelse ifeq (${COT},dualroot)
30a9d5c273SSandrine Bailleux  include src/dualroot/cot.mk
3143743ea5SSandrine Bailleuxelse
3243743ea5SSandrine Bailleux  $(error Unknown chain of trust ${COT})
3343743ea5SSandrine Bailleuxendif
34231c1470SEvan Lloyd
353b24b66eSSandrine BailleuxHOSTCCFLAGS := -Wall -std=c99
366f971622SJuan Castillo
376f971622SJuan Castilloifeq (${DEBUG},1)
38750e8d80SAntonio Nino Diaz  HOSTCCFLAGS += -g -O0 -DDEBUG -DLOG_LEVEL=40
396f971622SJuan Castilloelse
40750e8d80SAntonio Nino Diaz  HOSTCCFLAGS += -O2 -DLOG_LEVEL=20
416f971622SJuan Castilloendif
423b24b66eSSandrine Bailleux
436f971622SJuan Castilloifeq (${V},0)
446f971622SJuan Castillo  Q := @
456f971622SJuan Castilloelse
466f971622SJuan Castillo  Q :=
476f971622SJuan Castilloendif
486f971622SJuan Castillo
49750e8d80SAntonio Nino DiazHOSTCCFLAGS += ${DEFINES}
50bb41eb7aSMasahiro Yamada
516f971622SJuan Castillo# Make soft links and include from local directory otherwise wrong headers
526f971622SJuan Castillo# could get pulled in from firmware tree.
53ccbf890eSJuan CastilloINC_DIR := -I ./include -I ${PLAT_INCLUDE} -I ${OPENSSL_DIR}/include
54ccbf890eSJuan CastilloLIB_DIR := -L ${OPENSSL_DIR}/lib
556f971622SJuan CastilloLIB := -lssl -lcrypto
566f971622SJuan Castillo
5772610c41Sdp-armHOSTCC ?= gcc
586f971622SJuan Castillo
59aeb25668SEvan Lloyd.PHONY: all clean realclean
606f971622SJuan Castillo
616f971622SJuan Castilloall: clean ${BINARY}
626f971622SJuan Castillo
636f971622SJuan Castillo${BINARY}: ${OBJECTS} Makefile
64750e8d80SAntonio Nino Diaz	@echo "  HOSTLD  $@"
656f971622SJuan Castillo	@echo 'const char build_msg[] = "Built : "__TIME__", "__DATE__; \
66bb41eb7aSMasahiro Yamada                const char platform_msg[] = "${PLAT_MSG}";' | \
67750e8d80SAntonio Nino Diaz                ${HOSTCC} -c ${HOSTCCFLAGS} -xc - -o src/build_msg.o
6872610c41Sdp-arm	${Q}${HOSTCC} src/build_msg.o ${OBJECTS} ${LIB_DIR} ${LIB} -o $@
696f971622SJuan Castillo
706f971622SJuan Castillo%.o: %.c
71750e8d80SAntonio Nino Diaz	@echo "  HOSTCC  $<"
72750e8d80SAntonio Nino Diaz	${Q}${HOSTCC} -c ${HOSTCCFLAGS} ${INC_DIR} $< -o $@
736f971622SJuan Castillo
746f971622SJuan Castilloclean:
75f1477d4aSEvan Lloyd	$(call SHELL_DELETE_ALL, src/build_msg.o ${OBJECTS})
766f971622SJuan Castillo
776f971622SJuan Castillorealclean: clean
78f1477d4aSEvan Lloyd	$(call SHELL_DELETE,${BINARY})
79f1477d4aSEvan Lloyd
80