blob: d4be0c7350dcf7b8d8a09c31cf68fd6713510778 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001# SPDX-License-Identifier: GPL-2.0+
wdenk717b5aa2002-04-27 11:09:31 +00002#
Marian Balakowiczf9328632006-09-01 19:49:50 +02003# (C) Copyright 2000-2006
wdenk717b5aa2002-04-27 11:09:31 +00004# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
wdenk717b5aa2002-04-27 11:09:31 +00005
Masahiro Yamada4a20df32014-02-04 17:24:12 +09006extra-y := hello_world
7extra-$(CONFIG_SMC91111) += smc91111_eeprom
Masahiro Yamada4a20df32014-02-04 17:24:12 +09008extra-$(CONFIG_SPI_FLASH_ATMEL) += atmel_df_pow2
Masahiro Yamada4a20df32014-02-04 17:24:12 +09009extra-$(CONFIG_PPC) += sched
Mike Frysinger65f6f072009-07-23 16:37:03 -040010
Sanjeev Premi604f7ce2009-11-09 22:43:00 +053011#
12# Some versions of make do not handle trailing white spaces properly;
13# leading to build failures. The problem was found with GNU Make 3.80.
14# Using 'strip' as a workaround for the problem.
15#
Masahiro Yamada4a20df32014-02-04 17:24:12 +090016ELF := $(strip $(extra-y))
Sanjeev Premi604f7ce2009-11-09 22:43:00 +053017
Masahiro Yamada4a20df32014-02-04 17:24:12 +090018extra-y += $(addsuffix .srec,$(extra-y)) $(addsuffix .bin,$(extra-y))
Masahiro Yamada8e714432014-09-05 01:56:52 +090019clean-files := *.srec *.bin
Masahiro Yamada4a20df32014-02-04 17:24:12 +090020
Mike Frysinger557555f2009-09-04 19:54:45 -040021COBJS := $(ELF:=.o)
wdenk717b5aa2002-04-27 11:09:31 +000022
Masahiro Yamada9e414032014-02-04 17:24:24 +090023LIB = $(obj)/libstubs.o
Mike Frysinger557555f2009-09-04 19:54:45 -040024
Masahiro Yamada04a34c92014-02-24 11:12:19 +090025LIBOBJS-$(CONFIG_PPC) += ppc_longjmp.o ppc_setjmp.o
Masahiro Yamada04a34c92014-02-24 11:12:19 +090026LIBOBJS-y += stubs.o
Marian Balakowiczf9328632006-09-01 19:49:50 +020027
Masahiro Yamada04a34c92014-02-24 11:12:19 +090028targets += $(patsubst $(obj)/%,%,$(LIB)) $(COBJS) $(LIBOBJS-y)
Masahiro Yamada6825a952014-02-04 17:24:28 +090029
Masahiro Yamada04a34c92014-02-24 11:12:19 +090030LIBOBJS := $(addprefix $(obj)/,$(LIBOBJS-y))
Masahiro Yamada9e414032014-02-04 17:24:24 +090031ELF := $(addprefix $(obj)/,$(ELF))
wdenk717b5aa2002-04-27 11:09:31 +000032
Peter Tyser620bbba2010-06-15 21:48:25 +020033# For PowerPC there's no need to compile standalone applications as a
34# relocatable executable. The relocation data is not needed, and
35# also causes the entry point of the standalone application to be
36# inconsistent.
Masahiro Yamada026f9cf2014-03-05 16:59:40 +090037ifeq ($(CONFIG_PPC),y)
38PLATFORM_CPPFLAGS := $(filter-out $(RELFLAGS),$(PLATFORM_CPPFLAGS))
Peter Tyser620bbba2010-06-15 21:48:25 +020039endif
40
Peter Tyserc91d4562010-09-12 17:38:49 -050041# We don't want gcc reordering functions if possible. This ensures that an
42# application's entry point will be the first function in the application's
43# source file.
Masahiro Yamada6825a952014-02-04 17:24:28 +090044ccflags-y += $(call cc-option,-fno-toplevel-reorder)
wdenk717b5aa2002-04-27 11:09:31 +000045
Daniel Schwierzeck1d3b97c2018-09-23 19:15:15 +020046LDFLAGS_STANDALONE += -Ttext $(CONFIG_STANDALONE_LOAD_ADDR)
47
wdenk717b5aa2002-04-27 11:09:31 +000048#########################################################################
Masahiro Yamada6825a952014-02-04 17:24:28 +090049
50quiet_cmd_link_lib = LD $@
51 cmd_link_lib = $(LD) $(ld_flags) -r -o $@ $(filter $(LIBOBJS), $^)
52
53$(LIB): $(LIBOBJS) FORCE
54 $(call if_changed,link_lib)
wdenk717b5aa2002-04-27 11:09:31 +000055
Masahiro Yamada04a34c92014-02-24 11:12:19 +090056quiet_cmd_link_elf = LD $@
Tom Rini587e4a42020-03-27 11:46:27 -040057 cmd_link_elf = $(LD) $(KBUILD_LDFLAGS) $(LDFLAGS_STANDALONE) -g \
Alexey Brodkine75e73d2014-05-16 12:54:17 +040058 -o $@ -e $(SYM_PREFIX)$(@F) $< $(LIB) $(PLATFORM_LIBGCC)
Masahiro Yamada04a34c92014-02-24 11:12:19 +090059
60$(ELF): $(obj)/%: $(obj)/%.o $(LIB) FORCE
61 $(call if_changed,link_elf)
Wolfgang Denk96582982006-10-24 13:55:18 +020062
Daniel Schwierzeckd3a9ba72018-09-23 19:15:16 +020063$(obj)/%.srec: OBJCOPYFLAGS += -O srec
Masahiro Yamadaf9c235f2014-02-24 11:12:14 +090064$(obj)/%.srec: $(obj)/% FORCE
65 $(call if_changed,objcopy)
wdenk717b5aa2002-04-27 11:09:31 +000066
Daniel Schwierzeckd3a9ba72018-09-23 19:15:16 +020067$(obj)/%.bin: OBJCOPYFLAGS += -O binary
Masahiro Yamadaf9c235f2014-02-24 11:12:14 +090068$(obj)/%.bin: $(obj)/% FORCE
69 $(call if_changed,objcopy)
Albert ARIBAUD62e92072015-10-23 18:06:40 +020070
71# some files can only build in ARM or THUMB2, not THUMB1
72
73ifdef CONFIG_SYS_THUMB_BUILD
74ifndef CONFIG_HAS_THUMB2
75
76CFLAGS_stubs.o := -marm
77
78endif
79endif