| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 1 | # This file is included by the global makefile so that you can add your own | 
 | 2 | # architecture-specific flags and dependencies. Remember to do have actions | 
 | 3 | # for "archclean" and "archdep" for cleaning up and making dependencies for | 
 | 4 | # this architecture. | 
 | 5 | # | 
 | 6 | # This file is subject to the terms and conditions of the GNU General Public | 
 | 7 | # License.  See the file "COPYING" in the main directory of this archive | 
 | 8 | # for more details. | 
 | 9 | # | 
 | 10 | # Copyright (C) 1994 by Linus Torvalds | 
 | 11 | # Changes for PPC by Gary Thomas | 
 | 12 | # Rewritten by Cort Dougan and Paul Mackerras | 
 | 13 | # | 
 | 14 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 15 | HAS_BIARCH	:= $(call cc-option-yn, -m32) | 
 | 16 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 17 | # Set default 32 bits cross compilers for vdso and boot wrapper | 
 | 18 | CROSS32_COMPILE ?= | 
 | 19 |  | 
 | 20 | CROSS32CC		:= $(CROSS32_COMPILE)gcc | 
 | 21 | CROSS32AS		:= $(CROSS32_COMPILE)as | 
 | 22 | CROSS32LD		:= $(CROSS32_COMPILE)ld | 
 | 23 | CROSS32OBJCOPY		:= $(CROSS32_COMPILE)objcopy | 
 | 24 |  | 
 | 25 | ifeq ($(HAS_BIARCH),y) | 
 | 26 | ifeq ($(CROSS32_COMPILE),) | 
 | 27 | CROSS32CC	:= $(CC) -m32 | 
 | 28 | CROSS32AS	:= $(AS) -a32 | 
 | 29 | CROSS32LD	:= $(LD) -m elf32ppc | 
 | 30 | CROSS32OBJCOPY	:= $(OBJCOPY) | 
 | 31 | endif | 
 | 32 | endif | 
 | 33 |  | 
 | 34 | export CROSS32CC CROSS32AS CROSS32LD CROSS32OBJCOPY | 
 | 35 |  | 
| Paul Mackerras | 8a5abdf | 2005-11-18 16:39:08 +1100 | [diff] [blame^] | 36 | KBUILD_DEFCONFIG := $(shell uname -m)_defconfig | 
 | 37 |  | 
| Paul Mackerras | 94b212c | 2005-11-16 13:38:21 +1100 | [diff] [blame] | 38 | ifeq ($(CONFIG_PPC64),y) | 
 | 39 | OLDARCH	:= ppc64 | 
 | 40 | SZ	:= 64 | 
 | 41 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 42 | new_nm := $(shell if $(NM) --help 2>&1 | grep -- '--synthetic' > /dev/null; then echo y; else echo n; fi) | 
 | 43 |  | 
 | 44 | ifeq ($(new_nm),y) | 
 | 45 | NM		:= $(NM) --synthetic | 
 | 46 | endif | 
 | 47 |  | 
 | 48 | else | 
| Stephen Rothwell | bbeb3f4 | 2005-09-27 13:51:59 +1000 | [diff] [blame] | 49 | OLDARCH	:= ppc | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 50 | SZ	:= 32 | 
 | 51 | endif | 
 | 52 |  | 
| Stephen Rothwell | 190554d | 2005-10-13 16:14:15 +1000 | [diff] [blame] | 53 | UTS_MACHINE := $(OLDARCH) | 
 | 54 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 55 | ifeq ($(HAS_BIARCH),y) | 
 | 56 | override AS	+= -a$(SZ) | 
 | 57 | override LD	+= -m elf$(SZ)ppc | 
 | 58 | override CC	+= -m$(SZ) | 
 | 59 | endif | 
 | 60 |  | 
| Michael Ellerman | e19e4ab | 2005-11-03 16:03:06 +1100 | [diff] [blame] | 61 | LDFLAGS_vmlinux	:= -Bstatic | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 62 |  | 
 | 63 | # The -Iarch/$(ARCH)/include is temporary while we are merging | 
 | 64 | CPPFLAGS	+= -Iarch/$(ARCH) -Iarch/$(ARCH)/include | 
 | 65 | AFLAGS		+= -Iarch/$(ARCH) | 
 | 66 | CFLAGS		+= -Iarch/$(ARCH) -msoft-float -pipe | 
