xref: /arm-trusted-firmware/tools/renesas/rcar_layout_create/makefile (revision 91f16700b400a8c0651d24a598fc48ee2997a0d7)
1*91f16700Schasinglulu#
2*91f16700Schasinglulu# Copyright (c) 2015-2018, Renesas Electronics Corporation. All rights reserved.
3*91f16700Schasinglulu#
4*91f16700Schasinglulu# SPDX-License-Identifier: BSD-3-Clause
5*91f16700Schasinglulu#
6*91f16700Schasinglulu
7*91f16700Schasinglulu###################################################
8*91f16700Schasinglulu# makefile
9*91f16700Schasinglulu###################################################
10*91f16700Schasinglulu
11*91f16700Schasinglulu#output file name
12*91f16700SchasingluluFILE_NAME_SA0   = bootparam_sa0
13*91f16700SchasingluluFILE_NAME_SA6   = cert_header_sa6
14*91f16700Schasinglulu
15*91f16700SchasingluluOUTPUT_FILE_SA0 = $(FILE_NAME_SA0).elf
16*91f16700SchasingluluOUTPUT_FILE_SA6 = $(FILE_NAME_SA6).elf
17*91f16700Schasinglulu
18*91f16700Schasinglulu#object file name
19*91f16700SchasingluluOBJ_FILE_SA0 =	sa0.o
20*91f16700SchasingluluOBJ_FILE_SA6 =	sa6.o
21*91f16700Schasinglulu
22*91f16700Schasinglulu#linker script name
23*91f16700SchasingluluMEMORY_DEF_SA0 = sa0.ld.S
24*91f16700SchasingluluMEMORY_DEF_SA6 = sa6.ld.S
25*91f16700Schasinglulu
26*91f16700Schasinglulu###################################################
27*91f16700Schasinglulu# Convenience function for adding build definitions
28*91f16700Schasinglulu# $(eval $(call add_define,FOO)) will have:
29*91f16700Schasinglulu# -DFOO if $(FOO) is empty; -DFOO=$(FOO) otherwise
30*91f16700Schasingluludefine add_define
31*91f16700SchasingluluDEFINES			+=	-D$(1)$(if $(value $(1)),=$(value $(1)),)
32*91f16700Schasingluluendef
33*91f16700Schasinglulu
34*91f16700Schasinglulu# Process RCAR_SA0_SIZE flag
35*91f16700Schasingluluifndef RCAR_SA0_SIZE
36*91f16700SchasingluluRCAR_SA0_SIZE := 1
37*91f16700Schasingluluelse
38*91f16700Schasingluluifeq (${RCAR_SA0_SIZE},0)
39*91f16700SchasingluluRCAR_SA0_SIZE := 0
40*91f16700Schasingluluelse
41*91f16700SchasingluluRCAR_SA0_SIZE := 1
42*91f16700Schasingluluendif
43*91f16700Schasingluluendif
44*91f16700Schasinglulu$(eval $(call add_define,RCAR_SA0_SIZE))
45*91f16700Schasinglulu
46*91f16700Schasinglulu# Process RCAR_SA6_TYPE flag
47*91f16700Schasingluluifndef RCAR_SA6_TYPE
48*91f16700SchasingluluRCAR_SA6_TYPE := 0
49*91f16700Schasingluluelse
50*91f16700Schasingluluifeq (${RCAR_SA6_TYPE},0)
51*91f16700SchasingluluRCAR_SA6_TYPE := 0
52*91f16700Schasingluluelse
53*91f16700SchasingluluRCAR_SA6_TYPE := 1
54*91f16700Schasingluluendif
55*91f16700Schasingluluendif
56*91f16700Schasinglulu$(eval $(call add_define,RCAR_SA6_TYPE))
57*91f16700Schasinglulu
58*91f16700Schasinglulu# Handle different VMA adjustment on D3
59*91f16700Schasingluluifeq (${RCAR_LSI},${RCAR_D3})
60*91f16700SchasingluluRCAR_VMA_ADJUST_ADDR := 0xE6320000
61*91f16700Schasingluluelse
62*91f16700SchasingluluRCAR_VMA_ADJUST_ADDR := 0xE6312000
63*91f16700Schasingluluendif
64*91f16700Schasinglulu$(eval $(call add_define,RCAR_VMA_ADJUST_ADDR))
65*91f16700Schasinglulu
66*91f16700Schasinglulu
67*91f16700Schasinglulu###################################################
68*91f16700Schasinglulu
69*91f16700Schasinglulu#c compiler
70*91f16700SchasingluluCC = $(CROSS_COMPILE)gcc
71*91f16700SchasingluluCFLAGS += ${DEFINES}
72*91f16700SchasingluluCFLAGS += -I../../include/lib/stdlib
73*91f16700Schasinglulu
74*91f16700Schasinglulu#Linker
75*91f16700SchasingluluLD = $(CROSS_COMPILE)ld
76*91f16700Schasinglulu
77*91f16700Schasinglulu#objcopy
78*91f16700Schasingluluobjcopy = $(CROSS_COMPILE)objcopy
79*91f16700Schasinglulu
80*91f16700Schasinglulu#clean
81*91f16700SchasingluluCL = rm -f
82*91f16700Schasinglulu
83*91f16700Schasinglulu###################################################
84*91f16700Schasinglulu.SUFFIXES : .s .c .o
85*91f16700Schasinglulu
86*91f16700Schasinglulu###################################################
87*91f16700Schasinglulu# command
88*91f16700Schasinglulu
89*91f16700Schasinglulu.PHONY: all
90*91f16700Schasingluluall: $(OUTPUT_FILE_SA0) $(OUTPUT_FILE_SA6)
91*91f16700Schasinglulu###################################################
92*91f16700Schasinglulu# Linker
93*91f16700Schasinglulu###################################################
94*91f16700Schasinglulu$(OUTPUT_FILE_SA0) : $(MEMORY_DEF_SA0) $(OBJ_FILE_SA0)
95*91f16700Schasinglulu	$(LD) $(OBJ_FILE_SA0)		 	\
96*91f16700Schasinglulu	-T $(MEMORY_DEF_SA0)			\
97*91f16700Schasinglulu	-o $(OUTPUT_FILE_SA0)			\
98*91f16700Schasinglulu	-Map $(FILE_NAME_SA0).map 		\
99*91f16700Schasinglulu
100*91f16700Schasinglulu	$(objcopy) -O srec --adjust-vma=$(RCAR_VMA_ADJUST_ADDR) --srec-forceS3  $(OUTPUT_FILE_SA0) $(FILE_NAME_SA0).srec
101*91f16700Schasinglulu	$(objcopy) -O binary --adjust-vma=$(RCAR_VMA_ADJUST_ADDR) --srec-forceS3  $(OUTPUT_FILE_SA0) $(FILE_NAME_SA0).bin
102*91f16700Schasinglulu
103*91f16700Schasinglulu$(OUTPUT_FILE_SA6) : $(MEMORY_DEF_SA6) $(OBJ_FILE_SA6)
104*91f16700Schasinglulu	$(LD) $(OBJ_FILE_SA6)		 	\
105*91f16700Schasinglulu	-T $(MEMORY_DEF_SA6)			\
106*91f16700Schasinglulu	-o $(OUTPUT_FILE_SA6)			\
107*91f16700Schasinglulu	-Map $(FILE_NAME_SA6).map 		\
108*91f16700Schasinglulu
109*91f16700Schasinglulu	$(objcopy) -O srec --adjust-vma=$(RCAR_VMA_ADJUST_ADDR) --srec-forceS3  $(OUTPUT_FILE_SA6) $(FILE_NAME_SA6).srec
110*91f16700Schasinglulu	$(objcopy) -O binary --adjust-vma=$(RCAR_VMA_ADJUST_ADDR) --srec-forceS3  $(OUTPUT_FILE_SA6) $(FILE_NAME_SA6).bin
111*91f16700Schasinglulu
112*91f16700Schasinglulu###################################################
113*91f16700Schasinglulu# Compile
114*91f16700Schasinglulu###################################################
115*91f16700Schasinglulu
116*91f16700Schasinglulu%.o:../%.c
117*91f16700Schasinglulu	$(CC) -c -I $< -o $@
118*91f16700Schasinglulu
119*91f16700Schasinglulu.PHONY: clean
120*91f16700Schasingluluclean:
121*91f16700Schasinglulu	$(CL)  *.bin *.map *.srec *.elf *.o
122