xref: /optee_os/ldelf/link.mk (revision 5b2aaa117eee65e8c31abd3f2e4069bf6b902bf7)
1link-script$(sm) = ldelf/ldelf.ld.S
2link-script-pp$(sm) = $(link-out-dir$(sm))/ldelf.lds
3link-script-dep$(sm) = $(link-out-dir$(sm))/.ldelf.ld.d
4
5.PHONY: ldelf
6ldelf: $(link-out-dir$(sm))/ldelf.dmp
7ldelf: $(link-out-dir$(sm))/ldelf.elf
8all: ldelf
9
10cleanfiles += $(link-out-dir$(sm))/ldelf.dmp
11cleanfiles += $(link-out-dir$(sm))/ldelf.map
12cleanfiles += $(link-out-dir$(sm))/ldelf.elf
13cleanfiles += $(link-script-pp$(sm)) $(link-script-dep$(sm))
14
15link-ldflags  = -pie -static --gc-sections
16link-ldflags += -T $(link-script-pp$(sm))
17link-ldflags += -Map=$(link-out-dir$(sm))/ldelf.map
18link-ldflags += --sort-section=alignment
19link-ldflags += -z max-page-size=4096 # OP-TEE always uses 4K alignment
20link-ldflags += $(link-ldflags$(sm))
21
22link-ldadd  = $(addprefix -L,$(libdirs))
23link-ldadd += --start-group $(addprefix -l,$(libnames)) --end-group
24ldargs-ldelf.elf := $(link-ldflags) $(objs) $(link-ldadd)
25
26link-script-cppflags-$(sm) := \
27	$(filter-out $(CPPFLAGS_REMOVE) $(cppflags-remove), \
28		$(nostdinc$(sm)) $(CPPFLAGS) \
29		$(addprefix -I,$(incdirs$(sm)) $(link-out-dir$(sm))) \
30		$(cppflags$(sm)))
31
32-include $(link-script-dep$(sm))
33
34link-script-pp-makefiles$(sm) = $(filter-out %.d %.cmd,$(MAKEFILE_LIST))
35
36define gen-link-t
37$(link-script-pp$(sm)): $(link-script$(sm)) $(conf-file) \
38			$(link-script-pp-makefiles$(sm))
39	@$(cmd-echo-silent) '  CPP     $$@'
40	$(q)mkdir -p $$(dir $$@)
41	$(q)$(CPP$(sm)) -P -MT $$@ -MD -MF $(link-script-dep$(sm)) \
42		$(link-script-cppflags-$(sm)) $$< -o $$@
43
44$(link-out-dir$(sm))/ldelf.elf: $(objs) $(libdeps) $(link-script-pp$(sm))
45	@$(cmd-echo-silent) '  LD      $$@'
46	$(q)$(LD$(sm)) $(ldargs-ldelf.elf) -o $$@
47
48$(link-out-dir$(sm))/ldelf.dmp: $(link-out-dir$(sm))/ldelf.elf
49	@$(cmd-echo-silent) '  OBJDUMP $$@'
50	$(q)$(OBJDUMP$(sm)) -l -x -d $$< > $$@
51endef
52
53$(eval $(call gen-link-t))
54