| Stephen Rothwell | bbeb3f4 | 2005-09-27 13:51:59 +1000 | [diff] [blame] | 67 | CFLAGS-$(CONFIG_PPC64)	:= -mminimal-toc -mtraceback=none  -mcall-aixdesc | 
 | 68 | CFLAGS-$(CONFIG_PPC32)	:= -ffixed-r2 -mmultiple | 
 | 69 | CFLAGS		+= $(CFLAGS-y) | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 70 | CPP		= $(CC) -E $(CFLAGS) | 
 | 71 | # Temporary hack until we have migrated to asm-powerpc | 
 | 72 | LINUXINCLUDE    += -Iarch/$(ARCH)/include | 
 | 73 |  | 
 | 74 | CHECKFLAGS	+= -m$(SZ) -D__powerpc__ -D__powerpc$(SZ)__ | 
 | 75 |  | 
 | 76 | ifeq ($(CONFIG_PPC64),y) | 
 | 77 | GCC_VERSION     := $(call cc-version) | 
 | 78 | GCC_BROKEN_VEC	:= $(shell if [ $(GCC_VERSION) -lt 0400 ] ; then echo "y"; fi) | 
 | 79 |  | 
 | 80 | ifeq ($(CONFIG_POWER4_ONLY),y) | 
 | 81 | ifeq ($(CONFIG_ALTIVEC),y) | 
 | 82 | ifeq ($(GCC_BROKEN_VEC),y) | 
 | 83 | 	CFLAGS += $(call cc-option,-mcpu=970) | 
 | 84 | else | 
 | 85 | 	CFLAGS += $(call cc-option,-mcpu=power4) | 
 | 86 | endif | 
 | 87 | else | 
 | 88 | 	CFLAGS += $(call cc-option,-mcpu=power4) | 
 | 89 | endif | 
 | 90 | else | 
 | 91 | 	CFLAGS += $(call cc-option,-mtune=power4) | 
 | 92 | endif | 
 | 93 | endif | 
 | 94 |  | 
| Paul Mackerras | d3f67fb | 2005-10-29 15:31:17 +1000 | [diff] [blame] | 95 | # No AltiVec instruction when building kernel | 
 | 96 | CFLAGS += $(call cc-option,-mno-altivec) | 
 | 97 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 98 | # Enable unit-at-a-time mode when possible. It shrinks the | 
 | 99 | # kernel considerably. | 
 | 100 | CFLAGS += $(call cc-option,-funit-at-a-time) | 
 | 101 |  | 
 | 102 | ifndef CONFIG_FSL_BOOKE | 
 | 103 | CFLAGS		+= -mstring | 
 | 104 | endif | 
 | 105 |  | 
 | 106 | cpu-as-$(CONFIG_PPC64BRIDGE)	+= -Wa,-mppc64bridge | 
 | 107 | cpu-as-$(CONFIG_4xx)		+= -Wa,-m405 | 
 | 108 | cpu-as-$(CONFIG_6xx)		+= -Wa,-maltivec | 
 | 109 | cpu-as-$(CONFIG_POWER4)		+= -Wa,-maltivec | 
 | 110 | cpu-as-$(CONFIG_E500)		+= -Wa,-me500 | 
 | 111 | cpu-as-$(CONFIG_E200)		+= -Wa,-me200 | 
 | 112 |  | 
 | 113 | AFLAGS += $(cpu-as-y) | 
 | 114 | CFLAGS += $(cpu-as-y) | 
 | 115 |  | 
| Paul Mackerras | 70d64ce | 2005-10-10 21:52:43 +1000 | [diff] [blame] | 116 | head-y				:= arch/powerpc/kernel/head_32.o | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 117 | head-$(CONFIG_PPC64)		:= arch/powerpc/kernel/head_64.o | 
 | 118 | head-$(CONFIG_8xx)		:= arch/powerpc/kernel/head_8xx.o | 
 | 119 | head-$(CONFIG_4xx)		:= arch/powerpc/kernel/head_4xx.o | 
 | 120 | head-$(CONFIG_44x)		:= arch/powerpc/kernel/head_44x.o | 
 | 121 | head-$(CONFIG_FSL_BOOKE)	:= arch/powerpc/kernel/head_fsl_booke.o | 
 | 122 |  | 
