Makefile 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. #
  2. # linux/arch/arm/boot/compressed/Makefile
  3. #
  4. # create a compressed vmlinuz image from the original vmlinux
  5. #
  6. OBJS =
  7. # Ensure that MMCIF loader code appears early in the image
  8. # to minimise that number of bocks that have to be read in
  9. # order to load it.
  10. ifeq ($(CONFIG_ZBOOT_ROM_MMCIF),y)
  11. OBJS += mmcif-sh7372.o
  12. endif
  13. # Ensure that SDHI loader code appears early in the image
  14. # to minimise that number of bocks that have to be read in
  15. # order to load it.
  16. ifeq ($(CONFIG_ZBOOT_ROM_SH_MOBILE_SDHI),y)
  17. OBJS += sdhi-shmobile.o
  18. OBJS += sdhi-sh7372.o
  19. endif
  20. AFLAGS_head.o += -DTEXT_OFFSET=$(TEXT_OFFSET)
  21. HEAD = head.o
  22. OBJS += misc.o decompress.o
  23. FONTC = $(srctree)/drivers/video/console/font_acorn_8x8.c
  24. # string library code (-Os is enforced to keep it much smaller)
  25. OBJS += string.o
  26. CFLAGS_string.o := -Os
  27. #
  28. # Architecture dependencies
  29. #
  30. ifeq ($(CONFIG_ARCH_ACORN),y)
  31. OBJS += ll_char_wr.o font.o
  32. endif
  33. ifeq ($(CONFIG_ARCH_SHARK),y)
  34. OBJS += head-shark.o ofw-shark.o
  35. endif
  36. ifeq ($(CONFIG_ARCH_P720T),y)
  37. # Borrow this code from SA1100
  38. OBJS += head-sa1100.o
  39. endif
  40. ifeq ($(CONFIG_ARCH_SA1100),y)
  41. OBJS += head-sa1100.o
  42. endif
  43. ifeq ($(CONFIG_ARCH_VT8500),y)
  44. OBJS += head-vt8500.o
  45. endif
  46. ifeq ($(CONFIG_CPU_XSCALE),y)
  47. OBJS += head-xscale.o
  48. endif
  49. ifeq ($(CONFIG_PXA_SHARPSL_DETECT_MACH_ID),y)
  50. OBJS += head-sharpsl.o
  51. endif
  52. ifeq ($(CONFIG_CPU_ENDIAN_BE32),y)
  53. ifeq ($(CONFIG_CPU_CP15),y)
  54. OBJS += big-endian.o
  55. else
  56. # The endian should be set by h/w design.
  57. endif
  58. endif
  59. ifeq ($(CONFIG_ARCH_SHMOBILE),y)
  60. OBJS += head-shmobile.o
  61. endif
  62. #
  63. # We now have a PIC decompressor implementation. Decompressors running
  64. # from RAM should not define ZTEXTADDR. Decompressors running directly
  65. # from ROM or Flash must define ZTEXTADDR (preferably via the config)
  66. # FIXME: Previous assignment to ztextaddr-y is lost here. See SHARK
  67. ifeq ($(CONFIG_ZBOOT_ROM),y)
  68. ZTEXTADDR := $(CONFIG_ZBOOT_ROM_TEXT)
  69. ZBSSADDR := $(CONFIG_ZBOOT_ROM_BSS)
  70. else
  71. ZTEXTADDR := 0
  72. ZBSSADDR := ALIGN(8)
  73. endif
  74. SEDFLAGS = s/TEXT_START/$(ZTEXTADDR)/;s/BSS_START/$(ZBSSADDR)/
  75. suffix_$(CONFIG_KERNEL_GZIP) = gzip
  76. suffix_$(CONFIG_KERNEL_LZO) = lzo
  77. suffix_$(CONFIG_KERNEL_LZMA) = lzma
  78. # Borrowed libfdt files for the ATAG compatibility mode
  79. libfdt := fdt_rw.c fdt_ro.c fdt_wip.c fdt.c
  80. libfdt_hdrs := fdt.h libfdt.h libfdt_internal.h
  81. libfdt_objs := $(addsuffix .o, $(basename $(libfdt)))
  82. $(addprefix $(obj)/,$(libfdt) $(libfdt_hdrs)): $(obj)/%: $(srctree)/scripts/dtc/libfdt/%
  83. $(call cmd,shipped)
  84. $(addprefix $(obj)/,$(libfdt_objs) atags_to_fdt.o): \
  85. $(addprefix $(obj)/,$(libfdt_hdrs))
  86. ifeq ($(CONFIG_ARM_ATAG_DTB_COMPAT),y)
  87. OBJS += $(libfdt_objs) atags_to_fdt.o
  88. endif
  89. targets := vmlinux vmlinux.lds \
  90. piggy.$(suffix_y) piggy.$(suffix_y).o \
  91. lib1funcs.o lib1funcs.S font.o font.c head.o misc.o $(OBJS)
  92. # Make sure files are removed during clean
  93. extra-y += piggy.gzip piggy.lzo piggy.lzma lib1funcs.S $(libfdt) $(libfdt_hdrs)
  94. ifeq ($(CONFIG_FUNCTION_TRACER),y)
  95. ORIG_CFLAGS := $(KBUILD_CFLAGS)
  96. KBUILD_CFLAGS = $(subst -pg, , $(ORIG_CFLAGS))
  97. endif
  98. ccflags-y := -fpic -fno-builtin -I$(obj)
  99. asflags-y := -Wa,-march=all
  100. # Supply kernel BSS size to the decompressor via a linker symbol.
  101. KBSS_SZ = $(shell $(CROSS_COMPILE)size $(obj)/../../../../vmlinux | \
  102. awk 'END{print $$3}')
  103. LDFLAGS_vmlinux = --defsym _kernel_bss_size=$(KBSS_SZ)
  104. # Supply ZRELADDR to the decompressor via a linker symbol.
  105. ifneq ($(CONFIG_AUTO_ZRELADDR),y)
  106. LDFLAGS_vmlinux += --defsym zreladdr=$(ZRELADDR)
  107. endif
  108. ifeq ($(CONFIG_CPU_ENDIAN_BE8),y)
  109. LDFLAGS_vmlinux += --be8
  110. endif
  111. # ?
  112. LDFLAGS_vmlinux += -p
  113. # Report unresolved symbol references
  114. LDFLAGS_vmlinux += --no-undefined
  115. # Delete all temporary local symbols
  116. LDFLAGS_vmlinux += -X
  117. # Next argument is a linker script
  118. LDFLAGS_vmlinux += -T
  119. # For __aeabi_uidivmod
  120. lib1funcs = $(obj)/lib1funcs.o
  121. $(obj)/lib1funcs.S: $(srctree)/arch/$(SRCARCH)/lib/lib1funcs.S
  122. $(call cmd,shipped)
  123. # We need to prevent any GOTOFF relocs being used with references
  124. # to symbols in the .bss section since we cannot relocate them
  125. # independently from the rest at run time. This can be achieved by
  126. # ensuring that no private .bss symbols exist, as global symbols
  127. # always have a GOT entry which is what we need.
  128. # The .data section is already discarded by the linker script so no need
  129. # to bother about it here.
  130. check_for_bad_syms = \
  131. bad_syms=$$($(CROSS_COMPILE)nm $@ | sed -n 's/^.\{8\} [bc] \(.*\)/\1/p') && \
  132. [ -z "$$bad_syms" ] || \
  133. ( echo "following symbols must have non local/private scope:" >&2; \
  134. echo "$$bad_syms" >&2; rm -f $@; false )
  135. check_for_multiple_zreladdr = \
  136. if [ $(words $(ZRELADDR)) -gt 1 -a "$(CONFIG_AUTO_ZRELADDR)" = "" ]; then \
  137. echo 'multiple zreladdrs: $(ZRELADDR)'; \
  138. echo 'This needs CONFIG_AUTO_ZRELADDR to be set'; \
  139. false; \
  140. fi
  141. $(obj)/vmlinux: $(obj)/vmlinux.lds $(obj)/$(HEAD) $(obj)/piggy.$(suffix_y).o \
  142. $(addprefix $(obj)/, $(OBJS)) $(lib1funcs) FORCE
  143. @$(check_for_multiple_zreladdr)
  144. $(call if_changed,ld)
  145. @$(check_for_bad_syms)
  146. $(obj)/piggy.$(suffix_y): $(obj)/../Image FORCE
  147. $(call if_changed,$(suffix_y))
  148. $(obj)/piggy.$(suffix_y).o: $(obj)/piggy.$(suffix_y) FORCE
  149. CFLAGS_font.o := -Dstatic=
  150. $(obj)/font.c: $(FONTC)
  151. $(call cmd,shipped)
  152. $(obj)/vmlinux.lds: $(obj)/vmlinux.lds.in arch/arm/boot/Makefile $(KCONFIG_CONFIG)
  153. @sed "$(SEDFLAGS)" < $< > $@