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