| Paul Mackerras | 9994a33 | 2005-10-10 22:36:14 +1000 | [diff] [blame] | 123 | head-$(CONFIG_PPC64)		+= arch/powerpc/kernel/entry_64.o | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 124 | head-$(CONFIG_PPC_FPU)		+= arch/powerpc/kernel/fpu.o | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 125 |  | 
| Paul Mackerras | daec962 | 2005-10-10 22:25:26 +1000 | [diff] [blame] | 126 | core-y				+= arch/powerpc/kernel/ \ | 
| Paul Mackerras | daec962 | 2005-10-10 22:25:26 +1000 | [diff] [blame] | 127 | 				   arch/powerpc/mm/ \ | 
 | 128 | 				   arch/powerpc/lib/ \ | 
 | 129 | 				   arch/powerpc/sysdev/ \ | 
 | 130 | 				   arch/powerpc/platforms/ | 
| Paul Mackerras | 437a58d | 2005-11-18 15:43:34 +1100 | [diff] [blame] | 131 | core-$(CONFIG_PPC32)		+= arch/ppc/kernel/ | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 132 | core-$(CONFIG_MATH_EMULATION)	+= arch/ppc/math-emu/ | 
| Paul Mackerras | f78541d | 2005-10-28 22:53:37 +1000 | [diff] [blame] | 133 | core-$(CONFIG_XMON)		+= arch/powerpc/xmon/ | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 134 | core-$(CONFIG_APUS)		+= arch/ppc/amiga/ | 
 | 135 | drivers-$(CONFIG_8xx)		+= arch/ppc/8xx_io/ | 
 | 136 | drivers-$(CONFIG_4xx)		+= arch/ppc/4xx_io/ | 
 | 137 | drivers-$(CONFIG_CPM2)		+= arch/ppc/8260_io/ | 
 | 138 |  | 
 | 139 | drivers-$(CONFIG_OPROFILE)	+= arch/powerpc/oprofile/ | 
 | 140 |  | 
| Paul Mackerras | 94b212c | 2005-11-16 13:38:21 +1100 | [diff] [blame] | 141 | defaultimage-$(CONFIG_PPC32)	:= zImage | 
| Stephen Rothwell | cabb558 | 2005-09-30 16:16:52 +1000 | [diff] [blame] | 142 | defaultimage-$(CONFIG_PPC_ISERIES) := vmlinux | 
| Paul Mackerras | 20f6295 | 2005-10-11 09:25:40 +1000 | [diff] [blame] | 143 | defaultimage-$(CONFIG_PPC_PSERIES) := zImage | 
| Stephen Rothwell | cabb558 | 2005-09-30 16:16:52 +1000 | [diff] [blame] | 144 | KBUILD_IMAGE := $(defaultimage-y) | 
 | 145 | all: $(KBUILD_IMAGE) | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 146 |  | 
 | 147 | CPPFLAGS_vmlinux.lds	:= -Upowerpc | 
 | 148 |  | 
 | 149 | # All the instructions talk about "make bzImage". | 
 | 150 | bzImage: zImage | 
 | 151 |  | 
| Stephen Rothwell | cabb558 | 2005-09-30 16:16:52 +1000 | [diff] [blame] | 152 | BOOT_TARGETS = zImage zImage.initrd znetboot znetboot.initrd vmlinux.sm | 
 | 153 |  | 
 | 154 | .PHONY: $(BOOT_TARGETS) | 
 | 155 |  | 
| Paul Mackerras | 94b212c | 2005-11-16 13:38:21 +1100 | [diff] [blame] | 156 | boot := arch/$(ARCH)/boot | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 157 |  | 
 | 158 | $(BOOT_TARGETS): vmlinux | 
