Makefile 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. # SPDX-License-Identifier: GPL-2.0
  2. #
  3. # linux/arch/arm/boot/compressed/Makefile
  4. #
  5. # create a compressed vmlinuz image from the original vmlinux
  6. #
  7. OBJS =
  8. AFLAGS_head.o += -DTEXT_OFFSET=$(TEXT_OFFSET)
  9. HEAD = head.o
  10. OBJS += misc.o decompress.o
  11. ifeq ($(CONFIG_DEBUG_UNCOMPRESS),y)
  12. OBJS += debug.o
  13. endif
  14. FONTC = $(srctree)/lib/fonts/font_acorn_8x8.c
  15. # string library code (-Os is enforced to keep it much smaller)
  16. OBJS += string.o
  17. CFLAGS_string.o := -Os
  18. ifeq ($(CONFIG_ARM_VIRT_EXT),y)
  19. OBJS += hyp-stub.o
  20. endif
  21. GCOV_PROFILE := n
  22. # Prevents link failures: __sanitizer_cov_trace_pc() is not linked in.
  23. KCOV_INSTRUMENT := n
  24. #
  25. # Architecture dependencies
  26. #
  27. ifeq ($(CONFIG_ARCH_ACORN),y)
  28. OBJS += ll_char_wr.o font.o
  29. endif
  30. ifeq ($(CONFIG_ARCH_SA1100),y)
  31. OBJS += head-sa1100.o
  32. endif
  33. ifeq ($(CONFIG_CPU_XSCALE),y)
  34. OBJS += head-xscale.o
  35. endif
  36. ifeq ($(CONFIG_PXA_SHARPSL_DETECT_MACH_ID),y)
  37. OBJS += head-sharpsl.o
  38. endif
  39. ifeq ($(CONFIG_CPU_ENDIAN_BE32),y)
  40. ifeq ($(CONFIG_CPU_CP15),y)
  41. OBJS += big-endian.o
  42. else
  43. # The endian should be set by h/w design.
  44. endif
  45. endif
  46. #
  47. # We now have a PIC decompressor implementation. Decompressors running
  48. # from RAM should not define ZTEXTADDR. Decompressors running directly
  49. # from ROM or Flash must define ZTEXTADDR (preferably via the config)
  50. # FIXME: Previous assignment to ztextaddr-y is lost here. See SHARK
  51. ifeq ($(CONFIG_ZBOOT_ROM),y)
  52. ZTEXTADDR := $(CONFIG_ZBOOT_ROM_TEXT)
  53. ZBSSADDR := $(CONFIG_ZBOOT_ROM_BSS)
  54. else
  55. ZTEXTADDR := 0
  56. ZBSSADDR := ALIGN(8)
  57. endif
  58. CPPFLAGS_vmlinux.lds := -DTEXT_START="$(ZTEXTADDR)" -DBSS_START="$(ZBSSADDR)"
  59. compress-$(CONFIG_KERNEL_GZIP) = gzip
  60. compress-$(CONFIG_KERNEL_LZO) = lzo
  61. compress-$(CONFIG_KERNEL_LZMA) = lzma
  62. compress-$(CONFIG_KERNEL_XZ) = xzkern
  63. compress-$(CONFIG_KERNEL_LZ4) = lz4
  64. # Borrowed libfdt files for the ATAG compatibility mode
  65. libfdt := fdt_rw.c fdt_ro.c fdt_wip.c fdt.c
  66. libfdt_hdrs := fdt.h libfdt.h libfdt_internal.h
  67. libfdt_objs := $(addsuffix .o, $(basename $(libfdt)))
  68. $(addprefix $(obj)/,$(libfdt) $(libfdt_hdrs)): $(obj)/%: $(srctree)/scripts/dtc/libfdt/%
  69. $(call cmd,shipped)
  70. $(addprefix $(obj)/,$(libfdt_objs) atags_to_fdt.o): \
  71. $(addprefix $(obj)/,$(libfdt_hdrs))
  72. ifeq ($(CONFIG_ARM_ATAG_DTB_COMPAT),y)
  73. OBJS += $(libfdt_objs) atags_to_fdt.o
  74. endif
  75. targets := vmlinux vmlinux.lds piggy_data piggy.o \
  76. lib1funcs.o ashldi3.o bswapsdi2.o \
  77. head.o $(OBJS)
  78. clean-files += piggy_data lib1funcs.S ashldi3.S bswapsdi2.S \
  79. $(libfdt) $(libfdt_hdrs) hyp-stub.S
  80. KBUILD_CFLAGS += -DDISABLE_BRANCH_PROFILING
  81. ifeq ($(CONFIG_FUNCTION_TRACER),y)
  82. ORIG_CFLAGS := $(KBUILD_CFLAGS)
  83. KBUILD_CFLAGS = $(subst -pg, , $(ORIG_CFLAGS))
  84. endif
  85. # -fstack-protector-strong triggers protection checks in this code,
  86. # but it is being used too early to link to meaningful stack_chk logic.
  87. nossp_flags := $(call cc-option, -fno-stack-protector)
  88. CFLAGS_atags_to_fdt.o := $(nossp_flags)
  89. CFLAGS_fdt.o := $(nossp_flags)
  90. CFLAGS_fdt_ro.o := $(nossp_flags)
  91. CFLAGS_fdt_rw.o := $(nossp_flags)
  92. CFLAGS_fdt_wip.o := $(nossp_flags)
  93. ccflags-y := -fpic $(call cc-option,-mno-single-pic-base,) -fno-builtin -I$(obj)
  94. asflags-y := -DZIMAGE
  95. # Supply kernel BSS size to the decompressor via a linker symbol.
  96. KBSS_SZ = $(shell echo $$(($$($(CROSS_COMPILE)nm $(obj)/../../../../vmlinux | \
  97. sed -n -e 's/^\([^ ]*\) [AB] __bss_start$$/-0x\1/p' \
  98. -e 's/^\([^ ]*\) [AB] __bss_stop$$/+0x\1/p') )) )
  99. LDFLAGS_vmlinux = --defsym _kernel_bss_size=$(KBSS_SZ)
  100. # Supply ZRELADDR to the decompressor via a linker symbol.
  101. ifneq ($(CONFIG_AUTO_ZRELADDR),y)
  102. LDFLAGS_vmlinux += --defsym zreladdr=$(ZRELADDR)
  103. endif
  104. ifeq ($(CONFIG_CPU_ENDIAN_BE8),y)
  105. LDFLAGS_vmlinux += --be8
  106. endif
  107. # ?
  108. LDFLAGS_vmlinux += -p
  109. # Report unresolved symbol references
  110. LDFLAGS_vmlinux += --no-undefined
  111. # Delete all temporary local symbols
  112. LDFLAGS_vmlinux += -X
  113. # Next argument is a linker script
  114. LDFLAGS_vmlinux += -T
  115. # For __aeabi_uidivmod
  116. lib1funcs = $(obj)/lib1funcs.o
  117. $(obj)/lib1funcs.S: $(srctree)/arch/$(SRCARCH)/lib/lib1funcs.S
  118. $(call cmd,shipped)
  119. # For __aeabi_llsl
  120. ashldi3 = $(obj)/ashldi3.o
  121. $(obj)/ashldi3.S: $(srctree)/arch/$(SRCARCH)/lib/ashldi3.S
  122. $(call cmd,shipped)
  123. # For __bswapsi2, __bswapdi2
  124. bswapsdi2 = $(obj)/bswapsdi2.o
  125. $(obj)/bswapsdi2.S: $(srctree)/arch/$(SRCARCH)/lib/bswapsdi2.S
  126. $(call cmd,shipped)
  127. # We need to prevent any GOTOFF relocs being used with references
  128. # to symbols in the .bss section since we cannot relocate them
  129. # independently from the rest at run time. This can be achieved by
  130. # ensuring that no private .bss symbols exist, as global symbols
  131. # always have a GOT entry which is what we need.
  132. # The .data section is already discarded by the linker script so no need
  133. # to bother about it here.
  134. check_for_bad_syms = \
  135. bad_syms=$$($(CROSS_COMPILE)nm $@ | sed -n 's/^.\{8\} [bc] \(.*\)/\1/p') && \
  136. [ -z "$$bad_syms" ] || \
  137. ( echo "following symbols must have non local/private scope:" >&2; \
  138. echo "$$bad_syms" >&2; rm -f $@; false )
  139. check_for_multiple_zreladdr = \
  140. if [ $(words $(ZRELADDR)) -gt 1 -a "$(CONFIG_AUTO_ZRELADDR)" = "" ]; then \
  141. echo 'multiple zreladdrs: $(ZRELADDR)'; \
  142. echo 'This needs CONFIG_AUTO_ZRELADDR to be set'; \
  143. false; \
  144. fi
  145. efi-obj-$(CONFIG_EFI_STUB) := $(objtree)/drivers/firmware/efi/libstub/lib.a
  146. $(obj)/vmlinux: $(obj)/vmlinux.lds $(obj)/$(HEAD) $(obj)/piggy.o \
  147. $(addprefix $(obj)/, $(OBJS)) $(lib1funcs) $(ashldi3) \
  148. $(bswapsdi2) $(efi-obj-y) FORCE
  149. @$(check_for_multiple_zreladdr)
  150. $(call if_changed,ld)
  151. @$(check_for_bad_syms)
  152. $(obj)/piggy_data: $(obj)/../Image FORCE
  153. $(call if_changed,$(compress-y))
  154. $(obj)/piggy.o: $(obj)/piggy_data
  155. CFLAGS_font.o := -Dstatic=
  156. $(obj)/font.c: $(FONTC)
  157. $(call cmd,shipped)
  158. AFLAGS_hyp-stub.o := -Wa,-march=armv7-a
  159. $(obj)/hyp-stub.S: $(srctree)/arch/$(SRCARCH)/kernel/hyp-stub.S
  160. $(call cmd,shipped)