2005-09-26 10:04:21 +04:00
# 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" and "archdep" for cleaning up and making dependencies for
# this architecture.
#
# 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
# Changes for PPC by Gary Thomas
# Rewritten by Cort Dougan and Paul Mackerras
#
HAS_BIARCH := $( call cc-option-yn, -m32)
# Set default 32 bits cross compilers for vdso and boot wrapper
CROSS32_COMPILE ?=
CROSS32CC := $( CROSS32_COMPILE) gcc
CROSS32AS := $( CROSS32_COMPILE) as
CROSS32LD := $( CROSS32_COMPILE) ld
2006-09-27 16:47:03 +04:00
CROSS32AR := $( CROSS32_COMPILE) ar
2005-09-26 10:04:21 +04:00
CROSS32OBJCOPY := $( CROSS32_COMPILE) objcopy
i f e q ( $( HAS_BIARCH ) , y )
i f e q ( $( CROSS 32_COMPILE ) , )
CROSS32CC := $( CC) -m32
CROSS32AS := $( AS) -a32
CROSS32LD := $( LD) -m elf32ppc
CROSS32OBJCOPY := $( OBJCOPY)
2007-05-16 16:34:38 +04:00
CROSS32AR := GNUTARGET = elf32-powerpc $( AR)
2005-09-26 10:04:21 +04:00
e n d i f
e n d i f
2006-09-27 16:47:03 +04:00
export CROSS32CC CROSS32AS CROSS32LD CROSS32AR CROSS32OBJCOPY
2005-09-26 10:04:21 +04:00
2007-10-03 00:30:09 +04:00
i f e q ( $( CROSS_COMPILE ) , )
2005-11-18 08:39:08 +03:00
KBUILD_DEFCONFIG := $( shell uname -m) _defconfig
2007-10-03 00:30:09 +04:00
e l s e
KBUILD_DEFCONFIG := ppc64_defconfig
e n d i f
2005-11-18 08:39:08 +03:00
2005-11-16 05:38:21 +03:00
i f e q ( $( CONFIG_PPC 64) , y )
OLDARCH := ppc64
2005-09-26 10:04:21 +04:00
new_nm := $( shell if $( NM) --help 2>& 1 | grep -- '--synthetic' > /dev/null; then echo y; else echo n; fi )
i f e q ( $( new_nm ) , y )
NM := $( NM) --synthetic
e n d i f
e l s e
2005-09-27 07:51:59 +04:00
OLDARCH := ppc
2007-09-21 04:16:20 +04:00
e n d i f
# It seems there are times we use this Makefile without
# including the config file, but this replicates the old behaviour
i f e q ( $( CONFIG_WORD_SIZE ) , )
CONFIG_WORD_SIZE := 32
2005-09-26 10:04:21 +04:00
e n d i f
2005-10-13 10:14:15 +04:00
UTS_MACHINE := $( OLDARCH)
2005-09-26 10:04:21 +04:00
i f e q ( $( HAS_BIARCH ) , y )
2007-09-21 04:16:20 +04:00
o v e r r i d e AS += -a$( CONFIG_WORD_SIZE)
o v e r r i d e LD += -m elf$( CONFIG_WORD_SIZE) ppc
o v e r r i d e CC += -m$( CONFIG_WORD_SIZE)
override AR : = GNUTARGET =elf $( CONFIG_WORD_SIZE ) -powerpc $( AR )
2005-09-26 10:04:21 +04:00
e n d i f
2005-11-03 08:03:06 +03:00
LDFLAGS_vmlinux := -Bstatic
2005-09-26 10:04:21 +04:00
2007-08-17 10:52:39 +04:00
CPPFLAGS-$(CONFIG_PPC32) := -Iarch/$( ARCH)
2005-11-22 04:05:26 +03:00
AFLAGS-$(CONFIG_PPC32) := -Iarch/$( ARCH)
2005-09-27 07:51:59 +04:00
CFLAGS-$(CONFIG_PPC64) := -mminimal-toc -mtraceback= none -mcall-aixdesc
2005-11-22 04:05:26 +03:00
CFLAGS-$(CONFIG_PPC32) := -Iarch/$( ARCH) -ffixed-r2 -mmultiple
2007-10-16 00:17:25 +04:00
KBUILD_CPPFLAGS += $( CPPFLAGS-y)
2007-10-15 23:59:31 +04:00
KBUILD_AFLAGS += $( AFLAGS-y)
2007-10-15 00:21:35 +04:00
KBUILD_CFLAGS += -msoft-float -pipe $( CFLAGS-y)
CPP = $( CC) -E $( KBUILD_CFLAGS)
2005-09-26 10:04:21 +04:00
2007-09-21 04:16:20 +04:00
CHECKFLAGS += -m$( CONFIG_WORD_SIZE) -D__powerpc__ -D__powerpc$( CONFIG_WORD_SIZE) __
2005-09-26 10:04:21 +04:00
i f e q ( $( CONFIG_PPC 64) , y )
2006-01-08 21:58:51 +03:00
GCC_BROKEN_VEC := $( shell if [ $( call cc-version) -lt 0400 ] ; then echo "y" ; fi )
2005-09-26 10:04:21 +04:00
i f e q ( $( CONFIG_POWER 4_ONLY ) , y )
i f e q ( $( CONFIG_ALTIVEC ) , y )
i f e q ( $( GCC_BROKEN_VEC ) , y )
2007-10-15 00:21:35 +04:00
KBUILD_CFLAGS += $( call cc-option,-mcpu= 970)
2005-09-26 10:04:21 +04:00
e l s e
2007-10-15 00:21:35 +04:00
KBUILD_CFLAGS += $( call cc-option,-mcpu= power4)
2005-09-26 10:04:21 +04:00
e n d i f
e l s e
2007-10-15 00:21:35 +04:00
KBUILD_CFLAGS += $( call cc-option,-mcpu= power4)
2005-09-26 10:04:21 +04:00
e n d i f
e l s e
2007-10-15 00:21:35 +04:00
KBUILD_CFLAGS += $( call cc-option,-mtune= power4)
2005-09-26 10:04:21 +04:00
e n d i f
e n d i f
2007-09-15 04:21:57 +04:00
i f e q ( $( CONFIG_TUNE_CELL ) , y )
2007-10-15 00:21:35 +04:00
KBUILD_CFLAGS += $( call cc-option,-mtune= cell)
2007-09-15 04:21:57 +04:00
e n d i f
2005-10-29 09:31:17 +04:00
# No AltiVec instruction when building kernel
2007-10-15 00:21:35 +04:00
KBUILD_CFLAGS += $( call cc-option,-mno-altivec)
2005-10-29 09:31:17 +04:00
2007-10-19 01:53:19 +04:00
# No SPE instruction when building kernel
KBUILD_CFLAGS += $( call cc-option,-mno-spe)
2005-09-26 10:04:21 +04:00
# Enable unit-at-a-time mode when possible. It shrinks the
# kernel considerably.
2007-10-15 00:21:35 +04:00
KBUILD_CFLAGS += $( call cc-option,-funit-at-a-time)
2005-09-26 10:04:21 +04:00
2007-03-22 09:23:44 +03:00
# Never use string load/store instructions as they are
# often slow when they are implemented at all
2007-10-15 00:21:35 +04:00
KBUILD_CFLAGS += -mno-string
2005-09-26 10:04:21 +04:00
2006-04-11 22:42:08 +04:00
i f e q ( $( CONFIG_ 6xx ) , y )
2007-10-15 00:21:35 +04:00
KBUILD_CFLAGS += -mcpu= powerpc
2006-04-11 22:42:08 +04:00
e n d i f
2005-09-26 10:04:21 +04:00
cpu-as-$(CONFIG_4xx) += -Wa,-m405
cpu-as-$(CONFIG_6xx) += -Wa,-maltivec
cpu-as-$(CONFIG_POWER4) += -Wa,-maltivec
cpu-as-$(CONFIG_E500) += -Wa,-me500
cpu-as-$(CONFIG_E200) += -Wa,-me200
2007-10-15 23:59:31 +04:00
KBUILD_AFLAGS += $( cpu-as-y)
2007-10-15 00:21:35 +04:00
KBUILD_CFLAGS += $( cpu-as-y)
2005-09-26 10:04:21 +04:00
2007-09-21 04:16:20 +04:00
head-y := arch/powerpc/kernel/head_$( CONFIG_WORD_SIZE) .o
2005-09-26 10:04:21 +04:00
head-$(CONFIG_8xx) := arch/powerpc/kernel/head_8xx.o
2007-08-20 16:27:07 +04:00
head-$(CONFIG_40x) := arch/powerpc/kernel/head_40x.o
2005-09-26 10:04:21 +04:00
head-$(CONFIG_44x) := arch/powerpc/kernel/head_44x.o
head-$(CONFIG_FSL_BOOKE) := arch/powerpc/kernel/head_fsl_booke.o
2005-10-10 16:36:14 +04:00
head-$(CONFIG_PPC64) += arch/powerpc/kernel/entry_64.o
2005-09-26 10:04:21 +04:00
head-$(CONFIG_PPC_FPU) += arch/powerpc/kernel/fpu.o
2005-10-10 16:25:26 +04:00
core-y += arch/powerpc/kernel/ \
arch/powerpc/mm/ \
arch/powerpc/lib/ \
arch/powerpc/sysdev/ \
arch/powerpc/platforms/
2006-03-28 09:43:27 +04:00
core-$(CONFIG_MATH_EMULATION) += arch/powerpc/math-emu/
2005-10-28 16:53:37 +04:00
core-$(CONFIG_XMON) += arch/powerpc/xmon/
2005-09-26 10:04:21 +04:00
drivers-$(CONFIG_OPROFILE) += arch/powerpc/oprofile/
2006-01-13 02:55:58 +03:00
# Default to zImage, override when needed
defaultimage-y := zImage
2006-01-16 19:53:22 +03:00
defaultimage-$(CONFIG_DEFAULT_UIMAGE) := uImage
2005-09-30 10:16:52 +04:00
KBUILD_IMAGE := $( defaultimage-y)
all : $( KBUILD_IMAGE )
2005-09-26 10:04:21 +04:00
CPPFLAGS_vmlinux.lds := -Upowerpc
2007-05-31 23:54:39 +04:00
BOOT_TARGETS = zImage zImage.initrd uImage
2005-09-30 10:16:52 +04:00
2006-03-06 01:14:10 +03:00
PHONY += $( BOOT_TARGETS)
2005-09-30 10:16:52 +04:00
2005-11-16 05:38:21 +03:00
boot := arch/$( ARCH) /boot
2005-09-26 10:04:21 +04:00
2005-10-11 03:25:40 +04:00
$(BOOT_TARGETS) : vmlinux
$( Q) $( MAKE) ARCH = ppc64 $( build) = $( boot) $( patsubst %,$( boot) /%,$@ )
2005-09-26 10:04:21 +04:00
d e f i n e a r c h h e l p
2005-11-16 05:38:21 +03:00
@echo '* zImage - Compressed kernel image (arch/$(ARCH)/boot/zImage.*)'
2005-09-26 10:04:21 +04:00
@echo ' install - Install kernel using'
@echo ' (your) ~/bin/installkernel or'
@echo ' (distribution) /sbin/installkernel or'
@echo ' install to $$(INSTALL_PATH) and run lilo'
2005-11-18 07:43:34 +03:00
@echo ' *_defconfig - Select default config from arch/$(ARCH)/configs'
2005-09-26 10:04:21 +04:00
e n d e f
2007-10-03 00:30:04 +04:00
install : vdso_install
2007-04-10 15:05:31 +04:00
$( Q) $( MAKE) $( build) = $( boot) BOOTIMAGE = $( KBUILD_IMAGE) install
2007-10-03 00:30:04 +04:00
vdso_install :
i f e q ( $( CONFIG_PPC 64) , y )
$( Q) $( MAKE) $( build) = arch/$( ARCH) /kernel/vdso64 $@
e n d i f
$( Q) $( MAKE) $( build) = arch/$( ARCH) /kernel/vdso32 $@
2005-09-26 10:04:21 +04:00
archclean :
2005-09-28 09:53:36 +04:00
$( Q) $( MAKE) $( clean) = $( boot)
2006-02-10 12:51:07 +03:00
2005-09-26 10:04:21 +04:00
archprepare : checkbin
# Use the file '.tmp_gas_check' for binutils tests, as gas won't output
# to stdout and these checks are run even on install targets.
TOUT := .tmp_gas_check
# Ensure this is binutils 2.12.1 (or 2.12.90.0.7) or later for altivec
# instructions.
# gcc-3.4 and binutils-2.14 are a fatal combination.
checkbin :
2006-01-08 21:58:51 +03:00
@if test " $( call cc-version) " = "0304" ; then \
2005-09-26 10:04:21 +04:00
if ! /bin/echo mftb 5 | $( AS) -v -mppc -many -o $( TOUT) >/dev/null 2>& 1 ; then \
echo -n '*** ${VERSION}.${PATCHLEVEL} kernels no longer build ' ; \
echo 'correctly with gcc-3.4 and your version of binutils.' ; \
echo '*** Please upgrade your binutils or downgrade your gcc' ; \
false; \
fi ; \
fi
2007-05-19 20:49:08 +04:00
@if test " $( call cc-fullversion) " = "040200" \
&& test " x ${ CONFIG_MODULES } ${ CONFIG_PPC64 } " = "xyy" ; then \
echo -n '*** GCC-4.2.0 cannot compile the 64-bit powerpc ' ; \
echo 'kernel with modules enabled.' ; \
echo -n '*** Please use a different GCC version or ' ; \
echo 'disable kernel modules' ; \
false ; \
fi
2005-09-26 10:04:21 +04:00
@if ! /bin/echo dssall | $( AS) -many -o $( TOUT) >/dev/null 2>& 1 ; then \
echo -n '*** ${VERSION}.${PATCHLEVEL} kernels no longer build ' ; \
echo 'correctly with old versions of binutils.' ; \
echo '*** Please upgrade your binutils to 2.12.1 or newer' ; \
false ; \
fi
CLEAN_FILES += $( TOUT)