patch-2.2.18 linux/arch/arm/Makefile
Next file: linux/arch/arm/boot/Makefile
Previous file: linux/arch/alpha/vmlinux.lds
Back to the patch index
Back to the overall index
- Lines: 395
- Date:
Fri Sep 15 23:28:37 2000
- Orig file:
v2.2.17/arch/arm/Makefile
- Orig date:
Fri Apr 21 12:45:45 2000
diff -u --new-file --recursive --exclude-from /usr/src/exclude v2.2.17/arch/arm/Makefile linux/arch/arm/Makefile
@@ -10,217 +10,172 @@
# License. See the file "COPYING" in the main directory of this archive
# for more details.
#
-# Copyright (C) 1995, 1996 by Russell King
+# Copyright (C) 1995-1999 by Russell King
-CFLAGS_PROC :=
-ASFLAGS_PROC :=
+LD := $(CROSS_COMPILE)ld
+OBJCOPY := $(CROSS_COMPILE)objcopy -O binary -R .note -R .comment -S
+OBJDUMP = $(CROSS_COMPILE)objdump
+CPP := $(CC) -E
+PERL := perl
+LINKFLAGS := -p -X -T arch/arm/vmlinux.lds
+ARCHCC := $(word 1,$(CC))
+
+AFLAGS += -mno-fpu
+CFLAGS_PIPE := -pipe
+CFLAGS := $(CFLAGS) $(CFLAGS_PIPE)
+
+ifdef CONFIG_FRAME_POINTER
+CFLAGS := $(CFLAGS:-fomit-frame-pointer=)
+endif
+
+ifdef CONFIG_DEBUG_INFO
+CFLAGS += -g
+endif
-# All processors get `-mshort-load-bytes' for now, to work around alignment
-# problems. This is more of a hack that just happens to work than a real fix
-# but it will do for now.
+# Ensure this is ld "2.9.4" or later
+NEW_LINKER := $(shell if $(LD) --gc-sections --version >/dev/null 2>&1; then echo y; else echo n; fi)
+
+ifneq ($(NEW_LINKER),y)
+dummy:; @echo '*** 2.2 kernels no longer build correctly with old versions of binutils.'
+ @echo '*** Please upgrade your binutils to 2.9.5.'
+ @false
+endif
+
+
+# GCC 2.7 uses different options to later compilers; sort out which we have
+NEW_GCC := $(shell if $(CC) --version 2>&1 | grep '^2\.7' > /dev/null; then echo n; else echo y; fi)
+
+#
+# select flags depending on the compiler
+#
+ifeq ($(NEW_GCC),y)
+CFLAGS += -mshort-load-bytes -msoft-float
+CFLAGS_PROC_CPU_26 := -mcpu=arm3 -Os
+CFLAGS_PROC_CPU_32v3 := -march=armv3
+CFLAGS_PROC_CPU_32v4 := -march=armv4
+CFLAGS_ARM6 := -mtune=arm6
+CFLAGS_ARM7 := -mtune=arm7
+CFLAGS_SA110 := -mtune=strongarm110
+else
+CFLAGS_PROC_CPU_26 := -m3
+CFLAGS_PROC_CPU_32v3 :=
+CFLAGS_PROC_CPU_32v4 :=
+CFLAGS_ARM6 := -m6
+CFLAGS_ARM7 := -m6
+CFLAGS_SA110 := -m6
+endif
+#
+# Select CPU dependent flags
+#
ifeq ($(CONFIG_CPU_26),y)
- PROCESSOR = armo
- TEXTADDR = 0x02080000
- ZTEXTADDR = 0x01800000
- ZRELADDR = 0x02080000
- ifeq ($(CONFIG_BINUTILS_NEW),y)
- CFLAGS_PROC += -mapcs-26 -mshort-load-bytes
- ifeq ($(CONFIG_CPU_ARM2),y)
- CFLAGS_PROC += -mcpu=arm2
- ASFLAGS_PROC += -m2
- endif
- ifeq ($(CONFIG_CPU_ARM3),y)
- CFLAGS_PROC += -mcpu=arm3
- ASFLAGS_PROC += -m3
- endif
- else
- ifeq ($(CONFIG_CPU_ARM2),y)
- CFLAGS_PROC += -m2
- ASFLAGS_PROC += -m2
- endif
- ifeq ($(CONFIG_CPU_ARM3),y)
- CFLAGS_PROC += -m3
- ASFLAGS_PROC += -m3
- endif
- endif
+ PROCESSOR = armo
+ TEXTADDR = 0x02080000
+ CFLAGS += $(CFLAGS_PROC_CPU_26)
+ AFLAGS += -mapcs-26
endif
ifeq ($(CONFIG_CPU_32),y)
- PROCESSOR = armv
- TEXTADDR = 0xC0008000
- ifeq ($(CONFIG_BINUTILS_NEW),y)
- CFLAGS_PROC += -mapcs-32 -mshort-load-bytes
- ifeq ($(CONFIG_CPU_ARM6),y)
- CFLAGS_PROC += -mcpu=arm6
- endif
- ifeq ($(CONFIG_CPU_ARM7),y)
- CFLAGS_PROC += -mcpu=arm7
- endif
- ifeq ($(CONFIG_CPU_SA110),y)
- CFLAGS_PROC += -mcpu=strongarm110
- endif
- else
- CFLAGS_PROC += -m6
- endif
- ASFLAGS_PROC += -m6
-endif
-
-# Processor Architecture
-# CFLAGS_PROC - processor dependent CFLAGS
-# PROCESSOR - processor type
-# TEXTADDR - Uncompressed kernel link text address
-# ZTEXTADDR - Compressed kernel link text address
-# ZRELADDR - Compressed kernel relocating address (point at which uncompressed kernel is loaded).
-#
+ PROCESSOR = armv
+ TEXTADDR = 0xC0008000
+ ifeq ($(CONFIG_CPU_32v4),y)
+ CFLAGS += $(CFLAGS_PROC_CPU_32v4)
+ AFLAGS += -mapcs-32 -marmv4
+ else
+ CFLAGS += $(CFLAGS_PROC_CPU_32v3)
+ AFLAGS += -mapcs-32 -marmv3m
+ endif
+ #
+ # Exactly one of the following must be selected
+ #
+ ifeq ($(CONFIG_CPU_ARM6),y)
+ CFLAGS += $(CFLAGS_ARM6)
+ else
+ ifeq ($(CONFIG_CPU_ARM7),y)
+ CFLAGS += $(CFLAGS_ARM7)
+ else
+ ifeq ($(CONFIG_CPU_SA110),y)
+ CFLAGS += $(CFLAGS_SA110)
+ endif
+ endif
+ endif
+endif
-COMPRESSED_HEAD = head.o
+GCCLIB := $(shell $(CC) $(CFLAGS) --print-libgcc-file-name)
ifeq ($(CONFIG_ARCH_A5K),y)
MACHINE = a5k
ARCHDIR = arc
-COMPRESSED_EXTRA = $(TOPDIR)/arch/arm/lib/ll_char_wr.o
endif
ifeq ($(CONFIG_ARCH_ARC),y)
MACHINE = arc
ARCHDIR = arc
-COMPRESSED_EXTRA = $(TOPDIR)/arch/arm/lib/ll_char_wr.o
endif
ifeq ($(CONFIG_ARCH_RPC),y)
MACHINE = rpc
ARCHDIR = rpc
-COMPRESSED_EXTRA = $(TOPDIR)/arch/arm/lib/ll_char_wr.o
-ZTEXTADDR = 0x10008000
-ZRELADDR = 0x10008000
endif
ifeq ($(CONFIG_ARCH_EBSA110),y)
MACHINE = ebsa110
ARCHDIR = ebsa110
-ZTEXTADDR = 0x00008000
-ZRELADDR = 0x00008000
endif
-ifeq ($(CONFIG_ARCH_EBSA285),y)
-MACHINE = ebsa285
+ifeq ($(CONFIG_FOOTBRIDGE),y)
+MACHINE = footbridge
ARCHDIR = ebsa285
-ZTEXTADDR = 0x00008000
-ZRELADDR = 0x00008000
+endif
+
+ifeq ($(CONFIG_ARCH_CO285),y)
+TEXTADDR = 0x60008000
endif
ifeq ($(CONFIG_ARCH_NEXUSPCI),y)
MACHINE = nexuspci
ARCHDIR = nexuspci
-ZTEXTADDR = 0x40200000
-ZRELADDR = 0x40008000
-COMPRESSED_EXTRA = $(TOPDIR)/arch/arm/lib/ll_char_wr_scc.o
-COMPRESSED_HEAD = head-nexuspci.o
-endif
-
-ifeq ($(CONFIG_ARCH_VNC),y)
-TEXTADDR = 0xC000C000
-MACHINE = vnc
-ARCHDIR = vnc
-endif
-
-ifeq ($(CONFIG_ARCH_TBOX),y)
-MACHINE = tbox
-ARCHDIR = tbox
-ZTEXTADDR = 0x80008000
-ZRELDIR = 0x80008000
endif
-PERL = perl
-ifeq ($(CONFIG_BINUTILS_NEW),y)
-LD = $(CROSS_COMPILE)ld -m elf32arm
-else
-LD = $(CROSS_COMPILE)ld -m elf_arm
-endif
-OBJCOPY = $(CROSS_COMPILE)objcopy -O binary -R .note -R .comment -S
-OBJDUMP = $(CROSS_COMPILE)objdump
-CPP = $(CC) -E
-ARCHCC := $(word 1,$(CC))
-GCCLIB := `$(CC) $(CFLAGS_PROC) --print-libgcc-file-name`
-#GCCARCH := -B/usr/bin/arm-linuxelf-
-HOSTCFLAGS := $(CFLAGS:-fomit-frame-pointer=)
-ifeq ($(CONFIG_FRAME_POINTER),y)
-CFLAGS := $(CFLAGS:-fomit-frame-pointer=)
-endif
-CFLAGS := $(CFLAGS_PROC) $(CFLAGS) -pipe
-ASFLAGS := $(ASFLAGS_PROC) $(ASFLAGS)
-LINKFLAGS = -T $(TOPDIR)/arch/arm/vmlinux-$(PROCESSOR).lds -e stext -Ttext $(TEXTADDR)
-ZLINKFLAGS = -Ttext $(ZTEXTADDR)
-
-SUBDIRS := $(SUBDIRS:drivers=arch/arm/drivers) arch/arm/lib arch/arm/kernel arch/arm/mm
-HEAD := arch/arm/kernel/head-$(PROCESSOR).o arch/arm/kernel/init_task.o
+HEAD := arch/arm/kernel/head-$(PROCESSOR).o \
+ arch/arm/kernel/init_task.o
+SUBDIRS += arch/arm/kernel arch/arm/mm arch/arm/lib \
+ arch/arm/special arch/arm/nwfpe
CORE_FILES := arch/arm/kernel/kernel.o arch/arm/mm/mm.o $(CORE_FILES)
-LIBS := arch/arm/lib/lib.a $(LIBS) $(GCCLIB)
+LIBS := arch/arm/lib/lib.o arch/arm/lib/lib.a $(LIBS) $(GCCLIB)
+DRIVERS += arch/arm/special/special.a
-BLOCK_DRIVERS := drivers/block/block.a
-CDROM_DRIVERS := drivers/cdrom/cdrom.a
-ifeq ($(CONFIG_FB),y)
-CHAR_DRIVERS := arch/arm/drivers/char1/char1.a drivers/char/char.a arch/arm/drivers/char1/char1.a
-else
-ifeq ($(CONFIG_VGA_CONSOLE),y)
-CHAR_DRIVERS := arch/arm/drivers/char1/char1.a drivers/char/char.a arch/arm/drivers/char1/char1.a
-else
-CHAR_DRIVERS := arch/arm/drivers/char/char.a
+ifeq ($(CONFIG_NWFPE),y)
+LIBS := arch/arm/nwfpe/math-emu.a $(LIBS)
endif
-endif
-MISC_DRIVERS := drivers/misc/misc.a
-NET_DRIVERS := drivers/net/net.a
-PARIDE_DRIVERS := drivers/block/paride/paride.a
-PCI_DRIVERS := drivers/pci/pci.a
-SCSI_DRIVERS := drivers/scsi/scsi.a
-SOUND_DRIVERS := drivers/sound/sound.a
-VIDEO_DRIVERS := drivers/video/video.a
-PNP_DRIVERS := drivers/pnp/pnp.a
ifeq ($(CONFIG_ARCH_ACORN),y)
-BLOCK_DRIVERS += drivers/acorn/block/acorn-block.a
-CHAR_DRIVERS += drivers/acorn/char/acorn-char.a
-NET_DRIVERS += drivers/acorn/net/acorn-net.a drivers/net/net.a
-SCSI_DRIVERS += drivers/acorn/scsi/acorn-scsi.a
+SUBDIRS += drivers/acorn
+DRIVERS += drivers/acorn/block/acorn-block.a
+DRIVERS += drivers/acorn/char/acorn-char.a
+DRIVERS += drivers/acorn/net/acorn-net.a
+DRIVERS += drivers/acorn/scsi/acorn-scsi.a
endif
-DRIVERS := $(BLOCK_DRIVERS) $(CHAR_DRIVERS) $(MISC_DRIVERS) $(NET_DRIVERS)
+MAKEBOOT = $(MAKE) -C arch/$(ARCH)/boot
-ifeq ($(CONFIG_FB),y)
-DRIVERS := $(DRIVERS) $(VIDEO_DRIVERS)
-else
-ifeq ($(CONFIG_VGA_CONSOLE),y)
-DRIVERS := $(DRIVERS) $(VIDEO_DRIVERS)
-endif
-endif
-ifeq ($(CONFIG_SCSI),y)
-DRIVERS := $(DRIVERS) $(SCSI_DRIVERS)
-endif
-ifneq ($(CONFIG_CD_NO_IDESCSI)$(CONFIG_BLK_DEV_IDECD)$(CONFIG_BLK_DEV_SR),)
-DRIVERS := $(DRIVERS) $(CDROM_DRIVERS)
-endif
-ifdef CONFIG_PCI
-DRIVERS := $(DRIVERS) $(PCI_DRIVERS)
-endif
-ifeq ($(CONFIG_SOUND),y)
-DRIVERS := $(DRIVERS) $(SOUND_DRIVERS)
-endif
-ifeq ($(CONFIG_PARIDE),y)
-DRIVERS := $(DRIVERS) $(PARIDE_DRIVERS)
-endif
-ifdef CONFIG_PNP
-DRIVERS := $(DRIVERS) $(PNP_DRIVERS)
-endif
+# The following is a hack to get 'constants.h' up
+# to date before starting compilation
+CONSTANTS := constants
+
+constants: $(TOPDIR)/include/asm-arm/proc-fns.h dummy
+ @$(MAKE) -C arch/arm/lib constants.h
+
+symlinks: archsymlinks
-symlinks::
+archsymlinks:
$(RM) include/asm-arm/arch include/asm-arm/proc
(cd include/asm-arm; ln -sf arch-$(ARCHDIR) arch; ln -sf proc-$(PROCESSOR) proc)
-# Once we've finished integrating the sources, the @$(MAKE) will disappear
-archmrproper:
- rm -f include/asm-arm/arch include/asm-arm/proc
- @$(MAKE) -C arch/$(ARCH)/drivers mrproper
+vmlinux: arch/arm/vmlinux.lds
+
+arch/arm/vmlinux.lds: arch/arm/vmlinux-$(PROCESSOR).lds.in dummy
+ @sed 's/TEXTADDR/$(TEXTADDR)/' <$< >$@
arch/arm/kernel: dummy
$(MAKE) linuxsubdirs SUBDIRS=arch/arm/kernel
@@ -231,19 +186,19 @@
arch/arm/lib: dummy
$(MAKE) linuxsubdirs SUBDIRS=arch/arm/lib
-MAKEBOOT = $(MAKE) -C arch/$(ARCH)/boot
+zImage zinstall Image install: vmlinux
+ @$(MAKEBOOT) $@
-zImage: vmlinux
- @$(MAKEBOOT) zImage
-
-zinstall: vmlinux
- @$(MAKEBOOT) zinstall
+archmrproper:
+ @$(MAKE) -C arch/$(ARCH)/special mrproper
+ $(RM) include/asm-arm/arch include/asm-arm/proc
-Image: vmlinux
- @$(MAKEBOOT) Image
+archclean:
+ @$(MAKEBOOT) clean
+ $(RM) arch/arm/lib/constants.h arch/arm/vmlinux.lds
-install: vmlinux
- @$(MAKEBOOT) install
+archdep:
+ @$(MAKEBOOT) dep
# My testing targets (that short circuit a few dependencies)
zImg:; @$(MAKEBOOT) zImage
@@ -251,10 +206,23 @@
i:; @$(MAKEBOOT) install
zi:; @$(MAKEBOOT) zinstall
-archclean:
- @$(MAKEBOOT) clean
- $(RM) arch/arm/lib/constants.h
+#
+# Configuration targets. Use these to select a
+# configuration for your architecture
+#
+a5k_config:
+ $(RM) arch/arm/defconfig
+ cp arch/arm/def-configs/a5k arch/arm/defconfig
+
+ebsa110_config:
+ $(RM) arch/arm/defconfig
+ cp arch/arm/def-configs/ebsa110 arch/arm/defconfig
+
+footbridge_config:
+ $(RM) arch/arm/defconfig
+ cp arch/arm/def-configs/footbridge arch/arm/defconfig
+
+rpc_config:
+ $(RM) arch/arm/defconfig
+ cp arch/arm/def-configs/rpc arch/arm/defconfig
-archdep:
- @$(MAKEBOOT) dep
-sed -e /^MACHINE..*=/s,= .*,= rpc,;/^PROCESSOR..*=/s,= .*,= armv, linux/arch/arm/Makefile.normal
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)