]> git.ipfire.org Git - people/ms/u-boot.git/blob - examples/standalone/Makefile
Makefile: Select objects by CONFIG_ rather than $(ARCH) or $(CPU)
[people/ms/u-boot.git] / examples / standalone / Makefile
1 #
2 # (C) Copyright 2000-2006
3 # Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4 #
5 # SPDX-License-Identifier: GPL-2.0+
6 #
7
8 include $(TOPDIR)/config.mk
9
10 ELF-y := hello_world
11
12 ELF-$(CONFIG_SMC91111) += smc91111_eeprom
13 ELF-$(CONFIG_SMC911X) += smc911x_eeprom
14 ELF-$(CONFIG_SPI_FLASH_ATMEL) += atmel_df_pow2
15 # TODO:
16 # - Fix the warning of 82559_eeprom.c and uncomment the following
17 # or
18 # - Delete 82559_eeprom.c and the following line
19 #ELF-$(CONFIG_X86) += 82559_eeprom
20 ELF-$(CONFIG_MPC5xxx) += interrupt
21 ELF-$(CONFIG_8xx) += test_burst timer
22 ELF-$(CONFIG_8260) += mem_to_mem_idma2intr
23 ELF-$(CONFIG_PPC) += sched
24
25 #
26 # Some versions of make do not handle trailing white spaces properly;
27 # leading to build failures. The problem was found with GNU Make 3.80.
28 # Using 'strip' as a workaround for the problem.
29 #
30 ELF := $(strip $(ELF-y))
31
32 SREC := $(addsuffix .srec,$(ELF))
33 BIN := $(addsuffix .bin,$(ELF))
34
35 COBJS := $(ELF:=.o)
36
37 LIB = $(obj)libstubs.o
38
39 LIBAOBJS-$(CONFIG_PPC) += ppc_longjmp.o ppc_setjmp.o
40 LIBAOBJS-$(CONFIG_8xx) += test_burst_lib.o
41 LIBAOBJS := $(LIBAOBJS-y)
42
43 LIBCOBJS = stubs.o
44
45 LIBOBJS = $(addprefix $(obj),$(LIBAOBJS) $(LIBCOBJS))
46
47 SRCS := $(COBJS:.o=.c) $(LIBCOBJS:.o=.c) $(LIBAOBJS:.o=.S)
48 OBJS := $(addprefix $(obj),$(COBJS))
49 ELF := $(addprefix $(obj),$(ELF))
50 BIN := $(addprefix $(obj),$(BIN))
51 SREC := $(addprefix $(obj),$(SREC))
52
53 gcclibdir := $(shell dirname `$(CC) -print-libgcc-file-name`)
54
55 # For PowerPC there's no need to compile standalone applications as a
56 # relocatable executable. The relocation data is not needed, and
57 # also causes the entry point of the standalone application to be
58 # inconsistent.
59 ifeq ($(ARCH),powerpc)
60 AFLAGS := $(filter-out $(RELFLAGS),$(AFLAGS))
61 CFLAGS := $(filter-out $(RELFLAGS),$(CFLAGS))
62 CPPFLAGS := $(filter-out $(RELFLAGS),$(CPPFLAGS))
63 endif
64
65 # We don't want gcc reordering functions if possible. This ensures that an
66 # application's entry point will be the first function in the application's
67 # source file.
68 CFLAGS_NTR := $(call cc-option,-fno-toplevel-reorder)
69 CFLAGS += $(CFLAGS_NTR)
70
71 all: $(obj).depend $(OBJS) $(LIB) $(SREC) $(BIN) $(ELF)
72
73 #########################################################################
74 $(LIB): $(obj).depend $(LIBOBJS)
75 $(call cmd_link_o_target, $(LIBOBJS))
76
77 $(ELF):
78 $(obj)%: $(obj)%.o $(LIB)
79 $(LD) $(LDFLAGS) -g -Ttext $(CONFIG_STANDALONE_LOAD_ADDR) \
80 -o $@ -e $(SYM_PREFIX)$(notdir $(<:.o=)) $< $(LIB) \
81 -L$(gcclibdir) -lgcc
82
83 $(SREC):
84 $(obj)%.srec: $(obj)%
85 $(OBJCOPY) -O srec $< $@ 2>/dev/null
86
87 $(BIN):
88 $(obj)%.bin: $(obj)%
89 $(OBJCOPY) -O binary $< $@ 2>/dev/null
90
91 #########################################################################
92
93 # defines $(obj).depend target
94 include $(SRCTREE)/rules.mk
95
96 sinclude $(obj).depend
97
98 #########################################################################