hc
2024-05-10 23fa18eaa71266feff7ba8d83022d9e1cc83c65a
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
ifeq (,$(shlibuuid))
$(error SHLIBUUID not set)
endif
link-out-dir = $(out-dir)
 
SIGN ?= $(TA_DEV_KIT_DIR)/scripts/sign_encrypt.py
#TA_SIGN_KEY ?= $(TA_DEV_KIT_DIR)/keys/default_ta.pem
TA_SIGN_KEY := $(TA_DEV_KIT_DIR)/keys/rk_privkey.pem
 
ifneq ($(TA_SIGN_KEY), $(wildcard $(TA_SIGN_KEY)))
TA_SIGN_KEY := $(TA_DEV_KIT_DIR)/keys/oem_privkey.pem
endif
 
all: $(link-out-dir)/$(shlibname).so $(link-out-dir)/$(shlibname).dmp \
   $(link-out-dir)/$(shlibname).stripped.so \
   $(link-out-dir)/$(shlibuuid).elf \
   $(link-out-dir)/$(shlibuuid).ta
 
cleanfiles += $(link-out-dir)/$(shlibname).so
cleanfiles += $(link-out-dir)/$(shlibname).dmp
cleanfiles += $(link-out-dir)/$(shlibname).stripped.so
cleanfiles += $(link-out-dir)/$(shlibuuid).elf
cleanfiles += $(link-out-dir)/$(shlibuuid).ta
 
shlink-ldflags  = $(LDFLAGS)
shlink-ldflags += -shared -z max-page-size=4096
shlink-ldflags += $(call ld-option,-z separate-loadable-segments)
shlink-ldflags += --as-needed # Do not add dependency on unused shlib
 
shlink-ldadd  = $(LDADD)
shlink-ldadd += $(addprefix -L,$(libdirs))
shlink-ldadd += --start-group $(addprefix -l,$(libnames)) --end-group
ldargs-$(shlibname).so := $(shlink-ldflags) $(objs) $(shlink-ldadd) $(libgcc$(sm))
 
 
$(link-out-dir)/$(shlibname).so: $(objs) $(libdeps)
   @$(cmd-echo-silent) '  LD      $@'
   $(q)$(LD$(sm)) $(ldargs-$(shlibname).so) --soname=$(shlibuuid) -o $@
 
$(link-out-dir)/$(shlibname).dmp: $(link-out-dir)/$(shlibname).so
   @$(cmd-echo-silent) '  OBJDUMP $@'
   $(q)$(OBJDUMP$(sm)) -l -x -d $< > $@
 
$(link-out-dir)/$(shlibname).stripped.so: $(link-out-dir)/$(shlibname).so
   @$(cmd-echo-silent) '  OBJCOPY $@'
   $(q)$(OBJCOPY$(sm)) --strip-unneeded $< $@
 
$(link-out-dir)/$(shlibuuid).elf: $(link-out-dir)/$(shlibname).so
   @$(cmd-echo-silent) '  LN      $@'
   $(q)ln -sf $(<F) $@
 
$(link-out-dir)/$(shlibuuid).ta: $(link-out-dir)/$(shlibname).stripped.so \
               $(TA_SIGN_KEY)
   @$(cmd-echo-silent) '  SIGN    $@'
   $(q)$(PYTHON3) $(SIGN) --key $(TA_SIGN_KEY) --uuid $(shlibuuid) \
       --in $< --out $@