11b93b3c3SWu Zhangjin# 21b93b3c3SWu Zhangjin# This file is subject to the terms and conditions of the GNU General Public 31b93b3c3SWu Zhangjin# License. 41b93b3c3SWu Zhangjin# 51b93b3c3SWu Zhangjin# Adapted for MIPS Pete Popov, Dan Malek 61b93b3c3SWu Zhangjin# 71b93b3c3SWu Zhangjin# Copyright (C) 1994 by Linus Torvalds 81b93b3c3SWu Zhangjin# Adapted for PowerPC by Gary Thomas 91b93b3c3SWu Zhangjin# modified by Cort (cort@cs.nmt.edu) 101b93b3c3SWu Zhangjin# 111b93b3c3SWu Zhangjin# Copyright (C) 2009 Lemote Inc. & DSLab, Lanzhou University 12f7a904dfSWu Zhangjin# Author: Wu Zhangjin <wuzhangjin@gmail.com> 131b93b3c3SWu Zhangjin# 141b93b3c3SWu Zhangjin 151b93b3c3SWu Zhangjin# compressed kernel load addr: VMLINUZ_LOAD_ADDRESS > VMLINUX_LOAD_ADDRESS + VMLINUX_SIZE 161b93b3c3SWu ZhangjinVMLINUX_SIZE := $(shell wc -c $(objtree)/$(KBUILD_IMAGE) 2>/dev/null | cut -d' ' -f1) 179c4a6fceSAlexander ClouterVMLINUX_SIZE := $(shell [ -n "$(VMLINUX_SIZE)" ] && echo -n $$(($(VMLINUX_SIZE) + (65536 - $(VMLINUX_SIZE) % 65536)))) 189c4a6fceSAlexander Clouter# VMLINUZ_LOAD_ADDRESS = concat "high32 of VMLINUX_LOAD_ADDRESS" and "(low32 of VMLINUX_LOAD_ADDRESS) + VMLINUX_SIZE" 199c4a6fceSAlexander ClouterHIGH32 := $(shell A=$(VMLINUX_LOAD_ADDRESS); [ $${\#A} -gt 10 ] && expr substr "$(VMLINUX_LOAD_ADDRESS)" 3 $$(($${\#A} - 10))) 209c4a6fceSAlexander ClouterLOW32 := $(shell [ -n "$(HIGH32)" ] && A=11 || A=3; expr substr "$(VMLINUX_LOAD_ADDRESS)" $${A} 8) 219c4a6fceSAlexander ClouterVMLINUZ_LOAD_ADDRESS := 0x$(shell [ -n "$(VMLINUX_SIZE)" -a -n "$(LOW32)" ] && printf "$(HIGH32)%08x" $$(($(VMLINUX_SIZE) + 0x$(LOW32)))) 221b93b3c3SWu Zhangjin 231b93b3c3SWu Zhangjin# set the default size of the mallocing area for decompressing 241b93b3c3SWu ZhangjinBOOT_HEAP_SIZE := 0x400000 251b93b3c3SWu Zhangjin 261b93b3c3SWu Zhangjin# Disable Function Tracer 271b93b3c3SWu ZhangjinKBUILD_CFLAGS := $(shell echo $(KBUILD_CFLAGS) | sed -e "s/-pg//") 281b93b3c3SWu Zhangjin 291b93b3c3SWu ZhangjinKBUILD_CFLAGS := $(LINUXINCLUDE) $(KBUILD_CFLAGS) -D__KERNEL__ \ 30dac2965cSWu Zhangjin -DBOOT_HEAP_SIZE=$(BOOT_HEAP_SIZE) -D"VMLINUX_LOAD_ADDRESS_ULL=$(VMLINUX_LOAD_ADDRESS)ull" 311b93b3c3SWu Zhangjin 321b93b3c3SWu ZhangjinKBUILD_AFLAGS := $(LINUXINCLUDE) $(KBUILD_AFLAGS) -D__ASSEMBLY__ \ 33dac2965cSWu Zhangjin -DBOOT_HEAP_SIZE=$(BOOT_HEAP_SIZE) \ 34dac2965cSWu Zhangjin -DKERNEL_ENTRY=0x$(shell $(NM) $(objtree)/$(KBUILD_IMAGE) 2>/dev/null | grep " kernel_entry" | cut -f1 -d \ ) 351b93b3c3SWu Zhangjin 3635eaa1e9SSam Ravnborgtargets := head.o decompress.o dbg.o uart-16550.o uart-alchemy.o 3735eaa1e9SSam Ravnborg 3835eaa1e9SSam Ravnborg# decompressor objects (linked with vmlinuz) 3935eaa1e9SSam Ravnborgvmlinuzobjs-y := $(obj)/head.o $(obj)/decompress.o $(obj)/dbg.o 401b93b3c3SWu Zhangjin 41f86a69b1SWu Zhangjinifdef CONFIG_DEBUG_ZBOOT 4235eaa1e9SSam Ravnborgvmlinuzobjs-$(CONFIG_SYS_SUPPORTS_ZBOOT_UART16550) += $(obj)/uart-16550.o 4342a4f17dSManuel Laussvmlinuzobjs-$(CONFIG_MIPS_ALCHEMY) += $(obj)/uart-alchemy.o 44f86a69b1SWu Zhangjinendif 451b93b3c3SWu Zhangjin 4635eaa1e9SSam Ravnborgtargets += vmlinux.bin 471b93b3c3SWu ZhangjinOBJCOPYFLAGS_vmlinux.bin := $(OBJCOPYFLAGS) -O binary -R .comment -S 4835eaa1e9SSam Ravnborg$(obj)/vmlinux.bin: $(KBUILD_IMAGE) FORCE 491b93b3c3SWu Zhangjin $(call if_changed,objcopy) 501b93b3c3SWu Zhangjin 511b93b3c3SWu Zhangjintool_$(CONFIG_KERNEL_GZIP) = gzip 521b93b3c3SWu Zhangjintool_$(CONFIG_KERNEL_BZIP2) = bzip2 531b93b3c3SWu Zhangjintool_$(CONFIG_KERNEL_LZMA) = lzma 54fe1d45e0SWu Zhangjintool_$(CONFIG_KERNEL_LZO) = lzo 5535eaa1e9SSam Ravnborg 56*c853d945SWu Zhangjintargets += vmlinux.bin.z 57*c853d945SWu Zhangjin$(obj)/vmlinux.bin.z: $(obj)/vmlinux.bin FORCE 581b93b3c3SWu Zhangjin $(call if_changed,$(tool_y)) 591b93b3c3SWu Zhangjin 6035eaa1e9SSam Ravnborgtargets += piggy.o 61*c853d945SWu ZhangjinOBJCOPYFLAGS_piggy.o := --add-section=.image=$(obj)/vmlinux.bin.z \ 6235eaa1e9SSam Ravnborg --set-section-flags=.image=contents,alloc,load,readonly,data 63*c853d945SWu Zhangjin$(obj)/piggy.o: $(obj)/dummy.o $(obj)/vmlinux.bin.z FORCE 6435eaa1e9SSam Ravnborg $(call if_changed,objcopy) 651b93b3c3SWu Zhangjin 661b93b3c3SWu ZhangjinLDFLAGS_vmlinuz := $(LDFLAGS) -Ttext $(VMLINUZ_LOAD_ADDRESS) -T 6735eaa1e9SSam Ravnborgvmlinuz: $(src)/ld.script $(vmlinuzobjs-y) $(obj)/piggy.o 6835eaa1e9SSam Ravnborg $(call cmd,ld) 69d4d9a553SWu Zhangjin $(Q)$(OBJCOPY) $(OBJCOPYFLAGS) $@ 701b93b3c3SWu Zhangjin 711b93b3c3SWu Zhangjin# 721b93b3c3SWu Zhangjin# Some DECstations need all possible sections of an ECOFF executable 731b93b3c3SWu Zhangjin# 741b93b3c3SWu Zhangjinifdef CONFIG_MACH_DECSTATION 7535eaa1e9SSam Ravnborg e2eflag := -a 761b93b3c3SWu Zhangjinendif 771b93b3c3SWu Zhangjin 781b93b3c3SWu Zhangjin# elf2ecoff can only handle 32bit image 7935eaa1e9SSam Ravnborghostprogs-y := ../elf2ecoff 801b93b3c3SWu Zhangjin 811b93b3c3SWu Zhangjinifdef CONFIG_32BIT 821b93b3c3SWu Zhangjin VMLINUZ = vmlinuz 831b93b3c3SWu Zhangjinelse 841b93b3c3SWu Zhangjin VMLINUZ = vmlinuz.32 851b93b3c3SWu Zhangjinendif 861b93b3c3SWu Zhangjin 8735eaa1e9SSam Ravnborgquiet_cmd_32 = OBJCOPY $@ 8835eaa1e9SSam Ravnborg cmd_32 = $(OBJCOPY) -O $(32bit-bfd) $(OBJCOPYFLAGS) $< $@ 891b93b3c3SWu Zhangjinvmlinuz.32: vmlinuz 9035eaa1e9SSam Ravnborg $(call cmd,32) 911b93b3c3SWu Zhangjin 9235eaa1e9SSam Ravnborgquiet_cmd_ecoff = ECOFF $@ 9335eaa1e9SSam Ravnborg cmd_ecoff = $< $(VMLINUZ) $@ $(e2eflag) 941b93b3c3SWu Zhangjinvmlinuz.ecoff: $(obj)/../elf2ecoff $(VMLINUZ) 9535eaa1e9SSam Ravnborg $(call cmd,ecoff) 961b93b3c3SWu Zhangjin 97d4d9a553SWu ZhangjinOBJCOPYFLAGS_vmlinuz.bin := $(OBJCOPYFLAGS) -O binary 981b93b3c3SWu Zhangjinvmlinuz.bin: vmlinuz 9935eaa1e9SSam Ravnborg $(call cmd,objcopy) 1001b93b3c3SWu Zhangjin 101d4d9a553SWu ZhangjinOBJCOPYFLAGS_vmlinuz.srec := $(OBJCOPYFLAGS) -S -O srec 1021b93b3c3SWu Zhangjinvmlinuz.srec: vmlinuz 10335eaa1e9SSam Ravnborg $(call cmd,objcopy) 1041b93b3c3SWu Zhangjin 10535eaa1e9SSam Ravnborgclean-files := $(objtree)/vmlinuz.* 106