xref: /rk3399_ARM-atf/tools/cert_create/Makefile (revision 3b24b66edc8bc875b26cd5d52357f46afab974b8)
16f971622SJuan Castillo#
2*3b24b66eSSandrine 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
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
18*3b24b66eSSandrine Bailleux# Common source files.
19*3b24b66eSSandrine BailleuxOBJECTS := src/cert.o \
20*3b24b66eSSandrine Bailleux           src/cmd_opt.o \
21*3b24b66eSSandrine Bailleux           src/ext.o \
22*3b24b66eSSandrine Bailleux           src/key.o \
23*3b24b66eSSandrine Bailleux           src/main.o \
24*3b24b66eSSandrine Bailleux           src/sha.o
25bb41eb7aSMasahiro Yamada
26*3b24b66eSSandrine Bailleux# TBBR chain of trust definitions.
27*3b24b66eSSandrine Bailleuxinclude src/tbbr/tbbr.mk
28231c1470SEvan Lloyd
29*3b24b66eSSandrine BailleuxHOSTCCFLAGS := -Wall -std=c99
306f971622SJuan Castillo
316f971622SJuan Castilloifeq (${DEBUG},1)
32750e8d80SAntonio Nino Diaz  HOSTCCFLAGS += -g -O0 -DDEBUG -DLOG_LEVEL=40
336f971622SJuan Castilloelse
34750e8d80SAntonio Nino Diaz  HOSTCCFLAGS += -O2 -DLOG_LEVEL=20
356f971622SJuan Castilloendif
36*3b24b66eSSandrine Bailleux
376f971622SJuan Castilloifeq (${V},0)
386f971622SJuan Castillo  Q := @
396f971622SJuan Castilloelse
406f971622SJuan Castillo  Q :=
416f971622SJuan Castilloendif
426f971622SJuan Castillo
43750e8d80SAntonio Nino DiazHOSTCCFLAGS += ${DEFINES}
44bb41eb7aSMasahiro Yamada
456f971622SJuan Castillo# Make soft links and include from local directory otherwise wrong headers
466f971622SJuan Castillo# could get pulled in from firmware tree.
47ccbf890eSJuan CastilloINC_DIR := -I ./include -I ${PLAT_INCLUDE} -I ${OPENSSL_DIR}/include
48ccbf890eSJuan CastilloLIB_DIR := -L ${OPENSSL_DIR}/lib
496f971622SJuan CastilloLIB := -lssl -lcrypto
506f971622SJuan Castillo
5172610c41Sdp-armHOSTCC ?= gcc
526f971622SJuan Castillo
53aeb25668SEvan Lloyd.PHONY: all clean realclean
546f971622SJuan Castillo
556f971622SJuan Castilloall: clean ${BINARY}
566f971622SJuan Castillo
576f971622SJuan Castillo${BINARY}: ${OBJECTS} Makefile
58750e8d80SAntonio Nino Diaz	@echo "  HOSTLD  $@"
596f971622SJuan Castillo	@echo 'const char build_msg[] = "Built : "__TIME__", "__DATE__; \
60bb41eb7aSMasahiro Yamada                const char platform_msg[] = "${PLAT_MSG}";' | \
61750e8d80SAntonio Nino Diaz                ${HOSTCC} -c ${HOSTCCFLAGS} -xc - -o src/build_msg.o
6272610c41Sdp-arm	${Q}${HOSTCC} src/build_msg.o ${OBJECTS} ${LIB_DIR} ${LIB} -o $@
636f971622SJuan Castillo
646f971622SJuan Castillo%.o: %.c
65750e8d80SAntonio Nino Diaz	@echo "  HOSTCC  $<"
66750e8d80SAntonio Nino Diaz	${Q}${HOSTCC} -c ${HOSTCCFLAGS} ${INC_DIR} $< -o $@
676f971622SJuan Castillo
686f971622SJuan Castilloclean:
69f1477d4aSEvan Lloyd	$(call SHELL_DELETE_ALL, src/build_msg.o ${OBJECTS})
706f971622SJuan Castillo
716f971622SJuan Castillorealclean: clean
72f1477d4aSEvan Lloyd	$(call SHELL_DELETE,${BINARY})
73f1477d4aSEvan Lloyd
74