| Paul Mackerras | 20f6295 | 2005-10-11 09:25:40 +1000 | [diff] [blame] | 159 | 	$(Q)$(MAKE) ARCH=ppc64 $(build)=$(boot) $(patsubst %,$(boot)/%,$@) | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 160 |  | 
 | 161 | define archhelp | 
| Paul Mackerras | 94b212c | 2005-11-16 13:38:21 +1100 | [diff] [blame] | 162 |   @echo '* zImage          - Compressed kernel image (arch/$(ARCH)/boot/zImage.*)' | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 163 |   @echo '  install         - Install kernel using' | 
 | 164 |   @echo '                    (your) ~/bin/installkernel or' | 
 | 165 |   @echo '                    (distribution) /sbin/installkernel or' | 
 | 166 |   @echo '                    install to $$(INSTALL_PATH) and run lilo' | 
| Paul Mackerras | 437a58d | 2005-11-18 15:43:34 +1100 | [diff] [blame] | 167 |   @echo '  *_defconfig     - Select default config from arch/$(ARCH)/configs' | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 168 | endef | 
 | 169 |  | 
 | 170 | archclean: | 
| Paul Mackerras | a3a9e99 | 2005-09-28 15:53:36 +1000 | [diff] [blame] | 171 | 	$(Q)$(MAKE) $(clean)=$(boot) | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 172 | 	$(Q)rm -rf arch/$(ARCH)/include | 
 | 173 |  | 
 | 174 | archprepare: checkbin | 
 | 175 |  | 
 | 176 | # Temporary hack until we have migrated to asm-powerpc | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 177 | include/asm: arch/$(ARCH)/include/asm | 
| Benjamin Herrenschmidt | 50092b2 | 2005-11-14 11:02:20 +1100 | [diff] [blame] | 178 | arch/$(ARCH)/include/asm: FORCE | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 179 | 	$(Q)if [ ! -d arch/$(ARCH)/include ]; then mkdir -p arch/$(ARCH)/include; fi | 
| Stephen Rothwell | bbeb3f4 | 2005-09-27 13:51:59 +1000 | [diff] [blame] | 180 | 	$(Q)ln -fsn $(srctree)/include/asm-$(OLDARCH) arch/$(ARCH)/include/asm | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 181 |  | 
 | 182 | # Use the file '.tmp_gas_check' for binutils tests, as gas won't output | 
 | 183 | # to stdout and these checks are run even on install targets. | 
 | 184 | TOUT	:= .tmp_gas_check | 
 | 185 | # Ensure this is binutils 2.12.1 (or 2.12.90.0.7) or later for altivec | 
 | 186 | # instructions. | 
 | 187 | # gcc-3.4 and binutils-2.14 are a fatal combination. | 
 | 188 | GCC_VERSION	:= $(call cc-version) | 
 | 189 |  | 
 | 190 | checkbin: | 
 | 191 | 	@if test "$(GCC_VERSION)" = "0304" ; then \ | 
 | 192 | 		if ! /bin/echo mftb 5 | $(AS) -v -mppc -many -o $(TOUT) >/dev/null 2>&1 ; then \ | 
 | 193 | 			echo -n '*** ${VERSION}.${PATCHLEVEL} kernels no longer build '; \ | 
 | 194 | 			echo 'correctly with gcc-3.4 and your version of binutils.'; \ | 
 | 195 | 			echo '*** Please upgrade your binutils or downgrade your gcc'; \ | 
 | 196 | 			false; \ | 
 | 197 | 		fi ; \ | 
 | 198 | 	fi | 
 | 199 | 	@if ! /bin/echo dssall | $(AS) -many -o $(TOUT) >/dev/null 2>&1 ; then \ | 
 | 200 | 		echo -n '*** ${VERSION}.${PATCHLEVEL} kernels no longer build ' ; \ | 
 | 201 | 		echo 'correctly with old versions of binutils.' ; \ | 
 | 202 | 		echo '*** Please upgrade your binutils to 2.12.1 or newer' ; \ | 
 | 203 | 		false ; \ | 
 | 204 | 	fi | 
 | 205 |  | 
 | 206 | CLEAN_FILES += $(TOUT) | 
 | 207 |  |