1*1da177e4SLinus Torvalds# 2*1da177e4SLinus Torvalds# arch/arm/Makefile 3*1da177e4SLinus Torvalds# 4*1da177e4SLinus Torvalds# This file is subject to the terms and conditions of the GNU General Public 5*1da177e4SLinus Torvalds# License. See the file "COPYING" in the main directory of this archive 6*1da177e4SLinus Torvalds# for more details. 7*1da177e4SLinus Torvalds# 8*1da177e4SLinus Torvalds# Copyright (C) 1995-2001 by Russell King 9*1da177e4SLinus Torvalds 10*1da177e4SLinus TorvaldsLDFLAGS_vmlinux :=-p --no-undefined -X 11*1da177e4SLinus TorvaldsCPPFLAGS_vmlinux.lds = -DTEXTADDR=$(TEXTADDR) -DDATAADDR=$(DATAADDR) 12*1da177e4SLinus TorvaldsOBJCOPYFLAGS :=-O binary -R .note -R .comment -S 13*1da177e4SLinus TorvaldsGZFLAGS :=-9 14*1da177e4SLinus Torvalds#CFLAGS +=-pipe 15*1da177e4SLinus Torvalds 16*1da177e4SLinus Torvalds# Do not use arch/arm/defconfig - it's always outdated. 17*1da177e4SLinus Torvalds# Select a platform tht is kept up-to-date 18*1da177e4SLinus TorvaldsKBUILD_DEFCONFIG := versatile_defconfig 19*1da177e4SLinus Torvalds 20*1da177e4SLinus Torvaldsifeq ($(CONFIG_FRAME_POINTER),y) 21*1da177e4SLinus TorvaldsCFLAGS +=-fno-omit-frame-pointer -mapcs -mno-sched-prolog 22*1da177e4SLinus Torvaldsendif 23*1da177e4SLinus Torvalds 24*1da177e4SLinus Torvaldsifeq ($(CONFIG_CPU_BIG_ENDIAN),y) 25*1da177e4SLinus TorvaldsCPPFLAGS += -mbig-endian 26*1da177e4SLinus TorvaldsAS += -EB 27*1da177e4SLinus TorvaldsLD += -EB 28*1da177e4SLinus Torvaldselse 29*1da177e4SLinus TorvaldsCPPFLAGS += -mlittle-endian 30*1da177e4SLinus TorvaldsAS += -EL 31*1da177e4SLinus TorvaldsLD += -EL 32*1da177e4SLinus Torvaldsendif 33*1da177e4SLinus Torvalds 34*1da177e4SLinus Torvaldscomma = , 35*1da177e4SLinus Torvalds 36*1da177e4SLinus Torvalds# This selects which instruction set is used. 37*1da177e4SLinus Torvalds# Note that GCC does not numerically define an architecture version 38*1da177e4SLinus Torvalds# macro, but instead defines a whole series of macros which makes 39*1da177e4SLinus Torvalds# testing for a specific architecture or later rather impossible. 40*1da177e4SLinus Torvaldsarch-$(CONFIG_CPU_32v6) :=-D__LINUX_ARM_ARCH__=6 $(call cc-option,-march=armv6,-march=armv5t -Wa$(comma)-march=armv6) 41*1da177e4SLinus Torvaldsarch-$(CONFIG_CPU_32v5) :=-D__LINUX_ARM_ARCH__=5 $(call cc-option,-march=armv5te,-march=armv4) 42*1da177e4SLinus Torvaldsarch-$(CONFIG_CPU_32v4) :=-D__LINUX_ARM_ARCH__=4 -march=armv4 43*1da177e4SLinus Torvaldsarch-$(CONFIG_CPU_32v3) :=-D__LINUX_ARM_ARCH__=3 -march=armv3 44*1da177e4SLinus Torvalds 45*1da177e4SLinus Torvalds# This selects how we optimise for the processor. 46*1da177e4SLinus Torvaldstune-$(CONFIG_CPU_ARM610) :=-mtune=arm610 47*1da177e4SLinus Torvaldstune-$(CONFIG_CPU_ARM710) :=-mtune=arm710 48*1da177e4SLinus Torvaldstune-$(CONFIG_CPU_ARM720T) :=-mtune=arm7tdmi 49*1da177e4SLinus Torvaldstune-$(CONFIG_CPU_ARM920T) :=-mtune=arm9tdmi 50*1da177e4SLinus Torvaldstune-$(CONFIG_CPU_ARM922T) :=-mtune=arm9tdmi 51*1da177e4SLinus Torvaldstune-$(CONFIG_CPU_ARM925T) :=-mtune=arm9tdmi 52*1da177e4SLinus Torvaldstune-$(CONFIG_CPU_ARM926T) :=-mtune=arm9tdmi 53*1da177e4SLinus Torvaldstune-$(CONFIG_CPU_SA110) :=-mtune=strongarm110 54*1da177e4SLinus Torvaldstune-$(CONFIG_CPU_SA1100) :=-mtune=strongarm1100 55*1da177e4SLinus Torvaldstune-$(CONFIG_CPU_XSCALE) :=$(call cc-option,-mtune=xscale,-mtune=strongarm110) -Wa,-mcpu=xscale 56*1da177e4SLinus Torvaldstune-$(CONFIG_CPU_V6) :=-mtune=strongarm 57*1da177e4SLinus Torvalds 58*1da177e4SLinus Torvalds# Need -Uarm for gcc < 3.x 59*1da177e4SLinus TorvaldsCFLAGS_ABI :=$(call cc-option,-mapcs-32,-mabi=apcs-gnu) 60*1da177e4SLinus TorvaldsCFLAGS +=$(CFLAGS_ABI) $(arch-y) $(tune-y) $(call cc-option,-mshort-load-bytes,$(call cc-option,-malignment-traps,)) -msoft-float -Uarm 61*1da177e4SLinus TorvaldsAFLAGS +=$(CFLAGS_ABI) $(arch-y) $(tune-y) -msoft-float 62*1da177e4SLinus Torvalds 63*1da177e4SLinus TorvaldsCHECKFLAGS += -D__arm__ 64*1da177e4SLinus Torvalds 65*1da177e4SLinus Torvalds#Default value 66*1da177e4SLinus Torvaldshead-y := arch/arm/kernel/head.o arch/arm/kernel/init_task.o 67*1da177e4SLinus Torvaldstextaddr-y := 0xC0008000 68*1da177e4SLinus Torvalds 69*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_RPC) := rpc 70*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_EBSA110) := ebsa110 71*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_CLPS7500) := clps7500 72*1da177e4SLinus Torvalds incdir-$(CONFIG_ARCH_CLPS7500) := cl7500 73*1da177e4SLinus Torvalds machine-$(CONFIG_FOOTBRIDGE) := footbridge 74*1da177e4SLinus Torvalds incdir-$(CONFIG_FOOTBRIDGE) := ebsa285 75*1da177e4SLinus Torvaldstextaddr-$(CONFIG_ARCH_CO285) := 0x60008000 76*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_CO285) := footbridge 77*1da177e4SLinus Torvalds incdir-$(CONFIG_ARCH_CO285) := ebsa285 78*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_SHARK) := shark 79*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_SA1100) := sa1100 80*1da177e4SLinus Torvaldsifeq ($(CONFIG_ARCH_SA1100),y) 81*1da177e4SLinus Torvalds# SA1111 DMA bug: we don't want the kernel to live in precious DMA-able memory 82*1da177e4SLinus Torvaldstextaddr-$(CONFIG_SA1111) := 0xc0208000 83*1da177e4SLinus Torvaldsendif 84*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_PXA) := pxa 85*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_L7200) := l7200 86*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_INTEGRATOR) := integrator 87*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_CAMELOT) := epxa10db 88*1da177e4SLinus Torvaldstextaddr-$(CONFIG_ARCH_CLPS711X) := 0xc0028000 89*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_CLPS711X) := clps711x 90*1da177e4SLinus Torvaldstextaddr-$(CONFIG_ARCH_FORTUNET) := 0xc0008000 91*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_IOP3XX) := iop3xx 92*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_IXP4XX) := ixp4xx 93*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_IXP2000) := ixp2000 94*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_OMAP) := omap 95*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_S3C2410) := s3c2410 96*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_LH7A40X) := lh7a40x 97*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_VERSATILE) := versatile 98*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_IMX) := imx 99*1da177e4SLinus Torvalds machine-$(CONFIG_ARCH_H720X) := h720x 100*1da177e4SLinus Torvalds 101*1da177e4SLinus Torvaldsifeq ($(CONFIG_ARCH_EBSA110),y) 102*1da177e4SLinus Torvalds# This is what happens if you forget the IOCS16 line. 103*1da177e4SLinus Torvalds# PCMCIA cards stop working. 104*1da177e4SLinus TorvaldsCFLAGS_3c589_cs.o :=-DISA_SIXTEEN_BIT_PERIPHERAL 105*1da177e4SLinus Torvaldsexport CFLAGS_3c589_cs.o 106*1da177e4SLinus Torvaldsendif 107*1da177e4SLinus Torvalds 108*1da177e4SLinus TorvaldsTEXTADDR := $(textaddr-y) 109*1da177e4SLinus Torvaldsifeq ($(CONFIG_XIP_KERNEL),y) 110*1da177e4SLinus Torvalds DATAADDR := $(TEXTADDR) 111*1da177e4SLinus Torvalds xipaddr-$(CONFIG_ARCH_CO285) := 0x5f000000 112*1da177e4SLinus Torvalds xipaddr-y ?= 0xbf000000 113*1da177e4SLinus Torvalds # Replace phys addr with virt addr while keeping offset from base. 114*1da177e4SLinus Torvalds TEXTADDR := $(shell echo $(CONFIG_XIP_PHYS_ADDR) $(xipaddr-y) | \ 115*1da177e4SLinus Torvalds awk --non-decimal-data '/[:xdigit:]/ \ 116*1da177e4SLinus Torvalds { printf("0x%x\n", and($$1, 0x000fffff) + $$2) }' ) 117*1da177e4SLinus Torvaldsendif 118*1da177e4SLinus Torvalds 119*1da177e4SLinus Torvaldsifeq ($(incdir-y),) 120*1da177e4SLinus Torvaldsincdir-y := $(machine-y) 121*1da177e4SLinus Torvaldsendif 122*1da177e4SLinus TorvaldsINCDIR := arch-$(incdir-y) 123*1da177e4SLinus Torvaldsifneq ($(machine-y),) 124*1da177e4SLinus TorvaldsMACHINE := arch/arm/mach-$(machine-y)/ 125*1da177e4SLinus Torvaldselse 126*1da177e4SLinus TorvaldsMACHINE := 127*1da177e4SLinus Torvaldsendif 128*1da177e4SLinus Torvalds 129*1da177e4SLinus Torvaldsexport TEXTADDR DATAADDR GZFLAGS 130*1da177e4SLinus Torvalds 131*1da177e4SLinus Torvalds# Do we have FASTFPE? 132*1da177e4SLinus TorvaldsFASTFPE :=arch/arm/fastfpe 133*1da177e4SLinus Torvaldsifeq ($(FASTFPE),$(wildcard $(FASTFPE))) 134*1da177e4SLinus TorvaldsFASTFPE_OBJ :=$(FASTFPE)/ 135*1da177e4SLinus Torvaldsendif 136*1da177e4SLinus Torvalds 137*1da177e4SLinus Torvalds# If we have a machine-specific directory, then include it in the build. 138*1da177e4SLinus Torvaldscore-y += arch/arm/kernel/ arch/arm/mm/ arch/arm/common/ 139*1da177e4SLinus Torvaldscore-y += $(MACHINE) 140*1da177e4SLinus Torvaldscore-$(CONFIG_FPE_NWFPE) += arch/arm/nwfpe/ 141*1da177e4SLinus Torvaldscore-$(CONFIG_FPE_FASTFPE) += $(FASTFPE_OBJ) 142*1da177e4SLinus Torvaldscore-$(CONFIG_VFP) += arch/arm/vfp/ 143*1da177e4SLinus Torvalds 144*1da177e4SLinus Torvaldsdrivers-$(CONFIG_OPROFILE) += arch/arm/oprofile/ 145*1da177e4SLinus Torvaldsdrivers-$(CONFIG_ARCH_CLPS7500) += drivers/acorn/char/ 146*1da177e4SLinus Torvaldsdrivers-$(CONFIG_ARCH_L7200) += drivers/acorn/char/ 147*1da177e4SLinus Torvalds 148*1da177e4SLinus Torvaldslibs-y += arch/arm/lib/ 149*1da177e4SLinus Torvalds 150*1da177e4SLinus Torvalds# Default target when executing plain make 151*1da177e4SLinus Torvaldsifeq ($(CONFIG_XIP_KERNEL),y) 152*1da177e4SLinus Torvaldsall: xipImage 153*1da177e4SLinus Torvaldselse 154*1da177e4SLinus Torvaldsall: zImage 155*1da177e4SLinus Torvaldsendif 156*1da177e4SLinus Torvalds 157*1da177e4SLinus Torvaldsboot := arch/arm/boot 158*1da177e4SLinus Torvalds 159*1da177e4SLinus Torvalds# Update machine arch and proc symlinks if something which affects 160*1da177e4SLinus Torvalds# them changed. We use .arch to indicate when they were updated 161*1da177e4SLinus Torvalds# last, otherwise make uses the target directory mtime. 162*1da177e4SLinus Torvalds 163*1da177e4SLinus Torvaldsinclude/asm-arm/.arch: $(wildcard include/config/arch/*.h) include/config/MARKER 164*1da177e4SLinus Torvalds @echo ' SYMLINK include/asm-arm/arch -> include/asm-arm/$(INCDIR)' 165*1da177e4SLinus Torvaldsifneq ($(KBUILD_SRC),) 166*1da177e4SLinus Torvalds $(Q)mkdir -p include/asm-arm 167*1da177e4SLinus Torvalds $(Q)ln -fsn $(srctree)/include/asm-arm/$(INCDIR) include/asm-arm/arch 168*1da177e4SLinus Torvaldselse 169*1da177e4SLinus Torvalds $(Q)ln -fsn $(INCDIR) include/asm-arm/arch 170*1da177e4SLinus Torvaldsendif 171*1da177e4SLinus Torvalds @touch $@ 172*1da177e4SLinus Torvalds 173*1da177e4SLinus Torvaldsprepare: maketools include/asm-arm/.arch 174*1da177e4SLinus Torvalds 175*1da177e4SLinus Torvalds.PHONY: maketools FORCE 176*1da177e4SLinus Torvaldsmaketools: include/asm-arm/constants.h include/linux/version.h FORCE 177*1da177e4SLinus Torvalds $(Q)$(MAKE) $(build)=arch/arm/tools include/asm-arm/mach-types.h 178*1da177e4SLinus Torvalds 179*1da177e4SLinus Torvalds# Convert bzImage to zImage 180*1da177e4SLinus TorvaldsbzImage: zImage 181*1da177e4SLinus Torvalds 182*1da177e4SLinus TorvaldszImage Image xipImage bootpImage uImage: vmlinux 183*1da177e4SLinus Torvalds $(Q)$(MAKE) $(build)=$(boot) MACHINE=$(MACHINE) $(boot)/$@ 184*1da177e4SLinus Torvalds 185*1da177e4SLinus Torvaldszinstall install: vmlinux 186*1da177e4SLinus Torvalds $(Q)$(MAKE) $(build)=$(boot) MACHINE=$(MACHINE) $@ 187*1da177e4SLinus Torvalds 188*1da177e4SLinus TorvaldsCLEAN_FILES += include/asm-arm/constants.h* include/asm-arm/mach-types.h \ 189*1da177e4SLinus Torvalds include/asm-arm/arch include/asm-arm/.arch 190*1da177e4SLinus Torvalds 191*1da177e4SLinus Torvalds# We use MRPROPER_FILES and CLEAN_FILES now 192*1da177e4SLinus Torvaldsarchclean: 193*1da177e4SLinus Torvalds $(Q)$(MAKE) $(clean)=$(boot) 194*1da177e4SLinus Torvalds 195*1da177e4SLinus Torvalds# My testing targets (bypasses dependencies) 196*1da177e4SLinus Torvaldsbp:; $(Q)$(MAKE) $(build)=$(boot) MACHINE=$(MACHINE) $(boot)/bootpImage 197*1da177e4SLinus Torvaldsi zi:; $(Q)$(MAKE) $(build)=$(boot) MACHINE=$(MACHINE) $@ 198*1da177e4SLinus Torvalds 199*1da177e4SLinus Torvaldsarch/$(ARCH)/kernel/asm-offsets.s: include/asm include/linux/version.h \ 200*1da177e4SLinus Torvalds include/asm-arm/.arch 201*1da177e4SLinus Torvalds 202*1da177e4SLinus Torvaldsinclude/asm-$(ARCH)/constants.h: arch/$(ARCH)/kernel/asm-offsets.s 203*1da177e4SLinus Torvalds $(call filechk,gen-asm-offsets) 204*1da177e4SLinus Torvalds 205*1da177e4SLinus Torvaldsdefine archhelp 206*1da177e4SLinus Torvalds echo '* zImage - Compressed kernel image (arch/$(ARCH)/boot/zImage)' 207*1da177e4SLinus Torvalds echo ' Image - Uncompressed kernel image (arch/$(ARCH)/boot/Image)' 208*1da177e4SLinus Torvalds echo '* xipImage - XIP kernel image, if configured (arch/$(ARCH)/boot/xipImage)' 209*1da177e4SLinus Torvalds echo ' bootpImage - Combined zImage and initial RAM disk' 210*1da177e4SLinus Torvalds echo ' (supply initrd image via make variable INITRD=<path>)' 211*1da177e4SLinus Torvalds echo ' install - Install uncompressed kernel' 212*1da177e4SLinus Torvalds echo ' zinstall - Install compressed kernel' 213*1da177e4SLinus Torvalds echo ' Install using (your) ~/bin/installkernel or' 214*1da177e4SLinus Torvalds echo ' (distribution) /sbin/installkernel or' 215*1da177e4SLinus Torvalds echo ' install to $$(INSTALL_PATH) and run lilo' 216*1da177e4SLinus Torvaldsendef 217