xref: /rk3399_rockchip-uboot/examples/standalone/Makefile (revision 8386ca8bea7a6a8469c3b6a99313afb642e6cbeb)
11bc15386SPeter Tyser#
21bc15386SPeter Tyser# (C) Copyright 2000-2006
31bc15386SPeter Tyser# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
41bc15386SPeter Tyser#
51a459660SWolfgang Denk# SPDX-License-Identifier:	GPL-2.0+
61bc15386SPeter Tyser#
71bc15386SPeter Tyser
81bc15386SPeter Tyserinclude $(TOPDIR)/config.mk
91bc15386SPeter Tyser
10557555feSMike FrysingerELF-$(ARCH)  :=
11557555feSMike FrysingerELF-$(BOARD) :=
12557555feSMike FrysingerELF-$(CPU)   :=
13557555feSMike FrysingerELF-y        := hello_world
141bc15386SPeter Tyser
15557555feSMike FrysingerELF-$(CONFIG_SMC91111)           += smc91111_eeprom
16557555feSMike FrysingerELF-$(CONFIG_SMC911X)            += smc911x_eeprom
17557555feSMike FrysingerELF-$(CONFIG_SPI_FLASH_ATMEL)    += atmel_df_pow2
18557555feSMike FrysingerELF-i386                         += 82559_eeprom
19557555feSMike FrysingerELF-mpc5xxx                      += interrupt
20557555feSMike FrysingerELF-mpc8xx                       += test_burst timer
21557555feSMike FrysingerELF-mpc8260                      += mem_to_mem_idma2intr
22557555feSMike FrysingerELF-ppc                          += sched
23557555feSMike FrysingerELF-oxc                          += eepro100_eeprom
2465f6f07bSMike Frysinger
25604f7ce5SSanjeev Premi#
26604f7ce5SSanjeev Premi# Some versions of make do not handle trailing white spaces properly;
27604f7ce5SSanjeev Premi# leading to build failures. The problem was found with GNU Make 3.80.
28604f7ce5SSanjeev Premi# Using 'strip' as a workaround for the problem.
29604f7ce5SSanjeev Premi#
30604f7ce5SSanjeev PremiELF := $(strip $(ELF-y) $(ELF-$(ARCH)) $(ELF-$(BOARD)) $(ELF-$(CPU)))
31604f7ce5SSanjeev Premi
320da43893SChe-liang ChiouSREC := $(addsuffix .srec,$(ELF))
330da43893SChe-liang ChiouBIN  := $(addsuffix .bin,$(ELF))
341bc15386SPeter Tyser
35557555feSMike FrysingerCOBJS	:= $(ELF:=.o)
361bc15386SPeter Tyser
376d8962e8SSebastien CarlierLIB	= $(obj)libstubs.o
38557555feSMike Frysinger
39557555feSMike FrysingerLIBAOBJS-$(ARCH)     :=
40557555feSMike FrysingerLIBAOBJS-$(CPU)      :=
41557555feSMike FrysingerLIBAOBJS-ppc         += $(ARCH)_longjmp.o $(ARCH)_setjmp.o
42557555feSMike FrysingerLIBAOBJS-mpc8xx      += test_burst_lib.o
43557555feSMike FrysingerLIBAOBJS := $(LIBAOBJS-$(ARCH)) $(LIBAOBJS-$(CPU))
44557555feSMike Frysinger
451bc15386SPeter TyserLIBCOBJS = stubs.o
461bc15386SPeter Tyser
471bc15386SPeter TyserLIBOBJS	= $(addprefix $(obj),$(LIBAOBJS) $(LIBCOBJS))
481bc15386SPeter Tyser
49557555feSMike FrysingerSRCS	:= $(COBJS:.o=.c) $(LIBCOBJS:.o=.c) $(LIBAOBJS:.o=.S)
501bc15386SPeter TyserOBJS	:= $(addprefix $(obj),$(COBJS))
511bc15386SPeter TyserELF	:= $(addprefix $(obj),$(ELF))
521bc15386SPeter TyserBIN	:= $(addprefix $(obj),$(BIN))
531bc15386SPeter TyserSREC	:= $(addprefix $(obj),$(SREC))
541bc15386SPeter Tyser
55*8386ca8bSTom Rinigcclibdir := $(shell dirname `$(CC) -print-libgcc-file-name`)
561bc15386SPeter Tyser
571bc15386SPeter TyserCPPFLAGS += -I..
581bc15386SPeter Tyser
59620bbba5SPeter Tyser# For PowerPC there's no need to compile standalone applications as a
60620bbba5SPeter Tyser# relocatable executable.  The relocation data is not needed, and
61620bbba5SPeter Tyser# also causes the entry point of the standalone application to be
62620bbba5SPeter Tyser# inconsistent.
63620bbba5SPeter Tyserifeq ($(ARCH),powerpc)
64620bbba5SPeter TyserAFLAGS := $(filter-out $(RELFLAGS),$(AFLAGS))
65620bbba5SPeter TyserCFLAGS := $(filter-out $(RELFLAGS),$(CFLAGS))
66620bbba5SPeter TyserCPPFLAGS := $(filter-out $(RELFLAGS),$(CPPFLAGS))
67620bbba5SPeter Tyserendif
68620bbba5SPeter Tyser
69c91d456cSPeter Tyser# We don't want gcc reordering functions if possible.  This ensures that an
70c91d456cSPeter Tyser# application's entry point will be the first function in the application's
71c91d456cSPeter Tyser# source file.
72cca4e4aeSWolfgang DenkCFLAGS_NTR := $(call cc-option,-fno-toplevel-reorder)
73cca4e4aeSWolfgang DenkCFLAGS += $(CFLAGS_NTR)
74c91d456cSPeter Tyser
751bc15386SPeter Tyserall:	$(obj).depend $(OBJS) $(LIB) $(SREC) $(BIN) $(ELF)
761bc15386SPeter Tyser
771bc15386SPeter Tyser#########################################################################
781bc15386SPeter Tyser$(LIB):	$(obj).depend $(LIBOBJS)
796d8962e8SSebastien Carlier	$(call cmd_link_o_target, $(LIBOBJS))
801bc15386SPeter Tyser
811bc15386SPeter Tyser$(ELF):
821bc15386SPeter Tyser$(obj)%:	$(obj)%.o $(LIB)
83e0e7f3b2SMarek Vasut		$(LD) $(LDFLAGS) -g -Ttext $(CONFIG_STANDALONE_LOAD_ADDR) \
841bc15386SPeter Tyser			-o $@ -e $(SYM_PREFIX)$(notdir $(<:.o=)) $< $(LIB) \
85*8386ca8bSTom Rini			-L$(gcclibdir) -lgcc
861bc15386SPeter Tyser
871bc15386SPeter Tyser$(SREC):
881bc15386SPeter Tyser$(obj)%.srec:	$(obj)%
891bc15386SPeter Tyser		$(OBJCOPY) -O srec $< $@ 2>/dev/null
901bc15386SPeter Tyser
911bc15386SPeter Tyser$(BIN):
921bc15386SPeter Tyser$(obj)%.bin:	$(obj)%
931bc15386SPeter Tyser		$(OBJCOPY) -O binary $< $@ 2>/dev/null
941bc15386SPeter Tyser
951bc15386SPeter Tyser#########################################################################
961bc15386SPeter Tyser
971bc15386SPeter Tyser# defines $(obj).depend target
981bc15386SPeter Tyserinclude $(SRCTREE)/rules.mk
991bc15386SPeter Tyser
1001bc15386SPeter Tysersinclude $(obj).depend
1011bc15386SPeter Tyser
1021bc15386SPeter Tyser#########################################################################
103