a0ab36689a
This introduces some much overdue chainsawing of the fixed PMB support. fixed PMB was introduced initially to work around the fact that dynamic PMB mode was relatively broken, though they were never intended to converge. The main areas where there are differences are whether the system is booted in 29-bit mode or 32-bit mode, and whether legacy mappings are to be preserved. Any system booting in true 32-bit mode will not care about legacy mappings, so these are roughly decoupled. Regardless of the entry point, PMB and 32BIT are directly related as far as the kernel is concerned, so we also switch back to having one select the other. With legacy mappings iterated through and applied in the initialization path it's now possible to finally merge the two implementations and permit dynamic remapping overtop of remaining entries regardless of whether boot mappings are crafted by hand or inherited from the boot loader. Signed-off-by: Paul Mundt <lethal@linux-sh.org>
110 lines
3.1 KiB
Makefile
110 lines
3.1 KiB
Makefile
#
|
|
# arch/sh/boot/Makefile
|
|
#
|
|
# This file is subject to the terms and conditions of the GNU General Public
|
|
# License. See the file "COPYING" in the main directory of this archive
|
|
# for more details.
|
|
#
|
|
# Copyright (C) 1999 Stuart Menefy
|
|
#
|
|
|
|
MKIMAGE := $(srctree)/scripts/mkuboot.sh
|
|
|
|
#
|
|
# Assign safe dummy values if these variables are not defined,
|
|
# in order to suppress error message.
|
|
#
|
|
CONFIG_PAGE_OFFSET ?= 0x80000000
|
|
CONFIG_MEMORY_START ?= 0x0c000000
|
|
CONFIG_BOOT_LINK_OFFSET ?= 0x00800000
|
|
CONFIG_ZERO_PAGE_OFFSET ?= 0x00001000
|
|
CONFIG_ENTRY_OFFSET ?= 0x00001000
|
|
|
|
suffix-y := bin
|
|
suffix-$(CONFIG_KERNEL_GZIP) := gz
|
|
suffix-$(CONFIG_KERNEL_BZIP2) := bz2
|
|
suffix-$(CONFIG_KERNEL_LZMA) := lzma
|
|
suffix-$(CONFIG_KERNEL_LZO) := lzo
|
|
|
|
targets := zImage vmlinux.srec romImage uImage uImage.srec uImage.gz \
|
|
uImage.bz2 uImage.lzma uImage.lzo uImage.bin
|
|
extra-y += vmlinux.bin vmlinux.bin.gz vmlinux.bin.bz2 vmlinux.bin.lzma \
|
|
vmlinux.bin.lzo
|
|
subdir- := compressed romimage
|
|
|
|
$(obj)/zImage: $(obj)/compressed/vmlinux FORCE
|
|
$(call if_changed,objcopy)
|
|
@echo ' Kernel: $@ is ready'
|
|
|
|
$(obj)/compressed/vmlinux: FORCE
|
|
$(Q)$(MAKE) $(build)=$(obj)/compressed $@
|
|
|
|
$(obj)/romImage: $(obj)/romimage/vmlinux FORCE
|
|
$(call if_changed,objcopy)
|
|
@echo ' Kernel: $@ is ready'
|
|
|
|
$(obj)/romimage/vmlinux: $(obj)/zImage FORCE
|
|
$(Q)$(MAKE) $(build)=$(obj)/romimage $@
|
|
|
|
KERNEL_MEMORY := $(shell /bin/bash -c 'printf "0x%08x" \
|
|
$$[$(CONFIG_MEMORY_START) & 0x1fffffff]')
|
|
|
|
KERNEL_LOAD := $(shell /bin/bash -c 'printf "0x%08x" \
|
|
$$[$(CONFIG_PAGE_OFFSET) + \
|
|
$(KERNEL_MEMORY) + \
|
|
$(CONFIG_ZERO_PAGE_OFFSET)]')
|
|
|
|
KERNEL_ENTRY := $(shell /bin/bash -c 'printf "0x%08x" \
|
|
$$[$(CONFIG_PAGE_OFFSET) + \
|
|
$(KERNEL_MEMORY) + \
|
|
$(CONFIG_ZERO_PAGE_OFFSET) + $(CONFIG_ENTRY_OFFSET)]')
|
|
|
|
quiet_cmd_uimage = UIMAGE $@
|
|
cmd_uimage = $(CONFIG_SHELL) $(MKIMAGE) -A sh -O linux -T kernel \
|
|
-C $(2) -a $(KERNEL_LOAD) -e $(KERNEL_ENTRY) \
|
|
-n 'Linux-$(KERNELRELEASE)' -d $< $@
|
|
|
|
$(obj)/vmlinux.bin: vmlinux FORCE
|
|
$(call if_changed,objcopy)
|
|
|
|
$(obj)/vmlinux.bin.gz: $(obj)/vmlinux.bin FORCE
|
|
$(call if_changed,gzip)
|
|
|
|
$(obj)/vmlinux.bin.bz2: $(obj)/vmlinux.bin FORCE
|
|
$(call if_changed,bzip2)
|
|
|
|
$(obj)/vmlinux.bin.lzma: $(obj)/vmlinux.bin FORCE
|
|
$(call if_changed,lzma)
|
|
|
|
$(obj)/vmlinux.bin.lzo: $(obj)/vmlinux.bin FORCE
|
|
$(call if_changed,lzo)
|
|
|
|
$(obj)/uImage.bz2: $(obj)/vmlinux.bin.bz2
|
|
$(call if_changed,uimage,bzip2)
|
|
|
|
$(obj)/uImage.gz: $(obj)/vmlinux.bin.gz
|
|
$(call if_changed,uimage,gzip)
|
|
|
|
$(obj)/uImage.lzma: $(obj)/vmlinux.bin.lzma
|
|
$(call if_changed,uimage,lzma)
|
|
|
|
$(obj)/uImage.lzo: $(obj)/vmlinux.bin.lzo
|
|
$(call if_changed,uimage,lzo)
|
|
|
|
$(obj)/uImage.bin: $(obj)/vmlinux.bin
|
|
$(call if_changed,uimage,none)
|
|
|
|
OBJCOPYFLAGS_vmlinux.srec := -I binary -O srec
|
|
$(obj)/vmlinux.srec: $(obj)/compressed/vmlinux
|
|
$(call if_changed,objcopy)
|
|
|
|
OBJCOPYFLAGS_uImage.srec := -I binary -O srec
|
|
$(obj)/uImage.srec: $(obj)/uImage
|
|
$(call if_changed,objcopy)
|
|
|
|
$(obj)/uImage: $(obj)/uImage.$(suffix-y)
|
|
@ln -sf $(notdir $<) $@
|
|
@echo ' Image $@ is ready'
|
|
|
|
export CONFIG_PAGE_OFFSET CONFIG_MEMORY_START CONFIG_BOOT_LINK_OFFSET \
|
|
CONFIG_ZERO_PAGE_OFFSET CONFIG_ENTRY_OFFSET KERNEL_MEMORY suffix-y
|