summaryrefslogtreecommitdiff
path: root/openwrt/target
diff options
context:
space:
mode:
authorFlorian Fainelli <florian@openwrt.org>2006-05-04 22:45:27 +0000
committerFlorian Fainelli <florian@openwrt.org>2006-05-04 22:45:27 +0000
commitc0171a10805352b44e314beb04e3c485202ff693 (patch)
treefbd8490dff92321c1f8d5fd48ff3c222b7023403 /openwrt/target
parent5b1c6d3f78f5208e348f62d9f365f3f12a400501 (diff)
downloadmtk-20170518-c0171a10805352b44e314beb04e3c485202ff693.zip
mtk-20170518-c0171a10805352b44e314beb04e3c485202ff693.tar.gz
mtk-20170518-c0171a10805352b44e314beb04e3c485202ff693.tar.bz2
Fix zImage target, now really build valid images
SVN-Revision: 3729
Diffstat (limited to 'openwrt/target')
-rw-r--r--openwrt/target/linux/au1000-2.6/patches/003-zImage.patch2327
1 files changed, 1171 insertions, 1156 deletions
diff --git a/openwrt/target/linux/au1000-2.6/patches/003-zImage.patch b/openwrt/target/linux/au1000-2.6/patches/003-zImage.patch
index 6c2230f..685b854 100644
--- a/openwrt/target/linux/au1000-2.6/patches/003-zImage.patch
+++ b/openwrt/target/linux/au1000-2.6/patches/003-zImage.patch
@@ -1,1134 +1,6 @@
-diff -urN linux-2.6.16.7/arch/mips/Makefile linux-2.6.16.7.new/arch/mips/Makefile
---- linux-2.6.16.7/arch/mips/Makefile 2006-04-17 23:53:25.000000000 +0200
-+++ linux-2.6.16.7.new/arch/mips/Makefile 2006-04-20 19:27:22.000000000 +0200
-@@ -840,6 +840,12 @@
- vmlinux.srec: $(vmlinux-32)
- +@$(call makeboot,$@)
-
-+zImage: vmlinux
-+ +@$(call makeboot,$@)
-+
-+zImage.flash: vmlinux
-+ +@$(call makeboot,$@)
-+
- CLEAN_FILES += vmlinux.ecoff \
- vmlinux.srec \
- vmlinux.rm200.tmp \
-@@ -848,6 +854,7 @@
- archclean:
- @$(MAKE) $(clean)=arch/mips/boot
- @$(MAKE) $(clean)=arch/mips/lasat
-+ @$(MAKE) $(clean)=arch/mips/boot/compressed
-
- CLEAN_FILES += vmlinux.32 \
- vmlinux.64 \
-diff -urN linux-2.6.16.7/arch/mips/Makefile.orig linux-2.6.16.7.new/arch/mips/Makefile.orig
---- linux-2.6.16.7/arch/mips/Makefile.orig 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/Makefile.orig 2006-04-20 19:27:12.000000000 +0200
-@@ -0,0 +1,858 @@
-+#
-+# 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) 1994, 95, 96, 2003 by Ralf Baechle
-+# DECStation modifications by Paul M. Antoine, 1996
-+# Copyright (C) 2002, 2003, 2004 Maciej W. Rozycki
-+#
-+# This file is included by the global makefile so that you can add your own
-+# architecture-specific flags and dependencies. Remember to do have actions
-+# for "archclean" cleaning up for this architecture.
-+#
-+
-+as-option = $(shell if $(CC) $(CFLAGS) $(1) -Wa,-Z -c -o /dev/null \
-+ -xassembler /dev/null > /dev/null 2>&1; then echo "$(1)"; \
-+ else echo "$(2)"; fi ;)
-+
-+cflags-y :=
-+
-+#
-+# Select the object file format to substitute into the linker script.
-+#
-+ifdef CONFIG_CPU_LITTLE_ENDIAN
-+32bit-tool-prefix = mipsel-linux-
-+64bit-tool-prefix = mips64el-linux-
-+32bit-bfd = elf32-tradlittlemips
-+64bit-bfd = elf64-tradlittlemips
-+32bit-emul = elf32ltsmip
-+64bit-emul = elf64ltsmip
-+else
-+32bit-tool-prefix = mips-linux-
-+64bit-tool-prefix = mips64-linux-
-+32bit-bfd = elf32-tradbigmips
-+64bit-bfd = elf64-tradbigmips
-+32bit-emul = elf32btsmip
-+64bit-emul = elf64btsmip
-+endif
-+
-+ifdef CONFIG_32BIT
-+gcc-abi = 32
-+tool-prefix = $(32bit-tool-prefix)
-+UTS_MACHINE := mips
-+endif
-+ifdef CONFIG_64BIT
-+gcc-abi = 64
-+tool-prefix = $(64bit-tool-prefix)
-+UTS_MACHINE := mips64
-+endif
-+
-+ifdef CONFIG_CROSSCOMPILE
-+CROSS_COMPILE := $(tool-prefix)
-+endif
-+
-+CHECKFLAGS-y += -D__linux__ -D__mips__ \
-+ -D_MIPS_SZINT=32 \
-+ -D_ABIO32=1 \
-+ -D_ABIN32=2 \
-+ -D_ABI64=3
-+CHECKFLAGS-$(CONFIG_32BIT) += -D_MIPS_SIM=_ABIO32 \
-+ -D_MIPS_SZLONG=32 \
-+ -D_MIPS_SZPTR=32 \
-+ -D__PTRDIFF_TYPE__=int
-+CHECKFLAGS-$(CONFIG_64BIT) += -m64 -D_MIPS_SIM=_ABI64 \
-+ -D_MIPS_SZLONG=64 \
-+ -D_MIPS_SZPTR=64 \
-+ -D__PTRDIFF_TYPE__="long int"
-+CHECKFLAGS-$(CONFIG_CPU_BIG_ENDIAN) += -D__MIPSEB__
-+CHECKFLAGS-$(CONFIG_CPU_LITTLE_ENDIAN) += -D__MIPSEL__
-+
-+CHECKFLAGS = $(CHECKFLAGS-y)
-+
-+ifdef CONFIG_BUILD_ELF64
-+gas-abi = 64
-+ld-emul = $(64bit-emul)
-+vmlinux-32 = vmlinux.32
-+vmlinux-64 = vmlinux
-+else
-+gas-abi = 32
-+ld-emul = $(32bit-emul)
-+vmlinux-32 = vmlinux
-+vmlinux-64 = vmlinux.64
-+
-+cflags-$(CONFIG_64BIT) += $(call cc-option,-mno-explicit-relocs)
-+endif
-+
-+#
-+# GCC uses -G 0 -mabicalls -fpic as default. We don't want PIC in the kernel
-+# code since it only slows down the whole thing. At some point we might make
-+# use of global pointer optimizations but their use of $28 conflicts with
-+# the current pointer optimization.
-+#
-+# The DECStation requires an ECOFF kernel for remote booting, other MIPS
-+# machines may also. Since BFD is incredibly buggy with respect to
-+# crossformat linking we rely on the elf2ecoff tool for format conversion.
-+#
-+cflags-y += -G 0 -mno-abicalls -fno-pic -pipe
-+cflags-y += -msoft-float
-+LDFLAGS_vmlinux += -G 0 -static -n -nostdlib
-+MODFLAGS += -mlong-calls
-+
-+#
-+# We explicitly add the endianness specifier if needed, this allows
-+# to compile kernels with a toolchain for the other endianness. We
-+# carefully avoid to add it redundantly because gcc 3.3/3.4 complains
-+# when fed the toolchain default!
-+#
-+cflags-$(CONFIG_CPU_BIG_ENDIAN) += $(shell $(CC) -dumpmachine |grep -q 'mips.*el-.*' && echo -EB)
-+cflags-$(CONFIG_CPU_LITTLE_ENDIAN) += $(shell $(CC) -dumpmachine |grep -q 'mips.*el-.*' || echo -EL)
-+
-+cflags-$(CONFIG_SB1XXX_CORELIS) += $(call cc-option,-mno-sched-prolog) \
-+ -fno-omit-frame-pointer
-+
-+#
-+# Use: $(call set_gccflags,<cpu0>,<isa0>,<cpu1>,<isa1>,<isa2>)
-+#
-+# <cpu0>,<isa0> -- preferred CPU and ISA designations (may require
-+# recent tools)
-+# <cpu1>,<isa1> -- fallback CPU and ISA designations (have to work
-+# with up to the oldest supported tools)
-+# <isa2> -- an ISA designation used as an ABI selector for
-+# gcc versions that do not support "-mabi=32"
-+# (depending on the CPU type, either "mips1" or
-+# "mips2")
-+#
-+set_gccflags = $(shell \
-+while :; do \
-+ cpu=$(1); isa=-$(2); \
-+ for gcc_opt in -march= -mcpu=; do \
-+ $(CC) $$gcc_opt$$cpu $$isa -S -o /dev/null \
-+ -xc /dev/null > /dev/null 2>&1 && \
-+ break 2; \
-+ done; \
-+ cpu=$(3); isa=-$(4); \
-+ for gcc_opt in -march= -mcpu=; do \
-+ $(CC) $$gcc_opt$$cpu $$isa -S -o /dev/null \
-+ -xc /dev/null > /dev/null 2>&1 && \
-+ break 2; \
-+ done; \
-+ break; \
-+done; \
-+gcc_abi=-mabi=$(gcc-abi); gcc_cpu=$$cpu; \
-+if $(CC) $$gcc_abi -S -o /dev/null -xc /dev/null > /dev/null 2>&1; then \
-+ gcc_isa=$$isa; \
-+else \
-+ gcc_abi=; gcc_isa=-$(5); \
-+fi; \
-+gas_abi=-Wa,-$(gcc-abi); gas_cpu=$$cpu; gas_isa=-Wa,$$isa; \
-+while :; do \
-+ for gas_opt in -Wa,-march= -Wa,-mcpu=; do \
-+ $(CC) $$gas_abi $$gas_opt$$cpu $$gas_isa -Wa,-Z -c \
-+ -o /dev/null -xassembler /dev/null > /dev/null 2>&1 && \
-+ break 2; \
-+ done; \
-+ gas_abi=; gas_opt=; gas_cpu=; gas_isa=; \
-+ break; \
-+done; \
-+if test "$(gcc-abi)" != "$(gas-abi)"; then \
-+ gas_abi="-Wa,-$(gas-abi) -Wa,-mgp$(gcc-abi)"; \
-+fi; \
-+if test "$$gcc_opt" = -march= && test -n "$$gcc_abi"; then \
-+ $(CC) $$gcc_abi $$gcc_opt$$gcc_cpu -S -o /dev/null \
-+ -xc /dev/null > /dev/null 2>&1 && \
-+ gcc_isa=; \
-+fi; \
-+echo $$gcc_abi $$gcc_opt$$gcc_cpu $$gcc_isa $$gas_abi $$gas_opt$$gas_cpu $$gas_isa)
-+
-+#
-+# CPU-dependent compiler/assembler options for optimization.
-+#
-+cflags-$(CONFIG_CPU_R3000) += \
-+ $(call set_gccflags,r3000,mips1,r3000,mips1,mips1)
-+CHECKFLAGS-$(CONFIG_CPU_R3000) += -D_MIPS_ISA=_MIPS_ISA_MIPS1
-+
-+cflags-$(CONFIG_CPU_TX39XX) += \
-+ $(call set_gccflags,r3900,mips1,r3000,mips1,mips1)
-+CHECKFLAGS-$(CONFIG_CPU_TX39XX) += -D_MIPS_ISA=_MIPS_ISA_MIPS1
-+
-+cflags-$(CONFIG_CPU_R6000) += \
-+ $(call set_gccflags,r6000,mips2,r6000,mips2,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_R6000) += -D_MIPS_ISA=_MIPS_ISA_MIPS2
-+
-+cflags-$(CONFIG_CPU_R4300) += \
-+ $(call set_gccflags,r4300,mips3,r4300,mips3,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_R4300) += -D_MIPS_ISA=_MIPS_ISA_MIPS3
-+
-+cflags-$(CONFIG_CPU_VR41XX) += \
-+ $(call set_gccflags,r4100,mips3,r4600,mips3,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_VR41XX) += -D_MIPS_ISA=_MIPS_ISA_MIPS3
-+
-+cflags-$(CONFIG_CPU_R4X00) += \
-+ $(call set_gccflags,r4600,mips3,r4600,mips3,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_R4X00) += -D_MIPS_ISA=_MIPS_ISA_MIPS3
-+
-+cflags-$(CONFIG_CPU_TX49XX) += \
-+ $(call set_gccflags,r4600,mips3,r4600,mips3,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_TX49XX) += -D_MIPS_ISA=_MIPS_ISA_MIPS3
-+
-+cflags-$(CONFIG_CPU_MIPS32_R1) += \
-+ $(call set_gccflags,mips32,mips32,r4600,mips3,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_MIPS32_R1) += -D_MIPS_ISA=_MIPS_ISA_MIPS32
-+
-+cflags-$(CONFIG_CPU_MIPS32_R2) += \
-+ $(call set_gccflags,mips32r2,mips32r2,r4600,mips3,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_MIPS32_R2) += -D_MIPS_ISA=_MIPS_ISA_MIPS32
-+
-+cflags-$(CONFIG_CPU_MIPS64_R1) += \
-+ $(call set_gccflags,mips64,mips64,r4600,mips3,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_MIPS64_R1) += -D_MIPS_ISA=_MIPS_ISA_MIPS64
-+
-+cflags-$(CONFIG_CPU_MIPS64_R2) += \
-+ $(call set_gccflags,mips64r2,mips64r2,r4600,mips3,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_MIPS64_R2) += -D_MIPS_ISA=_MIPS_ISA_MIPS64
-+
-+cflags-$(CONFIG_CPU_R5000) += \
-+ $(call set_gccflags,r5000,mips4,r5000,mips4,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_R5000) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
-+
-+cflags-$(CONFIG_CPU_R5432) += \
-+ $(call set_gccflags,r5400,mips4,r5000,mips4,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_R5432) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
-+
-+cflags-$(CONFIG_CPU_NEVADA) += \
-+ $(call set_gccflags,rm5200,mips4,r5000,mips4,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_NEVADA) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
-+
-+cflags-$(CONFIG_CPU_RM7000) += \
-+ $(call set_gccflags,rm7000,mips4,r5000,mips4,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_RM7000) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
-+
-+cflags-$(CONFIG_CPU_RM9000) += \
-+ $(call set_gccflags,rm9000,mips4,r5000,mips4,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_RM9000) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
-+
-+
-+cflags-$(CONFIG_CPU_SB1) += \
-+ $(call set_gccflags,sb1,mips64,r5000,mips4,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_SB1) += -D_MIPS_ISA=_MIPS_ISA_MIPS64
-+
-+cflags-$(CONFIG_CPU_R8000) += \
-+ $(call set_gccflags,r8000,mips4,r8000,mips4,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_R8000) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
-+
-+cflags-$(CONFIG_CPU_R10000) += \
-+ $(call set_gccflags,r10000,mips4,r8000,mips4,mips2) \
-+ -Wa,--trap
-+CHECKFLAGS-$(CONFIG_CPU_R10000) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
-+
-+ifdef CONFIG_CPU_SB1
-+ifdef CONFIG_SB1_PASS_1_WORKAROUNDS
-+MODFLAGS += -msb1-pass1-workarounds
-+endif
-+endif
-+
-+#
-+# Firmware support
-+#
-+libs-$(CONFIG_ARC) += arch/mips/arc/
-+libs-$(CONFIG_SIBYTE_CFE) += arch/mips/sibyte/cfe/
-+
-+#
-+# Board-dependent options and extra files
-+#
-+
-+#
-+# Acer PICA 61, Mips Magnum 4000 and Olivetti M700.
-+#
-+core-$(CONFIG_MACH_JAZZ) += arch/mips/jazz/
-+cflags-$(CONFIG_MACH_JAZZ) += -Iinclude/asm-mips/mach-jazz
-+load-$(CONFIG_MACH_JAZZ) += 0xffffffff80080000
-+
-+#
-+# Common Alchemy Au1x00 stuff
-+#
-+core-$(CONFIG_SOC_AU1X00) += arch/mips/au1000/common/
-+cflags-$(CONFIG_SOC_AU1X00) += -Iinclude/asm-mips/mach-au1x00
-+
-+#
-+# AMD Alchemy Pb1000 eval board
-+#
-+libs-$(CONFIG_MIPS_PB1000) += arch/mips/au1000/pb1000/
-+cflags-$(CONFIG_MIPS_PB1000) += -Iinclude/asm-mips/mach-pb1x00
-+load-$(CONFIG_MIPS_PB1000) += 0xffffffff80100000
-+
-+#
-+# AMD Alchemy Pb1100 eval board
-+#
-+libs-$(CONFIG_MIPS_PB1100) += arch/mips/au1000/pb1100/
-+cflags-$(CONFIG_MIPS_PB1100) += -Iinclude/asm-mips/mach-pb1x00
-+load-$(CONFIG_MIPS_PB1100) += 0xffffffff80100000
-+
-+#
-+# AMD Alchemy Pb1500 eval board
-+#
-+libs-$(CONFIG_MIPS_PB1500) += arch/mips/au1000/pb1500/
-+cflags-$(CONFIG_MIPS_PB1500) += -Iinclude/asm-mips/mach-pb1x00
-+load-$(CONFIG_MIPS_PB1500) += 0xffffffff80100000
-+
-+#
-+# AMD Alchemy Pb1550 eval board
-+#
-+libs-$(CONFIG_MIPS_PB1550) += arch/mips/au1000/pb1550/
-+cflags-$(CONFIG_MIPS_PB1550) += -Iinclude/asm-mips/mach-pb1x00
-+load-$(CONFIG_MIPS_PB1550) += 0xffffffff80100000
-+
-+#
-+# AMD Alchemy Pb1200 eval board
-+#
-+libs-$(CONFIG_MIPS_PB1200) += arch/mips/au1000/pb1200/
-+cflags-$(CONFIG_MIPS_PB1200) += -Iinclude/asm-mips/mach-pb1x00
-+load-$(CONFIG_MIPS_PB1200) += 0xffffffff80100000
-+
-+#
-+# AMD Alchemy Db1000 eval board
-+#
-+libs-$(CONFIG_MIPS_DB1000) += arch/mips/au1000/db1x00/
-+cflags-$(CONFIG_MIPS_DB1000) += -Iinclude/asm-mips/mach-db1x00
-+load-$(CONFIG_MIPS_DB1000) += 0xffffffff80100000
-+
-+#
-+# AMD Alchemy Db1100 eval board
-+#
-+libs-$(CONFIG_MIPS_DB1100) += arch/mips/au1000/db1x00/
-+cflags-$(CONFIG_MIPS_DB1100) += -Iinclude/asm-mips/mach-db1x00
-+load-$(CONFIG_MIPS_DB1100) += 0xffffffff80100000
-+
-+#
-+# AMD Alchemy Db1500 eval board
-+#
-+libs-$(CONFIG_MIPS_DB1500) += arch/mips/au1000/db1x00/
-+cflags-$(CONFIG_MIPS_DB1500) += -Iinclude/asm-mips/mach-db1x00
-+load-$(CONFIG_MIPS_DB1500) += 0xffffffff80100000
-+
-+#
-+# AMD Alchemy Db1550 eval board
-+#
-+libs-$(CONFIG_MIPS_DB1550) += arch/mips/au1000/db1x00/
-+cflags-$(CONFIG_MIPS_DB1550) += -Iinclude/asm-mips/mach-db1x00
-+load-$(CONFIG_MIPS_DB1550) += 0xffffffff80100000
-+
-+#
-+# AMD Alchemy Db1200 eval board
-+#
-+libs-$(CONFIG_MIPS_DB1200) += arch/mips/au1000/pb1200/
-+cflags-$(CONFIG_MIPS_DB1200) += -Iinclude/asm-mips/mach-db1x00
-+load-$(CONFIG_MIPS_DB1200) += 0xffffffff80100000
-+
-+#
-+# AMD Alchemy Bosporus eval board
-+#
-+libs-$(CONFIG_MIPS_BOSPORUS) += arch/mips/au1000/db1x00/
-+cflags-$(CONFIG_MIPS_BOSPORUS) += -Iinclude/asm-mips/mach-db1x00
-+load-$(CONFIG_MIPS_BOSPORUS) += 0xffffffff80100000
-+
-+#
-+# AMD Alchemy Mirage eval board
-+#
-+libs-$(CONFIG_MIPS_MIRAGE) += arch/mips/au1000/db1x00/
-+cflags-$(CONFIG_MIPS_MIRAGE) += -Iinclude/asm-mips/mach-db1x00
-+load-$(CONFIG_MIPS_MIRAGE) += 0xffffffff80100000
-+
-+#
-+# 4G-Systems eval board
-+#
-+libs-$(CONFIG_MIPS_MTX1) += arch/mips/au1000/mtx-1/
-+load-$(CONFIG_MIPS_MTX1) += 0xffffffff80100000
-+
-+#
-+# MyCable eval board
-+#
-+libs-$(CONFIG_MIPS_XXS1500) += arch/mips/au1000/xxs1500/
-+load-$(CONFIG_MIPS_XXS1500) += 0xffffffff80100000
-+
-+#
-+# Cobalt Server
-+#
-+core-$(CONFIG_MIPS_COBALT) += arch/mips/cobalt/
-+cflags-$(CONFIG_MIPS_COBALT) += -Iinclude/asm-mips/mach-cobalt
-+load-$(CONFIG_MIPS_COBALT) += 0xffffffff80080000
-+
-+#
-+# DECstation family
-+#
-+core-$(CONFIG_MACH_DECSTATION) += arch/mips/dec/
-+cflags-$(CONFIG_MACH_DECSTATION)+= -Iinclude/asm-mips/mach-dec
-+libs-$(CONFIG_MACH_DECSTATION) += arch/mips/dec/prom/
-+load-$(CONFIG_MACH_DECSTATION) += 0xffffffff80040000
-+CLEAN_FILES += drivers/tc/lk201-map.c
-+
-+#
-+# Galileo EV64120 Board
-+#
-+core-$(CONFIG_MIPS_EV64120) += arch/mips/gt64120/ev64120/
-+core-$(CONFIG_MIPS_EV64120) += arch/mips/gt64120/common/
-+cflags-$(CONFIG_MIPS_EV64120) += -Iinclude/asm-mips/mach-ev64120
-+load-$(CONFIG_MIPS_EV64120) += 0xffffffff80100000
-+
-+#
-+# Galileo EV96100 Board
-+#
-+core-$(CONFIG_MIPS_EV96100) += arch/mips/galileo-boards/ev96100/
-+cflags-$(CONFIG_MIPS_EV96100) += -Iinclude/asm-mips/mach-ev96100
-+load-$(CONFIG_MIPS_EV96100) += 0xffffffff80100000
-+
-+#
-+# Globespan IVR eval board with QED 5231 CPU
-+#
-+core-$(CONFIG_ITE_BOARD_GEN) += arch/mips/ite-boards/generic/
-+core-$(CONFIG_MIPS_IVR) += arch/mips/ite-boards/ivr/
-+load-$(CONFIG_MIPS_IVR) += 0xffffffff80100000
-+
-+#
-+# ITE 8172 eval board with QED 5231 CPU
-+#
-+core-$(CONFIG_MIPS_ITE8172) += arch/mips/ite-boards/qed-4n-s01b/
-+load-$(CONFIG_MIPS_ITE8172) += 0xffffffff80100000
-+
-+#
-+# For all MIPS, Inc. eval boards
-+#
-+core-$(CONFIG_MIPS_BOARDS_GEN) += arch/mips/mips-boards/generic/
-+
-+#
-+# MIPS Atlas board
-+#
-+core-$(CONFIG_MIPS_ATLAS) += arch/mips/mips-boards/atlas/
-+cflags-$(CONFIG_MIPS_ATLAS) += -Iinclude/asm-mips/mach-atlas
-+cflags-$(CONFIG_MIPS_ATLAS) += -Iinclude/asm-mips/mach-mips
-+load-$(CONFIG_MIPS_ATLAS) += 0xffffffff80100000
-+
-+#
-+# MIPS Malta board
-+#
-+core-$(CONFIG_MIPS_MALTA) += arch/mips/mips-boards/malta/
-+cflags-$(CONFIG_MIPS_MALTA) += -Iinclude/asm-mips/mach-mips
-+load-$(CONFIG_MIPS_MALTA) += 0xffffffff80100000
-+
-+#
-+# MIPS SEAD board
-+#
-+core-$(CONFIG_MIPS_SEAD) += arch/mips/mips-boards/sead/
-+load-$(CONFIG_MIPS_SEAD) += 0xffffffff80100000
-+
-+#
-+# MIPS SIM
-+#
-+core-$(CONFIG_MIPS_SIM) += arch/mips/mips-boards/sim/
-+cflags-$(CONFIG_MIPS_SIM) += -Iinclude/asm-mips/mach-sim
-+load-$(CONFIG_MIPS_SIM) += 0x80100000
-+
-+#
-+# Momentum Ocelot board
-+#
-+# The Ocelot setup.o must be linked early - it does the ioremap() for the
-+# mips_io_port_base.
-+#
-+core-$(CONFIG_MOMENCO_OCELOT) += arch/mips/gt64120/common/ \
-+ arch/mips/gt64120/momenco_ocelot/
-+cflags-$(CONFIG_MOMENCO_OCELOT) += -Iinclude/asm-mips/mach-ocelot
-+load-$(CONFIG_MOMENCO_OCELOT) += 0xffffffff80100000
-+
-+#
-+# Momentum Ocelot-G board
-+#
-+# The Ocelot-G setup.o must be linked early - it does the ioremap() for the
-+# mips_io_port_base.
-+#
-+core-$(CONFIG_MOMENCO_OCELOT_G) += arch/mips/momentum/ocelot_g/
-+load-$(CONFIG_MOMENCO_OCELOT_G) += 0xffffffff80100000
-+
-+#
-+# Momentum Ocelot-C and -CS boards
-+#
-+# The Ocelot-C[S] setup.o must be linked early - it does the ioremap() for the
-+# mips_io_port_base.
-+core-$(CONFIG_MOMENCO_OCELOT_C) += arch/mips/momentum/ocelot_c/
-+load-$(CONFIG_MOMENCO_OCELOT_C) += 0xffffffff80100000
-+
-+#
-+# PMC-Sierra Yosemite
-+#
-+core-$(CONFIG_PMC_YOSEMITE) += arch/mips/pmc-sierra/yosemite/
-+cflags-$(CONFIG_PMC_YOSEMITE) += -Iinclude/asm-mips/mach-yosemite
-+load-$(CONFIG_PMC_YOSEMITE) += 0xffffffff80100000
-+
-+# Qemu simulating MIPS32 4Kc
-+#
-+core-$(CONFIG_QEMU) += arch/mips/qemu/
-+cflags-$(CONFIG_QEMU) += -Iinclude/asm-mips/mach-qemu
-+load-$(CONFIG_QEMU) += 0xffffffff80010000
-+
-+#
-+# Momentum Ocelot-3
-+#
-+core-$(CONFIG_MOMENCO_OCELOT_3) += arch/mips/momentum/ocelot_3/
-+cflags-$(CONFIG_MOMENCO_OCELOT_3) += -Iinclude/asm-mips/mach-ocelot3
-+load-$(CONFIG_MOMENCO_OCELOT_3) += 0xffffffff80100000
-+
-+#
-+# Momentum Jaguar ATX
-+#
-+core-$(CONFIG_MOMENCO_JAGUAR_ATX) += arch/mips/momentum/jaguar_atx/
-+cflags-$(CONFIG_MOMENCO_JAGUAR_ATX) += -Iinclude/asm-mips/mach-ja
-+#ifdef CONFIG_JAGUAR_DMALOW
-+#load-$(CONFIG_MOMENCO_JAGUAR_ATX) += 0xffffffff88000000
-+#else
-+load-$(CONFIG_MOMENCO_JAGUAR_ATX) += 0xffffffff80100000
-+#endif
-+
-+#
-+# NEC DDB
-+#
-+core-$(CONFIG_DDB5XXX_COMMON) += arch/mips/ddb5xxx/common/
-+
-+#
-+# NEC DDB Vrc-5074
-+#
-+core-$(CONFIG_DDB5074) += arch/mips/ddb5xxx/ddb5074/
-+load-$(CONFIG_DDB5074) += 0xffffffff80080000
-+
-+#
-+# NEC DDB Vrc-5476
-+#
-+core-$(CONFIG_DDB5476) += arch/mips/ddb5xxx/ddb5476/
-+load-$(CONFIG_DDB5476) += 0xffffffff80080000
-+
-+#
-+# NEC DDB Vrc-5477
-+#
-+core-$(CONFIG_DDB5477) += arch/mips/ddb5xxx/ddb5477/
-+load-$(CONFIG_DDB5477) += 0xffffffff80100000
-+
-+core-$(CONFIG_LASAT) += arch/mips/lasat/
-+cflags-$(CONFIG_LASAT) += -Iinclude/asm-mips/mach-lasat
-+load-$(CONFIG_LASAT) += 0xffffffff80000000
-+
-+#
-+# Common VR41xx
-+#
-+core-$(CONFIG_MACH_VR41XX) += arch/mips/vr41xx/common/
-+cflags-$(CONFIG_MACH_VR41XX) += -Iinclude/asm-mips/mach-vr41xx
-+
-+#
-+# NEC VR4133
-+#
-+core-$(CONFIG_NEC_CMBVR4133) += arch/mips/vr41xx/nec-cmbvr4133/
-+load-$(CONFIG_NEC_CMBVR4133) += 0xffffffff80100000
-+
-+#
-+# ZAO Networks Capcella (VR4131)
-+#
-+load-$(CONFIG_ZAO_CAPCELLA) += 0xffffffff80000000
-+
-+#
-+# Victor MP-C303/304 (VR4122)
-+#
-+load-$(CONFIG_VICTOR_MPC30X) += 0xffffffff80001000
-+
-+#
-+# IBM WorkPad z50 (VR4121)
-+#
-+core-$(CONFIG_IBM_WORKPAD) += arch/mips/vr41xx/ibm-workpad/
-+load-$(CONFIG_IBM_WORKPAD) += 0xffffffff80004000
-+
-+#
-+# CASIO CASSIPEIA E-55/65 (VR4111)
-+#
-+core-$(CONFIG_CASIO_E55) += arch/mips/vr41xx/casio-e55/
-+load-$(CONFIG_CASIO_E55) += 0xffffffff80004000
-+
-+#
-+# TANBAC VR4131 multichip module(TB0225) and TANBAC VR4131DIMM(TB0229) (VR4131)
-+#
-+load-$(CONFIG_TANBAC_TB022X) += 0xffffffff80000000
-+
-+#
-+# Common Philips PNX8550
-+#
-+core-$(CONFIG_SOC_PNX8550) += arch/mips/philips/pnx8550/common/
-+cflags-$(CONFIG_SOC_PNX8550) += -Iinclude/asm-mips/mach-pnx8550
-+
-+#
-+# Philips PNX8550 JBS board
-+#
-+libs-$(CONFIG_PNX8550_JBS) += arch/mips/philips/pnx8550/jbs/
-+#cflags-$(CONFIG_PNX8550_JBS) += -Iinclude/asm-mips/mach-pnx8550
-+load-$(CONFIG_PNX8550_JBS) += 0xffffffff80060000
-+
-+#
-+# SGI IP22 (Indy/Indigo2)
-+#
-+# Set the load address to >= 0xffffffff88069000 if you want to leave space for
-+# symmon, 0xffffffff80002000 for production kernels. Note that the value must
-+# be aligned to a multiple of the kernel stack size or the handling of the
-+# current variable will break so for 64-bit kernels we have to raise the start
-+# address by 8kb.
-+#
-+core-$(CONFIG_SGI_IP22) += arch/mips/sgi-ip22/
-+cflags-$(CONFIG_SGI_IP22) += -Iinclude/asm-mips/mach-ip22
-+ifdef CONFIG_32BIT
-+load-$(CONFIG_SGI_IP22) += 0xffffffff88002000
-+endif
-+ifdef CONFIG_64BIT
-+load-$(CONFIG_SGI_IP22) += 0xffffffff88004000
-+endif
-+
-+#
-+# SGI-IP27 (Origin200/2000)
-+#
-+# Set the load address to >= 0xc000000000300000 if you want to leave space for
-+# symmon, 0xc00000000001c000 for production kernels. Note that the value must
-+# be 16kb aligned or the handling of the current variable will break.
-+#
-+ifdef CONFIG_SGI_IP27
-+core-$(CONFIG_SGI_IP27) += arch/mips/sgi-ip27/
-+cflags-$(CONFIG_SGI_IP27) += -Iinclude/asm-mips/mach-ip27
-+ifdef CONFIG_BUILD_ELF64
-+ifdef CONFIG_MAPPED_KERNEL
-+load-$(CONFIG_SGI_IP27) += 0xc00000004001c000
-+OBJCOPYFLAGS := --change-addresses=0x3fffffff80000000
-+dataoffset-$(CONFIG_SGI_IP27) += 0x01000000
-+else
-+load-$(CONFIG_SGI_IP27) += 0xa80000000001c000
-+OBJCOPYFLAGS := --change-addresses=0x57ffffff80000000
-+endif
-+else
-+ifdef CONFIG_MAPPED_KERNEL
-+load-$(CONFIG_SGI_IP27) += 0xffffffffc001c000
-+OBJCOPYFLAGS := --change-addresses=0xc000000080000000
-+dataoffset-$(CONFIG_SGI_IP27) += 0x01000000
-+else
-+load-$(CONFIG_SGI_IP27) += 0xffffffff8001c000
-+OBJCOPYFLAGS := --change-addresses=0xa800000080000000
-+endif
-+endif
-+endif
-+
-+#
-+# SGI-IP32 (O2)
-+#
-+# Set the load address to >= 80069000 if you want to leave space for symmon,
-+# 0xffffffff80004000 for production kernels. Note that the value must be aligned to
-+# a multiple of the kernel stack size or the handling of the current variable
-+# will break.
-+#
-+core-$(CONFIG_SGI_IP32) += arch/mips/sgi-ip32/
-+cflags-$(CONFIG_SGI_IP32) += -Iinclude/asm-mips/mach-ip32
-+load-$(CONFIG_SGI_IP32) += 0xffffffff80004000
-+
-+#
-+# Sibyte SB1250 SOC
-+#
-+# This is a LIB so that it links at the end, and initcalls are later
-+# the sequence; but it is built as an object so that modules don't get
-+# removed (as happens, even if they have __initcall/module_init)
-+#
-+core-$(CONFIG_SIBYTE_BCM112X) += arch/mips/sibyte/sb1250/
-+cflags-$(CONFIG_SIBYTE_BCM112X) += -Iinclude/asm-mips/mach-sibyte \
-+ -DSIBYTE_HDR_FEATURES=SIBYTE_HDR_FMASK_1250_112x_ALL
-+
-+core-$(CONFIG_SIBYTE_SB1250) += arch/mips/sibyte/sb1250/
-+cflags-$(CONFIG_SIBYTE_SB1250) += -Iinclude/asm-mips/mach-sibyte \
-+ -DSIBYTE_HDR_FEATURES=SIBYTE_HDR_FMASK_1250_112x_ALL
-+
-+core-$(CONFIG_SIBYTE_BCM1x55) += arch/mips/sibyte/bcm1480/
-+cflags-$(CONFIG_SIBYTE_BCM1x55) += -Iinclude/asm-mips/mach-sibyte \
-+ -DSIBYTE_HDR_FEATURES=SIBYTE_HDR_FMASK_1480_ALL
-+
-+core-$(CONFIG_SIBYTE_BCM1x80) += arch/mips/sibyte/bcm1480/
-+cflags-$(CONFIG_SIBYTE_BCM1x80) += -Iinclude/asm-mips/mach-sibyte \
-+ -DSIBYTE_HDR_FEATURES=SIBYTE_HDR_FMASK_1480_ALL
-+
-+#
-+# Sibyte BCM91120x (Carmel) board
-+# Sibyte BCM91120C (CRhine) board
-+# Sibyte BCM91125C (CRhone) board
-+# Sibyte BCM91125E (Rhone) board
-+# Sibyte SWARM board
-+# Sibyte BCM91x80 (BigSur) board
-+#
-+libs-$(CONFIG_SIBYTE_CARMEL) += arch/mips/sibyte/swarm/
-+load-$(CONFIG_SIBYTE_CARMEL) := 0xffffffff80100000
-+libs-$(CONFIG_SIBYTE_CRHINE) += arch/mips/sibyte/swarm/
-+load-$(CONFIG_SIBYTE_CRHINE) := 0xffffffff80100000
-+libs-$(CONFIG_SIBYTE_CRHONE) += arch/mips/sibyte/swarm/
-+load-$(CONFIG_SIBYTE_CRHONE) := 0xffffffff80100000
-+libs-$(CONFIG_SIBYTE_RHONE) += arch/mips/sibyte/swarm/
-+load-$(CONFIG_SIBYTE_RHONE) := 0xffffffff80100000
-+libs-$(CONFIG_SIBYTE_SENTOSA) += arch/mips/sibyte/swarm/
-+load-$(CONFIG_SIBYTE_SENTOSA) := 0xffffffff80100000
-+libs-$(CONFIG_SIBYTE_SWARM) += arch/mips/sibyte/swarm/
-+load-$(CONFIG_SIBYTE_SWARM) := 0xffffffff80100000
-+libs-$(CONFIG_SIBYTE_BIGSUR) += arch/mips/sibyte/swarm/
-+load-$(CONFIG_SIBYTE_BIGSUR) := 0xffffffff80100000
-+
-+#
-+# SNI RM200 PCI
-+#
-+core-$(CONFIG_SNI_RM200_PCI) += arch/mips/sni/
-+cflags-$(CONFIG_SNI_RM200_PCI) += -Iinclude/asm-mips/mach-rm200
-+load-$(CONFIG_SNI_RM200_PCI) += 0xffffffff80600000
-+
-+#
-+# Toshiba JMR-TX3927 board
-+#
-+core-$(CONFIG_TOSHIBA_JMR3927) += arch/mips/jmr3927/rbhma3100/ \
-+ arch/mips/jmr3927/common/
-+cflags-$(CONFIG_TOSHIBA_JMR3927) += -Iinclude/asm-mips/mach-jmr3927
-+load-$(CONFIG_TOSHIBA_JMR3927) += 0xffffffff80050000
-+
-+#
-+# Toshiba RBTX4927 board or
-+# Toshiba RBTX4937 board
-+#
-+core-$(CONFIG_TOSHIBA_RBTX4927) += arch/mips/tx4927/toshiba_rbtx4927/
-+core-$(CONFIG_TOSHIBA_RBTX4927) += arch/mips/tx4927/common/
-+load-$(CONFIG_TOSHIBA_RBTX4927) += 0xffffffff80020000
-+
-+#
-+# Toshiba RBTX4938 board
-+#
-+core-$(CONFIG_TOSHIBA_RBTX4938) += arch/mips/tx4938/toshiba_rbtx4938/
-+core-$(CONFIG_TOSHIBA_RBTX4938) += arch/mips/tx4938/common/
-+load-$(CONFIG_TOSHIBA_RBTX4938) += 0xffffffff80100000
-+
-+cflags-y += -Iinclude/asm-mips/mach-generic
-+drivers-$(CONFIG_PCI) += arch/mips/pci/
-+
-+ifdef CONFIG_32BIT
-+ifdef CONFIG_CPU_LITTLE_ENDIAN
-+JIFFIES = jiffies_64
-+else
-+JIFFIES = jiffies_64 + 4
-+endif
-+else
-+JIFFIES = jiffies_64
-+endif
-+
-+AFLAGS += $(cflags-y)
-+CFLAGS += $(cflags-y)
-+
-+LDFLAGS += -m $(ld-emul)
-+
-+OBJCOPYFLAGS += --remove-section=.reginfo
-+
-+#
-+# Choosing incompatible machines durings configuration will result in
-+# error messages during linking. Select a default linkscript if
-+# none has been choosen above.
-+#
-+
-+CPPFLAGS_vmlinux.lds := \
-+ $(CFLAGS) \
-+ -D"LOADADDR=$(load-y)" \
-+ -D"JIFFIES=$(JIFFIES)" \
-+ -D"DATAOFFSET=$(if $(dataoffset-y),$(dataoffset-y),0)"
-+
-+head-y := arch/mips/kernel/head.o arch/mips/kernel/init_task.o
-+
-+libs-y += arch/mips/lib/
-+libs-$(CONFIG_32BIT) += arch/mips/lib-32/
-+libs-$(CONFIG_64BIT) += arch/mips/lib-64/
-+
-+core-y += arch/mips/kernel/ arch/mips/mm/ arch/mips/math-emu/
-+
-+drivers-$(CONFIG_OPROFILE) += arch/mips/oprofile/
-+
-+ifdef CONFIG_LASAT
-+rom.bin rom.sw: vmlinux
-+ $(Q)$(MAKE) $(build)=arch/mips/lasat/image $@
-+endif
-+
-+#
-+# Some machines like the Indy need 32-bit ELF binaries for booting purposes.
-+# Other need ECOFF, so we build a 32-bit ELF binary for them which we then
-+# convert to ECOFF using elf2ecoff.
-+#
-+vmlinux.32: vmlinux
-+ $(OBJCOPY) -O $(32bit-bfd) $(OBJCOPYFLAGS) $< $@
-+
-+#
-+# The 64-bit ELF tools are pretty broken so at this time we generate 64-bit
-+# ELF files from 32-bit files by conversion.
-+#
-+vmlinux.64: vmlinux
-+ $(OBJCOPY) -O $(64bit-bfd) $(OBJCOPYFLAGS) $< $@
-+
-+makeboot =$(Q)$(MAKE) $(build)=arch/mips/boot VMLINUX=$(vmlinux-32) $(1)
-+
-+ifdef CONFIG_BOOT_ELF32
-+all: $(vmlinux-32)
-+endif
-+
-+ifdef CONFIG_BOOT_ELF64
-+all: $(vmlinux-64)
-+endif
-+
-+ifdef CONFIG_MIPS_ATLAS
-+all: vmlinux.srec
-+endif
-+
-+ifdef CONFIG_MIPS_MALTA
-+all: vmlinux.srec
-+endif
-+
-+ifdef CONFIG_MIPS_SEAD
-+all: vmlinux.srec
-+endif
-+
-+ifdef CONFIG_QEMU
-+all: vmlinux.bin
-+endif
-+
-+ifdef CONFIG_SNI_RM200_PCI
-+all: vmlinux.ecoff
-+endif
-+
-+vmlinux.bin: $(vmlinux-32)
-+ +@$(call makeboot,$@)
-+
-+vmlinux.ecoff vmlinux.rm200: $(vmlinux-32)
-+ +@$(call makeboot,$@)
-+
-+vmlinux.srec: $(vmlinux-32)
-+ +@$(call makeboot,$@)
-+
-+zImage: vmlinux
-+ +@$(call makeboot,$@)
-+
-+CLEAN_FILES += vmlinux.ecoff \
-+ vmlinux.srec \
-+ vmlinux.rm200.tmp \
-+ vmlinux.rm200
-+
-+archclean:
-+ @$(MAKE) $(clean)=arch/mips/boot
-+ @$(MAKE) $(clean)=arch/mips/lasat
-+ @$(MAKE) $(clean)=arch/mips/boot/compressed
-+
-+CLEAN_FILES += vmlinux.32 \
-+ vmlinux.64 \
-+ vmlinux.ecoff
-diff -urN linux-2.6.16.7/arch/mips/boot/Makefile linux-2.6.16.7.new/arch/mips/boot/Makefile
---- linux-2.6.16.7/arch/mips/boot/Makefile 2006-04-17 23:53:25.000000000 +0200
-+++ linux-2.6.16.7.new/arch/mips/boot/Makefile 2006-04-20 19:27:22.000000000 +0200
-@@ -16,6 +16,7 @@
- E2EFLAGS =
- endif
-
-+
- #
- # Drop some uninteresting sections in the kernel.
- # This is only relevant for ELF kernels but doesn't hurt a.out
-@@ -25,7 +26,10 @@
-
- VMLINUX = vmlinux
-
--all: vmlinux.ecoff vmlinux.srec addinitrd
-+ZBOOT_TARGETS = zImage zImage.flash
-+bootdir-y := compressed
-+
-+all: vmlinux.ecoff vmlinux.srec addinitrd zImage
-
- vmlinux.ecoff: $(obj)/elf2ecoff $(VMLINUX)
- $(obj)/elf2ecoff $(VMLINUX) vmlinux.ecoff $(E2EFLAGS)
-@@ -51,3 +55,11 @@
- vmlinux.bin \
- vmlinux.ecoff \
- vmlinux.srec
-+
-+.PHONY: $(ZBOOT_TARGETS) $(bootdir-y)
-+
-+$(ZBOOT_TARGETS): $(bootdir-y)
-+
-+$(bootdir-y): $(addprefix $(obj)/,$(subdir-y)) \
-+ $(addprefix $(obj)/,$(hostprogs-y))
-+ $(Q)$(MAKE) $(build)=$(obj)/$@ $(MAKECMDGOALS)
-diff -urN linux-2.6.16.7/arch/mips/boot/Makefile.orig linux-2.6.16.7.new/arch/mips/boot/Makefile.orig
---- linux-2.6.16.7/arch/mips/boot/Makefile.orig 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/Makefile.orig 2006-04-17 23:53:25.000000000 +0200
-@@ -0,0 +1,53 @@
-+#
-+# 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) 1995, 1998, 2001, 2002 by Ralf Baechle
-+# Copyright (C) 2004 Maciej W. Rozycki
-+#
-+
-+#
-+# Some DECstations need all possible sections of an ECOFF executable
-+#
-+ifdef CONFIG_MACH_DECSTATION
-+ E2EFLAGS = -a
-+else
-+ E2EFLAGS =
-+endif
-+
-+#
-+# Drop some uninteresting sections in the kernel.
-+# This is only relevant for ELF kernels but doesn't hurt a.out
-+#
-+drop-sections = .reginfo .mdebug .comment .note .pdr .options .MIPS.options
-+strip-flags = $(addprefix --remove-section=,$(drop-sections))
-+
-+VMLINUX = vmlinux
-+
-+all: vmlinux.ecoff vmlinux.srec addinitrd
-+
-+vmlinux.ecoff: $(obj)/elf2ecoff $(VMLINUX)
-+ $(obj)/elf2ecoff $(VMLINUX) vmlinux.ecoff $(E2EFLAGS)
-+
-+$(obj)/elf2ecoff: $(obj)/elf2ecoff.c
-+ $(HOSTCC) -o $@ $^
-+
-+vmlinux.bin: $(VMLINUX)
-+ $(OBJCOPY) -O binary $(strip-flags) $(VMLINUX) $(obj)/vmlinux.bin
-+
-+vmlinux.srec: $(VMLINUX)
-+ $(OBJCOPY) -S -O srec $(strip-flags) $(VMLINUX) $(obj)/vmlinux.srec
-+
-+$(obj)/addinitrd: $(obj)/addinitrd.c
-+ $(HOSTCC) -o $@ $^
-+
-+archhelp:
-+ @echo '* vmlinux.ecoff - ECOFF boot image'
-+ @echo '* vmlinux.srec - SREC boot image'
-+
-+clean-files += addinitrd \
-+ elf2ecoff \
-+ vmlinux.bin \
-+ vmlinux.ecoff \
-+ vmlinux.srec
-diff -urN linux-2.6.16.7/arch/mips/boot/compressed/Makefile linux-2.6.16.7.new/arch/mips/boot/compressed/Makefile
---- linux-2.6.16.7/arch/mips/boot/compressed/Makefile 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/Makefile 2006-04-20 19:27:22.000000000 +0200
-@@ -0,0 +1,32 @@
-+
-+#
-+# arch/mips/boot/compressed/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) 1994 by Linus Torvalds
-+# Adapted for PowerPC by Gary Thomas
-+# modified by Cort (cort@cs.nmt.edu)
-+#
-+# Ported to MIPS by Pete Popov, ppopov@embeddedalley.com
-+#
-+
-+boot := arch/mips/boot
-+compressed := arch/mips/boot/compressed
-+
-+CFLAGS += -fno-builtin -D__BOOTER__ -I$(compressed)/include
-+
-+BOOT_TARGETS = zImage zImage.flash
-+
-+bootdir-$(CONFIG_SOC_AU1X00) := au1xxx
-+subdir-y := common lib images
-+
-+.PHONY: $(BOOT_TARGETS) $(bootdir-y)
-+
-+$(BOOT_TARGETS): $(bootdir-y)
-+
-+$(bootdir-y): $(addprefix $(obj)/,$(subdir-y)) \
-+ $(addprefix $(obj)/,$(hostprogs-y))
-+ $(Q)$(MAKE) $(build)=$(obj)/$@ $(MAKECMDGOALS)
-diff -urN linux-2.6.16.7/arch/mips/boot/compressed/au1xxx/Makefile linux-2.6.16.7.new/arch/mips/boot/compressed/au1xxx/Makefile
---- linux-2.6.16.7/arch/mips/boot/compressed/au1xxx/Makefile 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/au1xxx/Makefile 2006-04-20 19:27:22.000000000 +0200
-@@ -0,0 +1,110 @@
-+# arch/mips/boot/compressed/au1xxx/Makefile
-+#
-+# Makefile for AMD Alchemy Semiconductor Au1x based boards.
-+# All of the boot loader code was derived from the ppc
-+# boot code.
-+#
-+# Copyright 2001,2002 MontaVista Software Inc.
-+#
-+# Author: Mark A. Greer
-+# mgreer@mvista.com
-+#
-+# Copyright 2004 Embedded Alley Solutions, Inc
-+# Ported and modified for mips 2.6 support by
-+# Pete Popov <ppopov@embeddedalley.com>
-+#
-+# This program is free software; you can redistribute it and/or modify it
-+# under the terms of the GNU General Public License as published by the
-+# Free Software Foundation; either version 2 of the License, or (at your
-+# option) any later version.
-+
-+boot := arch/mips/boot
-+compressed := $(boot)/compressed
-+utils := $(compressed)/utils
-+lib := $(compressed)/lib
-+images := $(compressed)/images
-+common := $(compressed)/common
-+
-+#########################################################################
-+# START BOARD SPECIFIC VARIABLES
-+
-+# These two variables control where the zImage is stored
-+# in flash and loaded in memory. It only controls how the srec
-+# file is generated, the code is the same.
-+RAM_RUN_ADDR = 0x81000000
-+
-+ifdef CONFIG_MIPS_XXS1500
-+FLASH_LOAD_ADDR = 0xBF000000
-+else
-+FLASH_LOAD_ADDR = 0xBFD00000
-+endif
-+
-+# These two variables specify the free ram region
-+# that can be used for temporary malloc area
-+AVAIL_RAM_START=0x80500000
-+AVAIL_RAM_END=0x80900000
-+
-+# This one must match the LOADADDR in arch/mips/Makefile!
-+LOADADDR=0x80100000
-+
-+# WARNING WARNING WARNING
-+# Note that with a LOADADDR of 0x80100000 and AVAIL_RAM_START of
-+# 0x80500000, the max decompressed kernel size can be 4MB. Else we
-+# start overwriting ourselve. You can change these vars as needed;
-+# it would be much better if we just figured everything out on the fly.
-+
-+# END BOARD SPECIFIC VARIABLES
-+#########################################################################
-+
-+OBJECTS := $(obj)/head.o $(common)/misc-common.o $(common)/misc-simple.o \
-+ $(common)/au1k_uart.o
-+LIBS := $(lib)/lib.a
-+
-+ENTRY := $(utils)/entry
-+OFFSET := $(utils)/offset
-+SIZE := $(utils)/size
-+
-+LD_ARGS := -T $(compressed)/ld.script -Ttext $(RAM_RUN_ADDR) -Bstatic
-+
-+ifdef CONFIG_CPU_LITTLE_ENDIAN
-+OBJCOPY_ARGS = -O elf32-tradlittlemips
-+else
-+OBJCOPY_ARGS = -O elf32-tradbigmips
-+endif
-+
-+$(obj)/head.o: $(obj)/head.S $(TOPDIR)/vmlinux
-+ $(CC) -I $(TOPDIR)/include $(AFLAGS) \
-+ -DKERNEL_ENTRY=$(shell sh $(ENTRY) $(NM) $(TOPDIR)/vmlinux ) \
-+ -c -o $*.o $<
-+
-+$(common)/misc-simple.o:
-+ $(CC) -I $(TOPDIR)/include $(CFLAGS) -DINITRD_OFFSET=0 -DINITRD_SIZE=0 -DZIMAGE_OFFSET=0 \
-+ -DAVAIL_RAM_START=$(AVAIL_RAM_START) \
-+ -DAVAIL_RAM_END=$(AVAIL_RAM_END) \
-+ -DLOADADDR=$(LOADADDR) \
-+ -DZIMAGE_SIZE=0 -c -o $@ $*.c
-+
-+$(obj)/zvmlinux: $(OBJECTS) $(LIBS) $(srctree)/$(compressed)/ld.script $(images)/vmlinux.gz $(common)/dummy.o
-+ $(OBJCOPY) \
-+ --add-section=.image=$(images)/vmlinux.gz \
-+ --set-section-flags=.image=contents,alloc,load,readonly,data \
-+ $(common)/dummy.o $(common)/image.o
-+ $(LD) $(LD_ARGS) -o $@ $(OBJECTS) $(common)/image.o $(LIBS)
-+ $(OBJCOPY) $(OBJCOPY_ARGS) $@ $@ -R __kcrctab -R __ksymtab_strings \
-+ -R .comment -R .stab -R .stabstr -R .initrd -R .sysmap
-+
-+# Here we manipulate the image in order to get it the necessary
-+# srecord file we need.
-+zImage: $(obj)/zvmlinux
-+ mv $(obj)/zvmlinux $(images)/zImage
-+ $(OBJCOPY) -O srec $(images)/zImage $(images)/zImage.srec
-+ $(OBJCOPY) -O binary $(images)/zImage $(images)/zImage.bin
-+
-+zImage.flash: zImage
-+ ( \
-+ flash=${FLASH_LOAD_ADDR} ; \
-+ ram=${RAM_RUN_ADDR} ; \
-+ adjust=$$[ $$flash - $$ram ] ; \
-+ $(OBJCOPY) -O srec --adjust-vma `printf '0x%08x' $$adjust` \
-+ $(images)/zImage $(images)/zImage.flash.srec ; \
-+ )
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/au1xxx/head.S linux-2.6.16.7.new/arch/mips/boot/compressed/au1xxx/head.S
--- linux-2.6.16.7/arch/mips/boot/compressed/au1xxx/head.S 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/au1xxx/head.S 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/au1xxx/head.S 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,119 @@
+/*
+ * arch/mips/kernel/head.S
@@ -1249,27 +121,123 @@ diff -urN linux-2.6.16.7/arch/mips/boot/compressed/au1xxx/head.S linux-2.6.16.7.
+ b 3b
+ END(start)
+ .comm .stack,4096*2,4
-diff -urN linux-2.6.16.7/arch/mips/boot/compressed/common/Makefile linux-2.6.16.7.new/arch/mips/boot/compressed/common/Makefile
---- linux-2.6.16.7/arch/mips/boot/compressed/common/Makefile 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/common/Makefile 2006-04-20 19:27:12.000000000 +0200
-@@ -0,0 +1,14 @@
-+#
-+# arch/mips/boot/compressed/common/Makefile
+diff -urN linux-2.6.16.7/arch/mips/boot/compressed/au1xxx/Makefile linux-2.6.16.7.new/arch/mips/boot/compressed/au1xxx/Makefile
+--- linux-2.6.16.7/arch/mips/boot/compressed/au1xxx/Makefile 1970-01-01 01:00:00.000000000 +0100
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/au1xxx/Makefile 2006-05-04 23:08:18.000000000 +0200
+@@ -0,0 +1,110 @@
++# arch/mips/boot/compressed/au1xxx/Makefile
++#
++# Makefile for AMD Alchemy Semiconductor Au1x based boards.
++# All of the boot loader code was derived from the ppc
++# boot code.
+#
-+# 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 2001,2002 MontaVista Software Inc.
+#
-+# Tom Rini January 2001
++# Author: Mark A. Greer
++# mgreer@mvista.com
+#
-+# Pete Popov, 2004
++# Copyright 2004 Embedded Alley Solutions, Inc
++# Ported and modified for mips 2.6 support by
++# Pete Popov <ppopov@embeddedalley.com>
+#
++# This program is free software; you can redistribute it and/or modify it
++# under the terms of the GNU General Public License as published by the
++# Free Software Foundation; either version 2 of the License, or (at your
++# option) any later version.
+
-+lib-y := misc-common.o no_initrd.o dummy.o
-+lib-$(CONFIG_SOC_AU1X00) += au1k_uart.o
++boot := arch/mips/boot
++compressed := $(boot)/compressed
++utils := $(compressed)/utils
++lib := $(compressed)/lib
++images := $(compressed)/images
++common := $(compressed)/common
++
++#########################################################################
++# START BOARD SPECIFIC VARIABLES
++
++# These two variables control where the zImage is stored
++# in flash and loaded in memory. It only controls how the srec
++# file is generated, the code is the same.
++RAM_RUN_ADDR = 0x81000000
++
++ifdef CONFIG_MIPS_XXS1500
++FLASH_LOAD_ADDR = 0xBF000000
++else
++FLASH_LOAD_ADDR = 0xBFD00000
++endif
++
++# These two variables specify the free ram region
++# that can be used for temporary malloc area
++AVAIL_RAM_START=0x80500000
++AVAIL_RAM_END=0x80900000
++
++# This one must match the LOADADDR in arch/mips/Makefile!
++LOADADDR=0x80100000
++
++# WARNING WARNING WARNING
++# Note that with a LOADADDR of 0x80100000 and AVAIL_RAM_START of
++# 0x80500000, the max decompressed kernel size can be 4MB. Else we
++# start overwriting ourselve. You can change these vars as needed;
++# it would be much better if we just figured everything out on the fly.
++
++# END BOARD SPECIFIC VARIABLES
++#########################################################################
++
++OBJECTS := $(obj)/head.o $(common)/misc-common.o $(common)/misc-simple.o \
++ $(common)/au1k_uart.o
++LIBS := $(lib)/lib.a
++
++ENTRY := $(utils)/entry
++OFFSET := $(utils)/offset
++SIZE := $(utils)/size
++
++LD_ARGS := -T $(compressed)/ld.script -Ttext $(RAM_RUN_ADDR) -Bstatic
++
++ifdef CONFIG_CPU_LITTLE_ENDIAN
++OBJCOPY_ARGS = -O elf32-tradlittlemips
++else
++OBJCOPY_ARGS = -O elf32-tradbigmips
++endif
++
++$(obj)/head.o: $(obj)/head.S $(TOPDIR)/vmlinux
++ $(CC) -I $(TOPDIR)/include $(AFLAGS) \
++ -DKERNEL_ENTRY=$(shell sh $(ENTRY) $(NM) $(TOPDIR)/vmlinux ) \
++ -c -o $*.o $<
++
++$(common)/misc-simple.o:
++ $(CC) -I $(TOPDIR)/include $(CFLAGS) -DINITRD_OFFSET=0 -DINITRD_SIZE=0 -DZIMAGE_OFFSET=0 \
++ -DAVAIL_RAM_START=$(AVAIL_RAM_START) \
++ -DAVAIL_RAM_END=$(AVAIL_RAM_END) \
++ -DLOADADDR=$(LOADADDR) \
++ -DZIMAGE_SIZE=0 -c -o $@ $*.c
++
++$(obj)/zvmlinux: $(OBJECTS) $(LIBS) $(srctree)/$(compressed)/ld.script $(images)/vmlinux.gz $(common)/dummy.o
++ $(OBJCOPY) \
++ --add-section=.image=$(images)/vmlinux.gz \
++ --set-section-flags=.image=contents,alloc,load,readonly,data \
++ $(common)/dummy.o $(common)/image.o
++ $(LD) $(LD_ARGS) -o $@ $(OBJECTS) $(common)/image.o $(LIBS)
++ $(OBJCOPY) $(OBJCOPY_ARGS) $@ $@ -R __kcrctab -R __ksymtab_strings \
++ -R .comment -R .stab -R .stabstr -R .initrd -R .sysmap
++
++# Here we manipulate the image in order to get it the necessary
++# srecord file we need.
++zImage: $(obj)/zvmlinux
++ mv $(obj)/zvmlinux $(images)/zImage
++ $(OBJCOPY) -O srec $(images)/zImage $(images)/zImage.srec
++ $(OBJCOPY) -O binary $(images)/zImage $(images)/zImage.bin
++
++zImage.flash: zImage
++ ( \
++ flash=${FLASH_LOAD_ADDR} ; \
++ ram=${RAM_RUN_ADDR} ; \
++ adjust=$$[ $$flash - $$ram ] ; \
++ $(OBJCOPY) -O srec --adjust-vma `printf '0x%08x' $$adjust` \
++ $(images)/zImage $(images)/zImage.flash.srec ; \
++ )
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/common/au1k_uart.c linux-2.6.16.7.new/arch/mips/boot/compressed/common/au1k_uart.c
--- linux-2.6.16.7/arch/mips/boot/compressed/common/au1k_uart.c 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/common/au1k_uart.c 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/common/au1k_uart.c 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,103 @@
+/*
+ * BRIEF MODULE DESCRIPTION
@@ -1376,15 +344,33 @@ diff -urN linux-2.6.16.7/arch/mips/boot/compressed/common/au1k_uart.c linux-2.6.
+}
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/common/dummy.c linux-2.6.16.7.new/arch/mips/boot/compressed/common/dummy.c
--- linux-2.6.16.7/arch/mips/boot/compressed/common/dummy.c 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/common/dummy.c 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/common/dummy.c 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,4 @@
+int main(void)
+{
+ return 0;
+}
+diff -urN linux-2.6.16.7/arch/mips/boot/compressed/common/Makefile linux-2.6.16.7.new/arch/mips/boot/compressed/common/Makefile
+--- linux-2.6.16.7/arch/mips/boot/compressed/common/Makefile 1970-01-01 01:00:00.000000000 +0100
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/common/Makefile 2006-05-04 23:08:18.000000000 +0200
+@@ -0,0 +1,14 @@
++#
++# arch/mips/boot/compressed/common/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.
++#
++# Tom Rini January 2001
++#
++# Pete Popov, 2004
++#
++
++lib-y := misc-common.o no_initrd.o dummy.o
++lib-$(CONFIG_SOC_AU1X00) += au1k_uart.o
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/common/misc-common.c linux-2.6.16.7.new/arch/mips/boot/compressed/common/misc-common.c
--- linux-2.6.16.7/arch/mips/boot/compressed/common/misc-common.c 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/common/misc-common.c 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/common/misc-common.c 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,434 @@
+/*
+ * arch/mips/boot/compressed/common/misc-common.c
@@ -1822,7 +808,7 @@ diff -urN linux-2.6.16.7/arch/mips/boot/compressed/common/misc-common.c linux-2.
+ */
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/common/misc-simple.c linux-2.6.16.7.new/arch/mips/boot/compressed/common/misc-simple.c
--- linux-2.6.16.7/arch/mips/boot/compressed/common/misc-simple.c 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/common/misc-simple.c 2006-04-20 19:27:22.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/common/misc-simple.c 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,122 @@
+/*
+ * arch/mips/zboot/common/misc-simple.c
@@ -1948,13 +934,13 @@ diff -urN linux-2.6.16.7/arch/mips/boot/compressed/common/misc-simple.c linux-2.
+}
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/common/no_initrd.c linux-2.6.16.7.new/arch/mips/boot/compressed/common/no_initrd.c
--- linux-2.6.16.7/arch/mips/boot/compressed/common/no_initrd.c 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/common/no_initrd.c 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/common/no_initrd.c 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,2 @@
+char initrd_data[1];
+int initrd_len = 0;
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/images/Makefile linux-2.6.16.7.new/arch/mips/boot/compressed/images/Makefile
--- linux-2.6.16.7/arch/mips/boot/compressed/images/Makefile 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/images/Makefile 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/images/Makefile 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,17 @@
+
+#
@@ -1975,7 +961,7 @@ diff -urN linux-2.6.16.7/arch/mips/boot/compressed/images/Makefile linux-2.6.16.
+clean-files := vmlinux* zImage*
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/include/nonstdio.h linux-2.6.16.7.new/arch/mips/boot/compressed/include/nonstdio.h
--- linux-2.6.16.7/arch/mips/boot/compressed/include/nonstdio.h 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/include/nonstdio.h 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/include/nonstdio.h 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,18 @@
+/*
+ * Copyright (C) Paul Mackerras 1997.
@@ -1997,7 +983,7 @@ diff -urN linux-2.6.16.7/arch/mips/boot/compressed/include/nonstdio.h linux-2.6.
+#define perror(s) printf("%s: no files!\n", (s))
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/include/ns16550.h linux-2.6.16.7.new/arch/mips/boot/compressed/include/ns16550.h
--- linux-2.6.16.7/arch/mips/boot/compressed/include/ns16550.h 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/include/ns16550.h 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/include/ns16550.h 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,46 @@
+/*
+ * NS16550 Serial Port
@@ -2047,7 +1033,7 @@ diff -urN linux-2.6.16.7/arch/mips/boot/compressed/include/ns16550.h linux-2.6.1
+#define LSR_ERR 0x80 /* Error */
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/include/pb1000_serial.h linux-2.6.16.7.new/arch/mips/boot/compressed/include/pb1000_serial.h
--- linux-2.6.16.7/arch/mips/boot/compressed/include/pb1000_serial.h 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/include/pb1000_serial.h 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/include/pb1000_serial.h 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,20 @@
+/*
+ * arch/ppc/boot/include/sandpoint_serial.h
@@ -2071,7 +1057,7 @@ diff -urN linux-2.6.16.7/arch/mips/boot/compressed/include/pb1000_serial.h linux
+#define COM4 0x00000000 /* No COM4 */
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/ld.script linux-2.6.16.7.new/arch/mips/boot/compressed/ld.script
--- linux-2.6.16.7/arch/mips/boot/compressed/ld.script 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/ld.script 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/ld.script 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,151 @@
+OUTPUT_ARCH(mips)
+ENTRY(start)
@@ -2226,7 +1212,7 @@ diff -urN linux-2.6.16.7/arch/mips/boot/compressed/ld.script linux-2.6.16.7.new/
+}
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/lib/Makefile linux-2.6.16.7.new/arch/mips/boot/compressed/lib/Makefile
--- linux-2.6.16.7/arch/mips/boot/compressed/lib/Makefile 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/lib/Makefile 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/lib/Makefile 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,11 @@
+
+#
@@ -2239,9 +1225,45 @@ diff -urN linux-2.6.16.7/arch/mips/boot/compressed/lib/Makefile linux-2.6.16.7.n
+ $(addprefix ../../../../../arch/mips/lib/, memcpy.o) \
+
+
+diff -urN linux-2.6.16.7/arch/mips/boot/compressed/Makefile linux-2.6.16.7.new/arch/mips/boot/compressed/Makefile
+--- linux-2.6.16.7/arch/mips/boot/compressed/Makefile 1970-01-01 01:00:00.000000000 +0100
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/Makefile 2006-05-04 23:08:18.000000000 +0200
+@@ -0,0 +1,32 @@
++
++#
++# arch/mips/boot/compressed/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) 1994 by Linus Torvalds
++# Adapted for PowerPC by Gary Thomas
++# modified by Cort (cort@cs.nmt.edu)
++#
++# Ported to MIPS by Pete Popov, ppopov@embeddedalley.com
++#
++
++boot := arch/mips/boot
++compressed := arch/mips/boot/compressed
++
++CFLAGS += -fno-builtin -D__BOOTER__ -I$(compressed)/include
++
++BOOT_TARGETS = zImage zImage.flash
++
++bootdir-$(CONFIG_SOC_AU1X00) := au1xxx
++subdir-y := common lib images
++
++.PHONY: $(BOOT_TARGETS) $(bootdir-y)
++
++$(BOOT_TARGETS): $(bootdir-y)
++
++$(bootdir-y): $(addprefix $(obj)/,$(subdir-y)) \
++ $(addprefix $(obj)/,$(hostprogs-y))
++ $(Q)$(MAKE) $(build)=$(obj)/$@ $(MAKECMDGOALS)
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/utils/entry linux-2.6.16.7.new/arch/mips/boot/compressed/utils/entry
--- linux-2.6.16.7/arch/mips/boot/compressed/utils/entry 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/utils/entry 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/utils/entry 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,12 @@
+#!/bin/sh
+
@@ -2257,16 +1279,1009 @@ diff -urN linux-2.6.16.7/arch/mips/boot/compressed/utils/entry linux-2.6.16.7.ne
+fi
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/utils/offset linux-2.6.16.7.new/arch/mips/boot/compressed/utils/offset
--- linux-2.6.16.7/arch/mips/boot/compressed/utils/offset 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/utils/offset 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/utils/offset 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,3 @@
+#!/bin/sh
+
+echo "0x"`$1 -h $2 | grep $3 | grep -v zvmlinux| awk '{print $6}'`
diff -urN linux-2.6.16.7/arch/mips/boot/compressed/utils/size linux-2.6.16.7.new/arch/mips/boot/compressed/utils/size
--- linux-2.6.16.7/arch/mips/boot/compressed/utils/size 1970-01-01 01:00:00.000000000 +0100
-+++ linux-2.6.16.7.new/arch/mips/boot/compressed/utils/size 2006-04-20 19:27:12.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/compressed/utils/size 2006-05-04 23:08:18.000000000 +0200
@@ -0,0 +1,4 @@
+#!/bin/sh
+
+OFFSET=`$1 -h $2 | grep $3 | grep -v zvmlinux | awk '{print $3}'`
+echo "0x"$OFFSET
+diff -urN linux-2.6.16.7/arch/mips/boot/Makefile linux-2.6.16.7.new/arch/mips/boot/Makefile
+--- linux-2.6.16.7/arch/mips/boot/Makefile 2006-04-17 23:53:25.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/boot/Makefile 2006-05-04 23:08:18.000000000 +0200
+@@ -16,6 +16,7 @@
+ E2EFLAGS =
+ endif
+
++
+ #
+ # Drop some uninteresting sections in the kernel.
+ # This is only relevant for ELF kernels but doesn't hurt a.out
+@@ -25,7 +26,10 @@
+
+ VMLINUX = vmlinux
+
+-all: vmlinux.ecoff vmlinux.srec addinitrd
++ZBOOT_TARGETS = zImage zImage.flash
++bootdir-y := compressed
++
++all: vmlinux.ecoff vmlinux.srec addinitrd zImage
+
+ vmlinux.ecoff: $(obj)/elf2ecoff $(VMLINUX)
+ $(obj)/elf2ecoff $(VMLINUX) vmlinux.ecoff $(E2EFLAGS)
+@@ -51,3 +55,11 @@
+ vmlinux.bin \
+ vmlinux.ecoff \
+ vmlinux.srec
++
++.PHONY: $(ZBOOT_TARGETS) $(bootdir-y)
++
++$(ZBOOT_TARGETS): $(bootdir-y)
++
++$(bootdir-y): $(addprefix $(obj)/,$(subdir-y)) \
++ $(addprefix $(obj)/,$(hostprogs-y))
++ $(Q)$(MAKE) $(build)=$(obj)/$@ $(MAKECMDGOALS)
+diff -urN linux-2.6.16.7/arch/mips/boot/Makefile.orig linux-2.6.16.7.new/arch/mips/boot/Makefile.orig
+--- linux-2.6.16.7/arch/mips/boot/Makefile.orig 1970-01-01 01:00:00.000000000 +0100
++++ linux-2.6.16.7.new/arch/mips/boot/Makefile.orig 2006-05-04 23:08:18.000000000 +0200
+@@ -0,0 +1,53 @@
++#
++# 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) 1995, 1998, 2001, 2002 by Ralf Baechle
++# Copyright (C) 2004 Maciej W. Rozycki
++#
++
++#
++# Some DECstations need all possible sections of an ECOFF executable
++#
++ifdef CONFIG_MACH_DECSTATION
++ E2EFLAGS = -a
++else
++ E2EFLAGS =
++endif
++
++#
++# Drop some uninteresting sections in the kernel.
++# This is only relevant for ELF kernels but doesn't hurt a.out
++#
++drop-sections = .reginfo .mdebug .comment .note .pdr .options .MIPS.options
++strip-flags = $(addprefix --remove-section=,$(drop-sections))
++
++VMLINUX = vmlinux
++
++all: vmlinux.ecoff vmlinux.srec addinitrd
++
++vmlinux.ecoff: $(obj)/elf2ecoff $(VMLINUX)
++ $(obj)/elf2ecoff $(VMLINUX) vmlinux.ecoff $(E2EFLAGS)
++
++$(obj)/elf2ecoff: $(obj)/elf2ecoff.c
++ $(HOSTCC) -o $@ $^
++
++vmlinux.bin: $(VMLINUX)
++ $(OBJCOPY) -O binary $(strip-flags) $(VMLINUX) $(obj)/vmlinux.bin
++
++vmlinux.srec: $(VMLINUX)
++ $(OBJCOPY) -S -O srec $(strip-flags) $(VMLINUX) $(obj)/vmlinux.srec
++
++$(obj)/addinitrd: $(obj)/addinitrd.c
++ $(HOSTCC) -o $@ $^
++
++archhelp:
++ @echo '* vmlinux.ecoff - ECOFF boot image'
++ @echo '* vmlinux.srec - SREC boot image'
++
++clean-files += addinitrd \
++ elf2ecoff \
++ vmlinux.bin \
++ vmlinux.ecoff \
++ vmlinux.srec
+diff -urN linux-2.6.16.7/arch/mips/Makefile linux-2.6.16.7.new/arch/mips/Makefile
+--- linux-2.6.16.7/arch/mips/Makefile 2006-04-17 23:53:25.000000000 +0200
++++ linux-2.6.16.7.new/arch/mips/Makefile 2006-05-04 23:09:44.000000000 +0200
+@@ -831,6 +831,10 @@
+ all: vmlinux.ecoff
+ endif
+
++ifdef CONFIG_MIPS_MTX1
++all: vmlinux.srec zImage zImage.flash
++endif
++
+ vmlinux.bin: $(vmlinux-32)
+ +@$(call makeboot,$@)
+
+@@ -840,6 +844,12 @@
+ vmlinux.srec: $(vmlinux-32)
+ +@$(call makeboot,$@)
+
++zImage: vmlinux
++ +@$(call makeboot,$@)
++
++zImage.flash: vmlinux
++ +@$(call makeboot,$@)
++
+ CLEAN_FILES += vmlinux.ecoff \
+ vmlinux.srec \
+ vmlinux.rm200.tmp \
+@@ -848,6 +858,7 @@
+ archclean:
+ @$(MAKE) $(clean)=arch/mips/boot
+ @$(MAKE) $(clean)=arch/mips/lasat
++ @$(MAKE) $(clean)=arch/mips/boot/compressed
+
+ CLEAN_FILES += vmlinux.32 \
+ vmlinux.64 \
+diff -urN linux-2.6.16.7/arch/mips/Makefile.orig linux-2.6.16.7.new/arch/mips/Makefile.orig
+--- linux-2.6.16.7/arch/mips/Makefile.orig 1970-01-01 01:00:00.000000000 +0100
++++ linux-2.6.16.7.new/arch/mips/Makefile.orig 2006-05-04 23:09:55.000000000 +0200
+@@ -0,0 +1,862 @@
++#
++# 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) 1994, 95, 96, 2003 by Ralf Baechle
++# DECStation modifications by Paul M. Antoine, 1996
++# Copyright (C) 2002, 2003, 2004 Maciej W. Rozycki
++#
++# This file is included by the global makefile so that you can add your own
++# architecture-specific flags and dependencies. Remember to do have actions
++# for "archclean" cleaning up for this architecture.
++#
++
++as-option = $(shell if $(CC) $(CFLAGS) $(1) -Wa,-Z -c -o /dev/null \
++ -xassembler /dev/null > /dev/null 2>&1; then echo "$(1)"; \
++ else echo "$(2)"; fi ;)
++
++cflags-y :=
++
++#
++# Select the object file format to substitute into the linker script.
++#
++ifdef CONFIG_CPU_LITTLE_ENDIAN
++32bit-tool-prefix = mipsel-linux-
++64bit-tool-prefix = mips64el-linux-
++32bit-bfd = elf32-tradlittlemips
++64bit-bfd = elf64-tradlittlemips
++32bit-emul = elf32ltsmip
++64bit-emul = elf64ltsmip
++else
++32bit-tool-prefix = mips-linux-
++64bit-tool-prefix = mips64-linux-
++32bit-bfd = elf32-tradbigmips
++64bit-bfd = elf64-tradbigmips
++32bit-emul = elf32btsmip
++64bit-emul = elf64btsmip
++endif
++
++ifdef CONFIG_32BIT
++gcc-abi = 32
++tool-prefix = $(32bit-tool-prefix)
++UTS_MACHINE := mips
++endif
++ifdef CONFIG_64BIT
++gcc-abi = 64
++tool-prefix = $(64bit-tool-prefix)
++UTS_MACHINE := mips64
++endif
++
++ifdef CONFIG_CROSSCOMPILE
++CROSS_COMPILE := $(tool-prefix)
++endif
++
++CHECKFLAGS-y += -D__linux__ -D__mips__ \
++ -D_MIPS_SZINT=32 \
++ -D_ABIO32=1 \
++ -D_ABIN32=2 \
++ -D_ABI64=3
++CHECKFLAGS-$(CONFIG_32BIT) += -D_MIPS_SIM=_ABIO32 \
++ -D_MIPS_SZLONG=32 \
++ -D_MIPS_SZPTR=32 \
++ -D__PTRDIFF_TYPE__=int
++CHECKFLAGS-$(CONFIG_64BIT) += -m64 -D_MIPS_SIM=_ABI64 \
++ -D_MIPS_SZLONG=64 \
++ -D_MIPS_SZPTR=64 \
++ -D__PTRDIFF_TYPE__="long int"
++CHECKFLAGS-$(CONFIG_CPU_BIG_ENDIAN) += -D__MIPSEB__
++CHECKFLAGS-$(CONFIG_CPU_LITTLE_ENDIAN) += -D__MIPSEL__
++
++CHECKFLAGS = $(CHECKFLAGS-y)
++
++ifdef CONFIG_BUILD_ELF64
++gas-abi = 64
++ld-emul = $(64bit-emul)
++vmlinux-32 = vmlinux.32
++vmlinux-64 = vmlinux
++else
++gas-abi = 32
++ld-emul = $(32bit-emul)
++vmlinux-32 = vmlinux
++vmlinux-64 = vmlinux.64
++
++cflags-$(CONFIG_64BIT) += $(call cc-option,-mno-explicit-relocs)
++endif
++
++#
++# GCC uses -G 0 -mabicalls -fpic as default. We don't want PIC in the kernel
++# code since it only slows down the whole thing. At some point we might make
++# use of global pointer optimizations but their use of $28 conflicts with
++# the current pointer optimization.
++#
++# The DECStation requires an ECOFF kernel for remote booting, other MIPS
++# machines may also. Since BFD is incredibly buggy with respect to
++# crossformat linking we rely on the elf2ecoff tool for format conversion.
++#
++cflags-y += -G 0 -mno-abicalls -fno-pic -pipe
++cflags-y += -msoft-float
++LDFLAGS_vmlinux += -G 0 -static -n -nostdlib
++MODFLAGS += -mlong-calls
++
++#
++# We explicitly add the endianness specifier if needed, this allows
++# to compile kernels with a toolchain for the other endianness. We
++# carefully avoid to add it redundantly because gcc 3.3/3.4 complains
++# when fed the toolchain default!
++#
++cflags-$(CONFIG_CPU_BIG_ENDIAN) += $(shell $(CC) -dumpmachine |grep -q 'mips.*el-.*' && echo -EB)
++cflags-$(CONFIG_CPU_LITTLE_ENDIAN) += $(shell $(CC) -dumpmachine |grep -q 'mips.*el-.*' || echo -EL)
++
++cflags-$(CONFIG_SB1XXX_CORELIS) += $(call cc-option,-mno-sched-prolog) \
++ -fno-omit-frame-pointer
++
++#
++# Use: $(call set_gccflags,<cpu0>,<isa0>,<cpu1>,<isa1>,<isa2>)
++#
++# <cpu0>,<isa0> -- preferred CPU and ISA designations (may require
++# recent tools)
++# <cpu1>,<isa1> -- fallback CPU and ISA designations (have to work
++# with up to the oldest supported tools)
++# <isa2> -- an ISA designation used as an ABI selector for
++# gcc versions that do not support "-mabi=32"
++# (depending on the CPU type, either "mips1" or
++# "mips2")
++#
++set_gccflags = $(shell \
++while :; do \
++ cpu=$(1); isa=-$(2); \
++ for gcc_opt in -march= -mcpu=; do \
++ $(CC) $$gcc_opt$$cpu $$isa -S -o /dev/null \
++ -xc /dev/null > /dev/null 2>&1 && \
++ break 2; \
++ done; \
++ cpu=$(3); isa=-$(4); \
++ for gcc_opt in -march= -mcpu=; do \
++ $(CC) $$gcc_opt$$cpu $$isa -S -o /dev/null \
++ -xc /dev/null > /dev/null 2>&1 && \
++ break 2; \
++ done; \
++ break; \
++done; \
++gcc_abi=-mabi=$(gcc-abi); gcc_cpu=$$cpu; \
++if $(CC) $$gcc_abi -S -o /dev/null -xc /dev/null > /dev/null 2>&1; then \
++ gcc_isa=$$isa; \
++else \
++ gcc_abi=; gcc_isa=-$(5); \
++fi; \
++gas_abi=-Wa,-$(gcc-abi); gas_cpu=$$cpu; gas_isa=-Wa,$$isa; \
++while :; do \
++ for gas_opt in -Wa,-march= -Wa,-mcpu=; do \
++ $(CC) $$gas_abi $$gas_opt$$cpu $$gas_isa -Wa,-Z -c \
++ -o /dev/null -xassembler /dev/null > /dev/null 2>&1 && \
++ break 2; \
++ done; \
++ gas_abi=; gas_opt=; gas_cpu=; gas_isa=; \
++ break; \
++done; \
++if test "$(gcc-abi)" != "$(gas-abi)"; then \
++ gas_abi="-Wa,-$(gas-abi) -Wa,-mgp$(gcc-abi)"; \
++fi; \
++if test "$$gcc_opt" = -march= && test -n "$$gcc_abi"; then \
++ $(CC) $$gcc_abi $$gcc_opt$$gcc_cpu -S -o /dev/null \
++ -xc /dev/null > /dev/null 2>&1 && \
++ gcc_isa=; \
++fi; \
++echo $$gcc_abi $$gcc_opt$$gcc_cpu $$gcc_isa $$gas_abi $$gas_opt$$gas_cpu $$gas_isa)
++
++#
++# CPU-dependent compiler/assembler options for optimization.
++#
++cflags-$(CONFIG_CPU_R3000) += \
++ $(call set_gccflags,r3000,mips1,r3000,mips1,mips1)
++CHECKFLAGS-$(CONFIG_CPU_R3000) += -D_MIPS_ISA=_MIPS_ISA_MIPS1
++
++cflags-$(CONFIG_CPU_TX39XX) += \
++ $(call set_gccflags,r3900,mips1,r3000,mips1,mips1)
++CHECKFLAGS-$(CONFIG_CPU_TX39XX) += -D_MIPS_ISA=_MIPS_ISA_MIPS1
++
++cflags-$(CONFIG_CPU_R6000) += \
++ $(call set_gccflags,r6000,mips2,r6000,mips2,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_R6000) += -D_MIPS_ISA=_MIPS_ISA_MIPS2
++
++cflags-$(CONFIG_CPU_R4300) += \
++ $(call set_gccflags,r4300,mips3,r4300,mips3,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_R4300) += -D_MIPS_ISA=_MIPS_ISA_MIPS3
++
++cflags-$(CONFIG_CPU_VR41XX) += \
++ $(call set_gccflags,r4100,mips3,r4600,mips3,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_VR41XX) += -D_MIPS_ISA=_MIPS_ISA_MIPS3
++
++cflags-$(CONFIG_CPU_R4X00) += \
++ $(call set_gccflags,r4600,mips3,r4600,mips3,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_R4X00) += -D_MIPS_ISA=_MIPS_ISA_MIPS3
++
++cflags-$(CONFIG_CPU_TX49XX) += \
++ $(call set_gccflags,r4600,mips3,r4600,mips3,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_TX49XX) += -D_MIPS_ISA=_MIPS_ISA_MIPS3
++
++cflags-$(CONFIG_CPU_MIPS32_R1) += \
++ $(call set_gccflags,mips32,mips32,r4600,mips3,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_MIPS32_R1) += -D_MIPS_ISA=_MIPS_ISA_MIPS32
++
++cflags-$(CONFIG_CPU_MIPS32_R2) += \
++ $(call set_gccflags,mips32r2,mips32r2,r4600,mips3,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_MIPS32_R2) += -D_MIPS_ISA=_MIPS_ISA_MIPS32
++
++cflags-$(CONFIG_CPU_MIPS64_R1) += \
++ $(call set_gccflags,mips64,mips64,r4600,mips3,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_MIPS64_R1) += -D_MIPS_ISA=_MIPS_ISA_MIPS64
++
++cflags-$(CONFIG_CPU_MIPS64_R2) += \
++ $(call set_gccflags,mips64r2,mips64r2,r4600,mips3,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_MIPS64_R2) += -D_MIPS_ISA=_MIPS_ISA_MIPS64
++
++cflags-$(CONFIG_CPU_R5000) += \
++ $(call set_gccflags,r5000,mips4,r5000,mips4,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_R5000) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
++
++cflags-$(CONFIG_CPU_R5432) += \
++ $(call set_gccflags,r5400,mips4,r5000,mips4,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_R5432) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
++
++cflags-$(CONFIG_CPU_NEVADA) += \
++ $(call set_gccflags,rm5200,mips4,r5000,mips4,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_NEVADA) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
++
++cflags-$(CONFIG_CPU_RM7000) += \
++ $(call set_gccflags,rm7000,mips4,r5000,mips4,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_RM7000) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
++
++cflags-$(CONFIG_CPU_RM9000) += \
++ $(call set_gccflags,rm9000,mips4,r5000,mips4,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_RM9000) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
++
++
++cflags-$(CONFIG_CPU_SB1) += \
++ $(call set_gccflags,sb1,mips64,r5000,mips4,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_SB1) += -D_MIPS_ISA=_MIPS_ISA_MIPS64
++
++cflags-$(CONFIG_CPU_R8000) += \
++ $(call set_gccflags,r8000,mips4,r8000,mips4,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_R8000) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
++
++cflags-$(CONFIG_CPU_R10000) += \
++ $(call set_gccflags,r10000,mips4,r8000,mips4,mips2) \
++ -Wa,--trap
++CHECKFLAGS-$(CONFIG_CPU_R10000) += -D_MIPS_ISA=_MIPS_ISA_MIPS4
++
++ifdef CONFIG_CPU_SB1
++ifdef CONFIG_SB1_PASS_1_WORKAROUNDS
++MODFLAGS += -msb1-pass1-workarounds
++endif
++endif
++
++#
++# Firmware support
++#
++libs-$(CONFIG_ARC) += arch/mips/arc/
++libs-$(CONFIG_SIBYTE_CFE) += arch/mips/sibyte/cfe/
++
++#
++# Board-dependent options and extra files
++#
++
++#
++# Acer PICA 61, Mips Magnum 4000 and Olivetti M700.
++#
++core-$(CONFIG_MACH_JAZZ) += arch/mips/jazz/
++cflags-$(CONFIG_MACH_JAZZ) += -Iinclude/asm-mips/mach-jazz
++load-$(CONFIG_MACH_JAZZ) += 0xffffffff80080000
++
++#
++# Common Alchemy Au1x00 stuff
++#
++core-$(CONFIG_SOC_AU1X00) += arch/mips/au1000/common/
++cflags-$(CONFIG_SOC_AU1X00) += -Iinclude/asm-mips/mach-au1x00
++
++#
++# AMD Alchemy Pb1000 eval board
++#
++libs-$(CONFIG_MIPS_PB1000) += arch/mips/au1000/pb1000/
++cflags-$(CONFIG_MIPS_PB1000) += -Iinclude/asm-mips/mach-pb1x00
++load-$(CONFIG_MIPS_PB1000) += 0xffffffff80100000
++
++#
++# AMD Alchemy Pb1100 eval board
++#
++libs-$(CONFIG_MIPS_PB1100) += arch/mips/au1000/pb1100/
++cflags-$(CONFIG_MIPS_PB1100) += -Iinclude/asm-mips/mach-pb1x00
++load-$(CONFIG_MIPS_PB1100) += 0xffffffff80100000
++
++#
++# AMD Alchemy Pb1500 eval board
++#
++libs-$(CONFIG_MIPS_PB1500) += arch/mips/au1000/pb1500/
++cflags-$(CONFIG_MIPS_PB1500) += -Iinclude/asm-mips/mach-pb1x00
++load-$(CONFIG_MIPS_PB1500) += 0xffffffff80100000
++
++#
++# AMD Alchemy Pb1550 eval board
++#
++libs-$(CONFIG_MIPS_PB1550) += arch/mips/au1000/pb1550/
++cflags-$(CONFIG_MIPS_PB1550) += -Iinclude/asm-mips/mach-pb1x00
++load-$(CONFIG_MIPS_PB1550) += 0xffffffff80100000
++
++#
++# AMD Alchemy Pb1200 eval board
++#
++libs-$(CONFIG_MIPS_PB1200) += arch/mips/au1000/pb1200/
++cflags-$(CONFIG_MIPS_PB1200) += -Iinclude/asm-mips/mach-pb1x00
++load-$(CONFIG_MIPS_PB1200) += 0xffffffff80100000
++
++#
++# AMD Alchemy Db1000 eval board
++#
++libs-$(CONFIG_MIPS_DB1000) += arch/mips/au1000/db1x00/
++cflags-$(CONFIG_MIPS_DB1000) += -Iinclude/asm-mips/mach-db1x00
++load-$(CONFIG_MIPS_DB1000) += 0xffffffff80100000
++
++#
++# AMD Alchemy Db1100 eval board
++#
++libs-$(CONFIG_MIPS_DB1100) += arch/mips/au1000/db1x00/
++cflags-$(CONFIG_MIPS_DB1100) += -Iinclude/asm-mips/mach-db1x00
++load-$(CONFIG_MIPS_DB1100) += 0xffffffff80100000
++
++#
++# AMD Alchemy Db1500 eval board
++#
++libs-$(CONFIG_MIPS_DB1500) += arch/mips/au1000/db1x00/
++cflags-$(CONFIG_MIPS_DB1500) += -Iinclude/asm-mips/mach-db1x00
++load-$(CONFIG_MIPS_DB1500) += 0xffffffff80100000
++
++#
++# AMD Alchemy Db1550 eval board
++#
++libs-$(CONFIG_MIPS_DB1550) += arch/mips/au1000/db1x00/
++cflags-$(CONFIG_MIPS_DB1550) += -Iinclude/asm-mips/mach-db1x00
++load-$(CONFIG_MIPS_DB1550) += 0xffffffff80100000
++
++#
++# AMD Alchemy Db1200 eval board
++#
++libs-$(CONFIG_MIPS_DB1200) += arch/mips/au1000/pb1200/
++cflags-$(CONFIG_MIPS_DB1200) += -Iinclude/asm-mips/mach-db1x00
++load-$(CONFIG_MIPS_DB1200) += 0xffffffff80100000
++
++#
++# AMD Alchemy Bosporus eval board
++#
++libs-$(CONFIG_MIPS_BOSPORUS) += arch/mips/au1000/db1x00/
++cflags-$(CONFIG_MIPS_BOSPORUS) += -Iinclude/asm-mips/mach-db1x00
++load-$(CONFIG_MIPS_BOSPORUS) += 0xffffffff80100000
++
++#
++# AMD Alchemy Mirage eval board
++#
++libs-$(CONFIG_MIPS_MIRAGE) += arch/mips/au1000/db1x00/
++cflags-$(CONFIG_MIPS_MIRAGE) += -Iinclude/asm-mips/mach-db1x00
++load-$(CONFIG_MIPS_MIRAGE) += 0xffffffff80100000
++
++#
++# 4G-Systems eval board
++#
++libs-$(CONFIG_MIPS_MTX1) += arch/mips/au1000/mtx-1/
++load-$(CONFIG_MIPS_MTX1) += 0xffffffff80100000
++
++#
++# MyCable eval board
++#
++libs-$(CONFIG_MIPS_XXS1500) += arch/mips/au1000/xxs1500/
++load-$(CONFIG_MIPS_XXS1500) += 0xffffffff80100000
++
++#
++# Cobalt Server
++#
++core-$(CONFIG_MIPS_COBALT) += arch/mips/cobalt/
++cflags-$(CONFIG_MIPS_COBALT) += -Iinclude/asm-mips/mach-cobalt
++load-$(CONFIG_MIPS_COBALT) += 0xffffffff80080000
++
++#
++# DECstation family
++#
++core-$(CONFIG_MACH_DECSTATION) += arch/mips/dec/
++cflags-$(CONFIG_MACH_DECSTATION)+= -Iinclude/asm-mips/mach-dec
++libs-$(CONFIG_MACH_DECSTATION) += arch/mips/dec/prom/
++load-$(CONFIG_MACH_DECSTATION) += 0xffffffff80040000
++CLEAN_FILES += drivers/tc/lk201-map.c
++
++#
++# Galileo EV64120 Board
++#
++core-$(CONFIG_MIPS_EV64120) += arch/mips/gt64120/ev64120/
++core-$(CONFIG_MIPS_EV64120) += arch/mips/gt64120/common/
++cflags-$(CONFIG_MIPS_EV64120) += -Iinclude/asm-mips/mach-ev64120
++load-$(CONFIG_MIPS_EV64120) += 0xffffffff80100000
++
++#
++# Galileo EV96100 Board
++#
++core-$(CONFIG_MIPS_EV96100) += arch/mips/galileo-boards/ev96100/
++cflags-$(CONFIG_MIPS_EV96100) += -Iinclude/asm-mips/mach-ev96100
++load-$(CONFIG_MIPS_EV96100) += 0xffffffff80100000
++
++#
++# Globespan IVR eval board with QED 5231 CPU
++#
++core-$(CONFIG_ITE_BOARD_GEN) += arch/mips/ite-boards/generic/
++core-$(CONFIG_MIPS_IVR) += arch/mips/ite-boards/ivr/
++load-$(CONFIG_MIPS_IVR) += 0xffffffff80100000
++
++#
++# ITE 8172 eval board with QED 5231 CPU
++#
++core-$(CONFIG_MIPS_ITE8172) += arch/mips/ite-boards/qed-4n-s01b/
++load-$(CONFIG_MIPS_ITE8172) += 0xffffffff80100000
++
++#
++# For all MIPS, Inc. eval boards
++#
++core-$(CONFIG_MIPS_BOARDS_GEN) += arch/mips/mips-boards/generic/
++
++#
++# MIPS Atlas board
++#
++core-$(CONFIG_MIPS_ATLAS) += arch/mips/mips-boards/atlas/
++cflags-$(CONFIG_MIPS_ATLAS) += -Iinclude/asm-mips/mach-atlas
++cflags-$(CONFIG_MIPS_ATLAS) += -Iinclude/asm-mips/mach-mips
++load-$(CONFIG_MIPS_ATLAS) += 0xffffffff80100000
++
++#
++# MIPS Malta board
++#
++core-$(CONFIG_MIPS_MALTA) += arch/mips/mips-boards/malta/
++cflags-$(CONFIG_MIPS_MALTA) += -Iinclude/asm-mips/mach-mips
++load-$(CONFIG_MIPS_MALTA) += 0xffffffff80100000
++
++#
++# MIPS SEAD board
++#
++core-$(CONFIG_MIPS_SEAD) += arch/mips/mips-boards/sead/
++load-$(CONFIG_MIPS_SEAD) += 0xffffffff80100000
++
++#
++# MIPS SIM
++#
++core-$(CONFIG_MIPS_SIM) += arch/mips/mips-boards/sim/
++cflags-$(CONFIG_MIPS_SIM) += -Iinclude/asm-mips/mach-sim
++load-$(CONFIG_MIPS_SIM) += 0x80100000
++
++#
++# Momentum Ocelot board
++#
++# The Ocelot setup.o must be linked early - it does the ioremap() for the
++# mips_io_port_base.
++#
++core-$(CONFIG_MOMENCO_OCELOT) += arch/mips/gt64120/common/ \
++ arch/mips/gt64120/momenco_ocelot/
++cflags-$(CONFIG_MOMENCO_OCELOT) += -Iinclude/asm-mips/mach-ocelot
++load-$(CONFIG_MOMENCO_OCELOT) += 0xffffffff80100000
++
++#
++# Momentum Ocelot-G board
++#
++# The Ocelot-G setup.o must be linked early - it does the ioremap() for the
++# mips_io_port_base.
++#
++core-$(CONFIG_MOMENCO_OCELOT_G) += arch/mips/momentum/ocelot_g/
++load-$(CONFIG_MOMENCO_OCELOT_G) += 0xffffffff80100000
++
++#
++# Momentum Ocelot-C and -CS boards
++#
++# The Ocelot-C[S] setup.o must be linked early - it does the ioremap() for the
++# mips_io_port_base.
++core-$(CONFIG_MOMENCO_OCELOT_C) += arch/mips/momentum/ocelot_c/
++load-$(CONFIG_MOMENCO_OCELOT_C) += 0xffffffff80100000
++
++#
++# PMC-Sierra Yosemite
++#
++core-$(CONFIG_PMC_YOSEMITE) += arch/mips/pmc-sierra/yosemite/
++cflags-$(CONFIG_PMC_YOSEMITE) += -Iinclude/asm-mips/mach-yosemite
++load-$(CONFIG_PMC_YOSEMITE) += 0xffffffff80100000
++
++# Qemu simulating MIPS32 4Kc
++#
++core-$(CONFIG_QEMU) += arch/mips/qemu/
++cflags-$(CONFIG_QEMU) += -Iinclude/asm-mips/mach-qemu
++load-$(CONFIG_QEMU) += 0xffffffff80010000
++
++#
++# Momentum Ocelot-3
++#
++core-$(CONFIG_MOMENCO_OCELOT_3) += arch/mips/momentum/ocelot_3/
++cflags-$(CONFIG_MOMENCO_OCELOT_3) += -Iinclude/asm-mips/mach-ocelot3
++load-$(CONFIG_MOMENCO_OCELOT_3) += 0xffffffff80100000
++
++#
++# Momentum Jaguar ATX
++#
++core-$(CONFIG_MOMENCO_JAGUAR_ATX) += arch/mips/momentum/jaguar_atx/
++cflags-$(CONFIG_MOMENCO_JAGUAR_ATX) += -Iinclude/asm-mips/mach-ja
++#ifdef CONFIG_JAGUAR_DMALOW
++#load-$(CONFIG_MOMENCO_JAGUAR_ATX) += 0xffffffff88000000
++#else
++load-$(CONFIG_MOMENCO_JAGUAR_ATX) += 0xffffffff80100000
++#endif
++
++#
++# NEC DDB
++#
++core-$(CONFIG_DDB5XXX_COMMON) += arch/mips/ddb5xxx/common/
++
++#
++# NEC DDB Vrc-5074
++#
++core-$(CONFIG_DDB5074) += arch/mips/ddb5xxx/ddb5074/
++load-$(CONFIG_DDB5074) += 0xffffffff80080000
++
++#
++# NEC DDB Vrc-5476
++#
++core-$(CONFIG_DDB5476) += arch/mips/ddb5xxx/ddb5476/
++load-$(CONFIG_DDB5476) += 0xffffffff80080000
++
++#
++# NEC DDB Vrc-5477
++#
++core-$(CONFIG_DDB5477) += arch/mips/ddb5xxx/ddb5477/
++load-$(CONFIG_DDB5477) += 0xffffffff80100000
++
++core-$(CONFIG_LASAT) += arch/mips/lasat/
++cflags-$(CONFIG_LASAT) += -Iinclude/asm-mips/mach-lasat
++load-$(CONFIG_LASAT) += 0xffffffff80000000
++
++#
++# Common VR41xx
++#
++core-$(CONFIG_MACH_VR41XX) += arch/mips/vr41xx/common/
++cflags-$(CONFIG_MACH_VR41XX) += -Iinclude/asm-mips/mach-vr41xx
++
++#
++# NEC VR4133
++#
++core-$(CONFIG_NEC_CMBVR4133) += arch/mips/vr41xx/nec-cmbvr4133/
++load-$(CONFIG_NEC_CMBVR4133) += 0xffffffff80100000
++
++#
++# ZAO Networks Capcella (VR4131)
++#
++load-$(CONFIG_ZAO_CAPCELLA) += 0xffffffff80000000
++
++#
++# Victor MP-C303/304 (VR4122)
++#
++load-$(CONFIG_VICTOR_MPC30X) += 0xffffffff80001000
++
++#
++# IBM WorkPad z50 (VR4121)
++#
++core-$(CONFIG_IBM_WORKPAD) += arch/mips/vr41xx/ibm-workpad/
++load-$(CONFIG_IBM_WORKPAD) += 0xffffffff80004000
++
++#
++# CASIO CASSIPEIA E-55/65 (VR4111)
++#
++core-$(CONFIG_CASIO_E55) += arch/mips/vr41xx/casio-e55/
++load-$(CONFIG_CASIO_E55) += 0xffffffff80004000
++
++#
++# TANBAC VR4131 multichip module(TB0225) and TANBAC VR4131DIMM(TB0229) (VR4131)
++#
++load-$(CONFIG_TANBAC_TB022X) += 0xffffffff80000000
++
++#
++# Common Philips PNX8550
++#
++core-$(CONFIG_SOC_PNX8550) += arch/mips/philips/pnx8550/common/
++cflags-$(CONFIG_SOC_PNX8550) += -Iinclude/asm-mips/mach-pnx8550
++
++#
++# Philips PNX8550 JBS board
++#
++libs-$(CONFIG_PNX8550_JBS) += arch/mips/philips/pnx8550/jbs/
++#cflags-$(CONFIG_PNX8550_JBS) += -Iinclude/asm-mips/mach-pnx8550
++load-$(CONFIG_PNX8550_JBS) += 0xffffffff80060000
++
++#
++# SGI IP22 (Indy/Indigo2)
++#
++# Set the load address to >= 0xffffffff88069000 if you want to leave space for
++# symmon, 0xffffffff80002000 for production kernels. Note that the value must
++# be aligned to a multiple of the kernel stack size or the handling of the
++# current variable will break so for 64-bit kernels we have to raise the start
++# address by 8kb.
++#
++core-$(CONFIG_SGI_IP22) += arch/mips/sgi-ip22/
++cflags-$(CONFIG_SGI_IP22) += -Iinclude/asm-mips/mach-ip22
++ifdef CONFIG_32BIT
++load-$(CONFIG_SGI_IP22) += 0xffffffff88002000
++endif
++ifdef CONFIG_64BIT
++load-$(CONFIG_SGI_IP22) += 0xffffffff88004000
++endif
++
++#
++# SGI-IP27 (Origin200/2000)
++#
++# Set the load address to >= 0xc000000000300000 if you want to leave space for
++# symmon, 0xc00000000001c000 for production kernels. Note that the value must
++# be 16kb aligned or the handling of the current variable will break.
++#
++ifdef CONFIG_SGI_IP27
++core-$(CONFIG_SGI_IP27) += arch/mips/sgi-ip27/
++cflags-$(CONFIG_SGI_IP27) += -Iinclude/asm-mips/mach-ip27
++ifdef CONFIG_BUILD_ELF64
++ifdef CONFIG_MAPPED_KERNEL
++load-$(CONFIG_SGI_IP27) += 0xc00000004001c000
++OBJCOPYFLAGS := --change-addresses=0x3fffffff80000000
++dataoffset-$(CONFIG_SGI_IP27) += 0x01000000
++else
++load-$(CONFIG_SGI_IP27) += 0xa80000000001c000
++OBJCOPYFLAGS := --change-addresses=0x57ffffff80000000
++endif
++else
++ifdef CONFIG_MAPPED_KERNEL
++load-$(CONFIG_SGI_IP27) += 0xffffffffc001c000
++OBJCOPYFLAGS := --change-addresses=0xc000000080000000
++dataoffset-$(CONFIG_SGI_IP27) += 0x01000000
++else
++load-$(CONFIG_SGI_IP27) += 0xffffffff8001c000
++OBJCOPYFLAGS := --change-addresses=0xa800000080000000
++endif
++endif
++endif
++
++#
++# SGI-IP32 (O2)
++#
++# Set the load address to >= 80069000 if you want to leave space for symmon,
++# 0xffffffff80004000 for production kernels. Note that the value must be aligned to
++# a multiple of the kernel stack size or the handling of the current variable
++# will break.
++#
++core-$(CONFIG_SGI_IP32) += arch/mips/sgi-ip32/
++cflags-$(CONFIG_SGI_IP32) += -Iinclude/asm-mips/mach-ip32
++load-$(CONFIG_SGI_IP32) += 0xffffffff80004000
++
++#
++# Sibyte SB1250 SOC
++#
++# This is a LIB so that it links at the end, and initcalls are later
++# the sequence; but it is built as an object so that modules don't get
++# removed (as happens, even if they have __initcall/module_init)
++#
++core-$(CONFIG_SIBYTE_BCM112X) += arch/mips/sibyte/sb1250/
++cflags-$(CONFIG_SIBYTE_BCM112X) += -Iinclude/asm-mips/mach-sibyte \
++ -DSIBYTE_HDR_FEATURES=SIBYTE_HDR_FMASK_1250_112x_ALL
++
++core-$(CONFIG_SIBYTE_SB1250) += arch/mips/sibyte/sb1250/
++cflags-$(CONFIG_SIBYTE_SB1250) += -Iinclude/asm-mips/mach-sibyte \
++ -DSIBYTE_HDR_FEATURES=SIBYTE_HDR_FMASK_1250_112x_ALL
++
++core-$(CONFIG_SIBYTE_BCM1x55) += arch/mips/sibyte/bcm1480/
++cflags-$(CONFIG_SIBYTE_BCM1x55) += -Iinclude/asm-mips/mach-sibyte \
++ -DSIBYTE_HDR_FEATURES=SIBYTE_HDR_FMASK_1480_ALL
++
++core-$(CONFIG_SIBYTE_BCM1x80) += arch/mips/sibyte/bcm1480/
++cflags-$(CONFIG_SIBYTE_BCM1x80) += -Iinclude/asm-mips/mach-sibyte \
++ -DSIBYTE_HDR_FEATURES=SIBYTE_HDR_FMASK_1480_ALL
++
++#
++# Sibyte BCM91120x (Carmel) board
++# Sibyte BCM91120C (CRhine) board
++# Sibyte BCM91125C (CRhone) board
++# Sibyte BCM91125E (Rhone) board
++# Sibyte SWARM board
++# Sibyte BCM91x80 (BigSur) board
++#
++libs-$(CONFIG_SIBYTE_CARMEL) += arch/mips/sibyte/swarm/
++load-$(CONFIG_SIBYTE_CARMEL) := 0xffffffff80100000
++libs-$(CONFIG_SIBYTE_CRHINE) += arch/mips/sibyte/swarm/
++load-$(CONFIG_SIBYTE_CRHINE) := 0xffffffff80100000
++libs-$(CONFIG_SIBYTE_CRHONE) += arch/mips/sibyte/swarm/
++load-$(CONFIG_SIBYTE_CRHONE) := 0xffffffff80100000
++libs-$(CONFIG_SIBYTE_RHONE) += arch/mips/sibyte/swarm/
++load-$(CONFIG_SIBYTE_RHONE) := 0xffffffff80100000
++libs-$(CONFIG_SIBYTE_SENTOSA) += arch/mips/sibyte/swarm/
++load-$(CONFIG_SIBYTE_SENTOSA) := 0xffffffff80100000
++libs-$(CONFIG_SIBYTE_SWARM) += arch/mips/sibyte/swarm/
++load-$(CONFIG_SIBYTE_SWARM) := 0xffffffff80100000
++libs-$(CONFIG_SIBYTE_BIGSUR) += arch/mips/sibyte/swarm/
++load-$(CONFIG_SIBYTE_BIGSUR) := 0xffffffff80100000
++
++#
++# SNI RM200 PCI
++#
++core-$(CONFIG_SNI_RM200_PCI) += arch/mips/sni/
++cflags-$(CONFIG_SNI_RM200_PCI) += -Iinclude/asm-mips/mach-rm200
++load-$(CONFIG_SNI_RM200_PCI) += 0xffffffff80600000
++
++#
++# Toshiba JMR-TX3927 board
++#
++core-$(CONFIG_TOSHIBA_JMR3927) += arch/mips/jmr3927/rbhma3100/ \
++ arch/mips/jmr3927/common/
++cflags-$(CONFIG_TOSHIBA_JMR3927) += -Iinclude/asm-mips/mach-jmr3927
++load-$(CONFIG_TOSHIBA_JMR3927) += 0xffffffff80050000
++
++#
++# Toshiba RBTX4927 board or
++# Toshiba RBTX4937 board
++#
++core-$(CONFIG_TOSHIBA_RBTX4927) += arch/mips/tx4927/toshiba_rbtx4927/
++core-$(CONFIG_TOSHIBA_RBTX4927) += arch/mips/tx4927/common/
++load-$(CONFIG_TOSHIBA_RBTX4927) += 0xffffffff80020000
++
++#
++# Toshiba RBTX4938 board
++#
++core-$(CONFIG_TOSHIBA_RBTX4938) += arch/mips/tx4938/toshiba_rbtx4938/
++core-$(CONFIG_TOSHIBA_RBTX4938) += arch/mips/tx4938/common/
++load-$(CONFIG_TOSHIBA_RBTX4938) += 0xffffffff80100000
++
++cflags-y += -Iinclude/asm-mips/mach-generic
++drivers-$(CONFIG_PCI) += arch/mips/pci/
++
++ifdef CONFIG_32BIT
++ifdef CONFIG_CPU_LITTLE_ENDIAN
++JIFFIES = jiffies_64
++else
++JIFFIES = jiffies_64 + 4
++endif
++else
++JIFFIES = jiffies_64
++endif
++
++AFLAGS += $(cflags-y)
++CFLAGS += $(cflags-y)
++
++LDFLAGS += -m $(ld-emul)
++
++OBJCOPYFLAGS += --remove-section=.reginfo
++
++#
++# Choosing incompatible machines durings configuration will result in
++# error messages during linking. Select a default linkscript if
++# none has been choosen above.
++#
++
++CPPFLAGS_vmlinux.lds := \
++ $(CFLAGS) \
++ -D"LOADADDR=$(load-y)" \
++ -D"JIFFIES=$(JIFFIES)" \
++ -D"DATAOFFSET=$(if $(dataoffset-y),$(dataoffset-y),0)"
++
++head-y := arch/mips/kernel/head.o arch/mips/kernel/init_task.o
++
++libs-y += arch/mips/lib/
++libs-$(CONFIG_32BIT) += arch/mips/lib-32/
++libs-$(CONFIG_64BIT) += arch/mips/lib-64/
++
++core-y += arch/mips/kernel/ arch/mips/mm/ arch/mips/math-emu/
++
++drivers-$(CONFIG_OPROFILE) += arch/mips/oprofile/
++
++ifdef CONFIG_LASAT
++rom.bin rom.sw: vmlinux
++ $(Q)$(MAKE) $(build)=arch/mips/lasat/image $@
++endif
++
++#
++# Some machines like the Indy need 32-bit ELF binaries for booting purposes.
++# Other need ECOFF, so we build a 32-bit ELF binary for them which we then
++# convert to ECOFF using elf2ecoff.
++#
++vmlinux.32: vmlinux
++ $(OBJCOPY) -O $(32bit-bfd) $(OBJCOPYFLAGS) $< $@
++
++#
++# The 64-bit ELF tools are pretty broken so at this time we generate 64-bit
++# ELF files from 32-bit files by conversion.
++#
++vmlinux.64: vmlinux
++ $(OBJCOPY) -O $(64bit-bfd) $(OBJCOPYFLAGS) $< $@
++
++makeboot =$(Q)$(MAKE) $(build)=arch/mips/boot VMLINUX=$(vmlinux-32) $(1)
++
++ifdef CONFIG_BOOT_ELF32
++all: $(vmlinux-32)
++endif
++
++ifdef CONFIG_BOOT_ELF64
++all: $(vmlinux-64)
++endif
++
++ifdef CONFIG_MIPS_ATLAS
++all: vmlinux.srec
++endif
++
++ifdef CONFIG_MIPS_MALTA
++all: vmlinux.srec
++endif
++
++ifdef CONFIG_MIPS_SEAD
++all: vmlinux.srec
++endif
++
++ifdef CONFIG_QEMU
++all: vmlinux.bin
++endif
++
++ifdef CONFIG_SNI_RM200_PCI
++all: vmlinux.ecoff
++endif
++
++ifdef CONFIG_MIPS_MTX1
++all: vmlinux.srec zImage zImage.flash
++endif
++
++vmlinux.bin: $(vmlinux-32)
++ +@$(call makeboot,$@)
++
++vmlinux.ecoff vmlinux.rm200: $(vmlinux-32)
++ +@$(call makeboot,$@)
++
++vmlinux.srec: $(vmlinux-32)
++ +@$(call makeboot,$@)
++
++zImage: vmlinux
++ +@$(call makeboot,$@)
++
++CLEAN_FILES += vmlinux.ecoff \
++ vmlinux.srec \
++ vmlinux.rm200.tmp \
++ vmlinux.rm200
++
++archclean:
++ @$(MAKE) $(clean)=arch/mips/boot
++ @$(MAKE) $(clean)=arch/mips/lasat
++ @$(MAKE) $(clean)=arch/mips/boot/compressed
++
++CLEAN_FILES += vmlinux.32 \
++ vmlinux.64 \
++ vmlinux.ecoff