Makefile 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. #
  2. # This file is subject to the terms and conditions of the GNU General Public
  3. # License.
  4. #
  5. # Adapted for MIPS Pete Popov, Dan Malek
  6. #
  7. # Copyright (C) 1994 by Linus Torvalds
  8. # Adapted for PowerPC by Gary Thomas
  9. # modified by Cort (cort@cs.nmt.edu)
  10. #
  11. # Copyright (C) 2009 Lemote Inc. & DSLab, Lanzhou University
  12. # Author: Wu Zhangjin <wuzhangjin@gmail.com>
  13. #
  14. # set the default size of the mallocing area for decompressing
  15. BOOT_HEAP_SIZE := 0x400000
  16. # Disable Function Tracer
  17. KBUILD_CFLAGS := $(shell echo $(KBUILD_CFLAGS) | sed -e "s/-pg//")
  18. KBUILD_CFLAGS := $(LINUXINCLUDE) $(KBUILD_CFLAGS) -D__KERNEL__ \
  19. -DBOOT_HEAP_SIZE=$(BOOT_HEAP_SIZE) -D"VMLINUX_LOAD_ADDRESS_ULL=$(VMLINUX_LOAD_ADDRESS)ull"
  20. KBUILD_AFLAGS := $(LINUXINCLUDE) $(KBUILD_AFLAGS) -D__ASSEMBLY__ \
  21. -DBOOT_HEAP_SIZE=$(BOOT_HEAP_SIZE) \
  22. -DKERNEL_ENTRY=0x$(shell $(NM) $(objtree)/$(KBUILD_IMAGE) 2>/dev/null | grep " kernel_entry" | cut -f1 -d \ )
  23. targets := head.o decompress.o dbg.o uart-16550.o uart-alchemy.o
  24. # decompressor objects (linked with vmlinuz)
  25. vmlinuzobjs-y := $(obj)/head.o $(obj)/decompress.o $(obj)/dbg.o
  26. ifdef CONFIG_DEBUG_ZBOOT
  27. vmlinuzobjs-$(CONFIG_SYS_SUPPORTS_ZBOOT_UART16550) += $(obj)/uart-16550.o
  28. vmlinuzobjs-$(CONFIG_MIPS_ALCHEMY) += $(obj)/uart-alchemy.o
  29. endif
  30. targets += vmlinux.bin
  31. OBJCOPYFLAGS_vmlinux.bin := $(OBJCOPYFLAGS) -O binary -R .comment -S
  32. $(obj)/vmlinux.bin: $(KBUILD_IMAGE) FORCE
  33. $(call if_changed,objcopy)
  34. tool_$(CONFIG_KERNEL_GZIP) = gzip
  35. tool_$(CONFIG_KERNEL_BZIP2) = bzip2
  36. tool_$(CONFIG_KERNEL_LZMA) = lzma
  37. tool_$(CONFIG_KERNEL_LZO) = lzo
  38. targets += vmlinux.bin.z
  39. $(obj)/vmlinux.bin.z: $(obj)/vmlinux.bin FORCE
  40. $(call if_changed,$(tool_y))
  41. targets += piggy.o
  42. OBJCOPYFLAGS_piggy.o := --add-section=.image=$(obj)/vmlinux.bin.z \
  43. --set-section-flags=.image=contents,alloc,load,readonly,data
  44. $(obj)/piggy.o: $(obj)/dummy.o $(obj)/vmlinux.bin.z FORCE
  45. $(call if_changed,objcopy)
  46. # Calculate the load address of the compressed kernel image
  47. hostprogs-y := calc_vmlinuz_load_addr
  48. VMLINUZ_LOAD_ADDRESS = $(shell $(obj)/calc_vmlinuz_load_addr \
  49. $(objtree)/$(KBUILD_IMAGE) $(VMLINUX_LOAD_ADDRESS))
  50. vmlinuzobjs-y += $(obj)/piggy.o
  51. quiet_cmd_zld = LD $@
  52. cmd_zld = $(LD) $(LDFLAGS) -Ttext $(VMLINUZ_LOAD_ADDRESS) -T $< $(vmlinuzobjs-y) -o $@
  53. vmlinuz: $(src)/ld.script $(vmlinuzobjs-y) $(obj)/calc_vmlinuz_load_addr
  54. $(call cmd,zld)
  55. #
  56. # Some DECstations need all possible sections of an ECOFF executable
  57. #
  58. ifdef CONFIG_MACH_DECSTATION
  59. e2eflag := -a
  60. endif
  61. # elf2ecoff can only handle 32bit image
  62. hostprogs-y += ../elf2ecoff
  63. ifdef CONFIG_32BIT
  64. VMLINUZ = vmlinuz
  65. else
  66. VMLINUZ = vmlinuz.32
  67. endif
  68. quiet_cmd_32 = OBJCOPY $@
  69. cmd_32 = $(OBJCOPY) -O $(32bit-bfd) $(OBJCOPYFLAGS) $< $@
  70. vmlinuz.32: vmlinuz
  71. $(call cmd,32)
  72. quiet_cmd_ecoff = ECOFF $@
  73. cmd_ecoff = $< $(VMLINUZ) $@ $(e2eflag)
  74. vmlinuz.ecoff: $(obj)/../elf2ecoff $(VMLINUZ)
  75. $(call cmd,ecoff)
  76. OBJCOPYFLAGS_vmlinuz.bin := $(OBJCOPYFLAGS) -O binary
  77. vmlinuz.bin: vmlinuz
  78. $(call cmd,objcopy)
  79. OBJCOPYFLAGS_vmlinuz.srec := $(OBJCOPYFLAGS) -S -O srec
  80. vmlinuz.srec: vmlinuz
  81. $(call cmd,objcopy)
  82. clean-files := $(objtree)/vmlinuz.*