2005-04-16 15:20:36 -07:00
#
# arch/arm/Makefile
#
2006-03-05 17:14:10 -05:00
# This file is included by the global makefile so that you can add your own
# architecture-specific flags and dependencies.
#
2005-04-16 15:20:36 -07:00
# 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-2001 by Russell King
LDFLAGS_vmlinux := -p --no-undefined -X
2006-01-03 17:28:33 +00:00
CPPFLAGS_vmlinux.lds = -DTEXT_OFFSET= $( TEXT_OFFSET)
2007-10-12 14:38:54 +01:00
OBJCOPYFLAGS := -O binary -R .note -R .note.gnu.build-id -R .comment -S
2005-04-16 15:20:36 -07:00
GZFLAGS := -9
2007-10-14 22:21:35 +02:00
#KBUILD_CFLAGS +=-pipe
2006-12-05 18:28:04 +01:00
# Explicitly specifiy 32-bit ARM ISA since toolchain default can be -mthumb:
2007-10-14 22:21:35 +02:00
KBUILD_CFLAGS += $( call cc-option,-marm,)
2005-04-16 15:20:36 -07:00
# Do not use arch/arm/defconfig - it's always outdated.
# Select a platform tht is kept up-to-date
KBUILD_DEFCONFIG := versatile_defconfig
2006-03-27 15:14:19 +01:00
# defines filename extension depending memory manement type.
i f e q ( $( CONFIG_MMU ) , )
MMUEXT := -nommu
e n d i f
2005-04-16 15:20:36 -07:00
i f e q ( $( CONFIG_FRAME_POINTER ) , y )
2007-10-14 22:21:35 +02:00
KBUILD_CFLAGS += -fno-omit-frame-pointer -mapcs -mno-sched-prolog
2005-04-16 15:20:36 -07:00
e n d i f
i f e q ( $( CONFIG_CPU_BIG_ENDIAN ) , y )
2007-10-15 22:17:25 +02:00
KBUILD_CPPFLAGS += -mbig-endian
2005-04-16 15:20:36 -07:00
AS += -EB
LD += -EB
e l s e
2007-10-15 22:17:25 +02:00
KBUILD_CPPFLAGS += -mlittle-endian
2005-04-16 15:20:36 -07:00
AS += -EL
LD += -EL
e n d i f
comma = ,
# This selects which instruction set is used.
# Note that GCC does not numerically define an architecture version
# macro, but instead defines a whole series of macros which makes
# testing for a specific architecture or later rather impossible.
2007-05-08 22:45:26 +01:00
arch-$(CONFIG_CPU_32v7) := -D__LINUX_ARM_ARCH__= 7 $( call cc-option,-march= armv7a,-march= armv5t -Wa$( comma) -march= armv7a)
2005-04-16 15:20:36 -07:00
arch-$(CONFIG_CPU_32v6) := -D__LINUX_ARM_ARCH__= 6 $( call cc-option,-march= armv6,-march= armv5t -Wa$( comma) -march= armv6)
2007-05-08 22:45:26 +01:00
# Only override the compiler option if ARMv6. The ARMv6K extensions are
# always available in ARMv7
i f e q ( $( CONFIG_CPU_ 32v 6) , y )
2005-11-03 15:48:21 +00:00
arch-$(CONFIG_CPU_32v6K) := -D__LINUX_ARM_ARCH__= 6 $( call cc-option,-march= armv6k,-march= armv5t -Wa$( comma) -march= armv6k)
2007-05-08 22:45:26 +01:00
e n d i f
2006-08-28 12:51:20 +01:00
arch-$(CONFIG_CPU_32v5) := -D__LINUX_ARM_ARCH__= 5 $( call cc-option,-march= armv5te,-march= armv4t)
arch-$(CONFIG_CPU_32v4T) := -D__LINUX_ARM_ARCH__= 4 -march= armv4t
2005-04-16 15:20:36 -07:00
arch-$(CONFIG_CPU_32v4) := -D__LINUX_ARM_ARCH__= 4 -march= armv4
arch-$(CONFIG_CPU_32v3) := -D__LINUX_ARM_ARCH__= 3 -march= armv3
# This selects how we optimise for the processor.
tune-$(CONFIG_CPU_ARM610) := -mtune= arm610
tune-$(CONFIG_CPU_ARM710) := -mtune= arm710
2006-09-26 17:37:36 +09:00
tune-$(CONFIG_CPU_ARM7TDMI) := -mtune= arm7tdmi
2005-04-16 15:20:36 -07:00
tune-$(CONFIG_CPU_ARM720T) := -mtune= arm7tdmi
2006-09-26 17:37:50 +09:00
tune-$(CONFIG_CPU_ARM740T) := -mtune= arm7tdmi
2006-09-26 17:38:05 +09:00
tune-$(CONFIG_CPU_ARM9TDMI) := -mtune= arm9tdmi
2006-09-26 17:38:18 +09:00
tune-$(CONFIG_CPU_ARM940T) := -mtune= arm9tdmi
2006-09-26 17:38:32 +09:00
tune-$(CONFIG_CPU_ARM946T) := $( call cc-option,-mtune= arm9e,-mtune= arm9tdmi)
2005-04-16 15:20:36 -07:00
tune-$(CONFIG_CPU_ARM920T) := -mtune= arm9tdmi
tune-$(CONFIG_CPU_ARM922T) := -mtune= arm9tdmi
tune-$(CONFIG_CPU_ARM925T) := -mtune= arm9tdmi
tune-$(CONFIG_CPU_ARM926T) := -mtune= arm9tdmi
tune-$(CONFIG_CPU_SA110) := -mtune= strongarm110
tune-$(CONFIG_CPU_SA1100) := -mtune= strongarm1100
tune-$(CONFIG_CPU_XSCALE) := $( call cc-option,-mtune= xscale,-mtune= strongarm110) -Wa,-mcpu= xscale
2006-03-28 21:00:40 +01:00
tune-$(CONFIG_CPU_XSC3) := $( call cc-option,-mtune= xscale,-mtune= strongarm110) -Wa,-mcpu= xscale
2005-10-12 19:58:09 +01:00
tune-$(CONFIG_CPU_V6) := $( call cc-option,-mtune= arm1136j-s,-mtune= strongarm)
2005-04-16 15:20:36 -07:00
2006-01-14 16:33:50 +00:00
i f e q ( $( CONFIG_AEABI ) , y )
2006-04-25 20:36:04 +01:00
CFLAGS_ABI := -mabi= aapcs-linux -mno-thumb-interwork
2006-01-14 16:33:50 +00:00
e l s e
2005-06-30 17:04:14 +01:00
CFLAGS_ABI := $( call cc-option,-mapcs-32,-mabi= apcs-gnu) $( call cc-option,-mno-thumb-interwork,)
2006-01-14 16:33:50 +00:00
e n d i f
# Need -Uarm for gcc < 3.x
2007-10-14 22:21:35 +02:00
KBUILD_CFLAGS += $( CFLAGS_ABI) $( arch-y) $( tune-y) $( call cc-option,-mshort-load-bytes,$( call cc-option,-malignment-traps,) ) -msoft-float -Uarm
2007-10-15 21:59:31 +02:00
KBUILD_AFLAGS += $( CFLAGS_ABI) $( arch-y) $( tune-y) -msoft-float
2005-04-16 15:20:36 -07:00
CHECKFLAGS += -D__arm__
#Default value
2006-03-27 14:58:25 +01:00
head-y := arch/arm/kernel/head$( MMUEXT) .o arch/arm/kernel/init_task.o
2006-01-03 17:28:33 +00:00
textofs-y := 0x00008000
2005-04-16 15:20:36 -07:00
machine-$( CONFIG_ARCH_RPC) := rpc
machine-$( CONFIG_ARCH_EBSA110) := ebsa110
machine-$( CONFIG_ARCH_CLPS7500) := clps7500
incdir-$( CONFIG_ARCH_CLPS7500) := cl7500
machine-$( CONFIG_FOOTBRIDGE) := footbridge
incdir-$( CONFIG_FOOTBRIDGE) := ebsa285
machine-$( CONFIG_ARCH_CO285) := footbridge
incdir-$( CONFIG_ARCH_CO285) := ebsa285
machine-$( CONFIG_ARCH_SHARK) := shark
machine-$( CONFIG_ARCH_SA1100) := sa1100
i f e q ( $( CONFIG_ARCH_SA 1100) , y )
# SA1111 DMA bug: we don't want the kernel to live in precious DMA-able memory
2006-01-03 17:28:33 +00:00
textofs-$( CONFIG_SA1111) := 0x00208000
2005-04-16 15:20:36 -07:00
e n d i f
machine-$( CONFIG_ARCH_PXA) := pxa
machine-$( CONFIG_ARCH_L7200) := l7200
machine-$( CONFIG_ARCH_INTEGRATOR) := integrator
2006-01-03 17:28:33 +00:00
textofs-$( CONFIG_ARCH_CLPS711X) := 0x00028000
2005-04-16 15:20:36 -07:00
machine-$( CONFIG_ARCH_CLPS711X) := clps711x
2006-09-18 23:10:26 +01:00
machine-$( CONFIG_ARCH_IOP32X) := iop32x
machine-$( CONFIG_ARCH_IOP33X) := iop33x
2006-12-07 02:59:39 +01:00
machine-$( CONFIG_ARCH_IOP13XX) := iop13xx
2005-04-16 15:20:36 -07:00
machine-$( CONFIG_ARCH_IXP4XX) := ixp4xx
machine-$( CONFIG_ARCH_IXP2000) := ixp2000
[ARM] 3388/1: ixp23xx: add core ixp23xx support
Patch from Lennert Buytenhek
This patch adds support for the Intel ixp23xx series of CPUs. The
ixp23xx is an XSC3 based CPU with 512K of L2 cache, a 64bit 66MHz PCI
interface, two DDR RAM interfaces, QDR RAM interfaces, two gigabit
MACs, two 10/100 MACs, expansion bus, four microengines, a Media and
Switch Fabric unit almost identical to the one on the ixp2400, two
xscale (8250ish) UARTs and a bunch of other stuff.
This patch adds the core ixp23xx support code, and support for the
ADI Engineering Roadrunner, Intel IXDP2351, and IP Fabrics Double
Espresso platforms.
Signed-off-by: Deepak Saxena <dsaxena@plexity.net>
Signed-off-by: Lennert Buytenhek <buytenh@wantstofly.org>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
2006-03-28 21:18:54 +01:00
machine-$( CONFIG_ARCH_IXP23XX) := ixp23xx
2005-07-10 19:58:17 +01:00
machine-$( CONFIG_ARCH_OMAP1) := omap1
2005-11-10 14:26:51 +00:00
machine-$( CONFIG_ARCH_OMAP2) := omap2
2005-07-10 19:58:17 +01:00
incdir-$( CONFIG_ARCH_OMAP) := omap
2005-04-16 15:20:36 -07:00
machine-$( CONFIG_ARCH_S3C2410) := s3c2410
machine-$( CONFIG_ARCH_LH7A40X) := lh7a40x
machine-$( CONFIG_ARCH_VERSATILE) := versatile
machine-$( CONFIG_ARCH_IMX) := imx
machine-$( CONFIG_ARCH_H720X) := h720x
2005-06-20 18:51:05 +01:00
machine-$( CONFIG_ARCH_AAEC2000) := aaec2000
2005-10-31 14:25:02 +00:00
machine-$( CONFIG_ARCH_REALVIEW) := realview
2007-02-19 21:28:53 -08:00
machine-$( CONFIG_ARCH_AT91) := at91
2007-02-16 15:36:55 +01:00
machine-$( CONFIG_ARCH_EP93XX) := ep93xx
machine-$( CONFIG_ARCH_PNX4008) := pnx4008
machine-$( CONFIG_ARCH_NETX) := netx
machine-$( CONFIG_ARCH_NS9XXX) := ns9xxx
textofs-$( CONFIG_ARCH_NS9XXX) := 0x00108000
2007-04-30 19:37:19 +01:00
machine-$( CONFIG_ARCH_DAVINCI) := davinci
2007-05-11 21:01:28 +01:00
machine-$( CONFIG_ARCH_KS8695) := ks8695
2007-07-09 22:06:53 +01:00
incdir-$( CONFIG_ARCH_MXC) := mxc
machine-$( CONFIG_ARCH_MX3) := mx3
2007-11-26 04:11:43 -08:00
machine-$( CONFIG_ARCH_MSM7X00A) := msm
2005-04-16 15:20:36 -07:00
i f e q ( $( CONFIG_ARCH_EBSA 110) , y )
# This is what happens if you forget the IOCS16 line.
# PCMCIA cards stop working.
CFLAGS_3c589_cs.o := -DISA_SIXTEEN_BIT_PERIPHERAL
export C F L A G S _ 3 c 5 8 9 _ c s . o
e n d i f
2006-01-03 17:28:33 +00:00
# The byte offset of the kernel image in RAM from the start of RAM.
TEXT_OFFSET := $( textofs-y)
2005-04-16 15:20:36 -07:00
i f e q ( $( incdir -y ) , )
incdir-y := $( machine-y)
e n d i f
INCDIR := arch-$( incdir-y)
2005-10-29 21:44:56 +01:00
2005-04-16 15:20:36 -07:00
i f n e q ( $( machine -y ) , )
MACHINE := arch/arm/mach-$( machine-y) /
e l s e
MACHINE :=
e n d i f
2007-02-11 18:31:01 +01:00
2006-03-27 15:14:19 +01:00
export TEXT_OFFSET GZFLAGS MMUEXT
2005-04-16 15:20:36 -07:00
# Do we have FASTFPE?
FASTFPE := arch/arm/fastfpe
i f e q ( $( FASTFPE ) , $( wildcard $ ( FASTFPE ) ) )
FASTFPE_OBJ := $( FASTFPE) /
e n d i f
# If we have a machine-specific directory, then include it in the build.
core-y += arch/arm/kernel/ arch/arm/mm/ arch/arm/common/
core-y += $( MACHINE)
2007-02-11 18:31:01 +01:00
core-$(CONFIG_ARCH_S3C2410) += arch/arm/mach-s3c2400/
core-$(CONFIG_ARCH_S3C2410) += arch/arm/mach-s3c2412/
core-$(CONFIG_ARCH_S3C2410) += arch/arm/mach-s3c2440/
core-$(CONFIG_ARCH_S3C2410) += arch/arm/mach-s3c2442/
2007-02-16 12:12:31 +01:00
core-$(CONFIG_ARCH_S3C2410) += arch/arm/mach-s3c2443/
2005-04-16 15:20:36 -07:00
core-$(CONFIG_FPE_NWFPE) += arch/arm/nwfpe/
core-$(CONFIG_FPE_FASTFPE) += $( FASTFPE_OBJ)
core-$(CONFIG_VFP) += arch/arm/vfp/
2005-07-10 19:58:17 +01:00
# If we have a common platform directory, then include it in the build.
2006-09-18 23:12:53 +01:00
core-$(CONFIG_PLAT_IOP) += arch/arm/plat-iop/
2005-07-10 19:58:17 +01:00
core-$(CONFIG_ARCH_OMAP) += arch/arm/plat-omap/
2007-02-11 18:31:01 +01:00
core-$(CONFIG_PLAT_S3C24XX) += arch/arm/plat-s3c24xx/
2007-07-09 22:06:53 +01:00
core-$(CONFIG_ARCH_MXC) += arch/arm/plat-mxc/
2005-07-10 19:58:17 +01:00
2005-04-16 15:20:36 -07:00
drivers-$(CONFIG_OPROFILE) += arch/arm/oprofile/
drivers-$(CONFIG_ARCH_CLPS7500) += drivers/acorn/char/
drivers-$(CONFIG_ARCH_L7200) += drivers/acorn/char/
2005-11-04 17:17:30 +00:00
libs-y := arch/arm/lib/ $( libs-y)
2005-04-16 15:20:36 -07:00
# Default target when executing plain make
i f e q ( $( CONFIG_XIP_KERNEL ) , y )
2006-10-29 12:51:05 +00:00
KBUILD_IMAGE := xipImage
2005-04-16 15:20:36 -07:00
e l s e
2006-10-29 12:51:05 +00:00
KBUILD_IMAGE := zImage
2005-04-16 15:20:36 -07:00
e n d i f
2006-10-29 12:51:05 +00:00
all : $( KBUILD_IMAGE )
2005-04-16 15:20:36 -07:00
boot := arch/arm/boot
# Update machine arch and proc symlinks if something which affects
# them changed. We use .arch to indicate when they were updated
# last, otherwise make uses the target directory mtime.
2006-06-08 22:12:42 -07:00
include/asm-arm/.arch : $( wildcard include /config /arch /*.h ) include /config /auto .conf
2005-04-16 15:20:36 -07:00
@echo ' SYMLINK include/asm-arm/arch -> include/asm-arm/$(INCDIR)'
i f n e q ( $( KBUILD_SRC ) , )
$( Q) mkdir -p include/asm-arm
$( Q) ln -fsn $( srctree) /include/asm-arm/$( INCDIR) include/asm-arm/arch
e l s e
$( Q) ln -fsn $( INCDIR) include/asm-arm/arch
e n d i f
@touch $@
2005-09-26 07:49:27 +01:00
archprepare : maketools
2005-04-16 15:20:36 -07:00
2006-03-05 17:14:10 -05:00
PHONY += maketools FORCE
2005-09-26 07:49:27 +01:00
maketools : include /linux /version .h include /asm -arm /.arch FORCE
2005-04-16 15:20:36 -07:00
$( Q) $( MAKE) $( build) = arch/arm/tools include/asm-arm/mach-types.h
# Convert bzImage to zImage
bzImage : zImage
zImage Image xipImage bootpImage uImage : vmlinux
$( Q) $( MAKE) $( build) = $( boot) MACHINE = $( MACHINE) $( boot) /$@
zinstall install : vmlinux
$( Q) $( MAKE) $( build) = $( boot) MACHINE = $( MACHINE) $@
2005-09-09 21:08:59 +02:00
CLEAN_FILES += include/asm-arm/mach-types.h \
2005-04-16 15:20:36 -07:00
include/asm-arm/arch include/asm-arm/.arch
# We use MRPROPER_FILES and CLEAN_FILES now
archclean :
$( Q) $( MAKE) $( clean) = $( boot)
# My testing targets (bypasses dependencies)
bp : ; $( Q ) $( MAKE ) $( build ) =$( boot ) MACHINE =$( MACHINE ) $( boot ) /bootpImage
i zi : ; $( Q ) $( MAKE ) $( build ) =$( boot ) MACHINE =$( MACHINE ) $@
d e f i n e a r c h h e l p
echo '* zImage - Compressed kernel image (arch/$(ARCH)/boot/zImage)'
echo ' Image - Uncompressed kernel image (arch/$(ARCH)/boot/Image)'
echo '* xipImage - XIP kernel image, if configured (arch/$(ARCH)/boot/xipImage)'
echo ' bootpImage - Combined zImage and initial RAM disk'
echo ' (supply initrd image via make variable INITRD=<path>)'
echo ' install - Install uncompressed kernel'
echo ' zinstall - Install compressed kernel'
echo ' Install using (your) ~/bin/installkernel or'
echo ' (distribution) /sbin/installkernel or'
echo ' install to $$(INSTALL_PATH) and run lilo'
e n d e f