1 # 1 # 2 # parisc/Makefile !! 2 # sparc/Makefile 3 # 3 # 4 # This file is included by the global makefile !! 4 # Makefile for the architecture dependent flags and dependencies on the 5 # architecture-specific flags and dependencies !! 5 # Sparc and sparc64. 6 # 6 # 7 # This file is subject to the terms and condit !! 7 # Copyright (C) 1994,1996,1998 David S. Miller (davem@caip.rutgers.edu) 8 # License. See the file "COPYING" in the main !! 8 # Copyright (C) 1998 Jakub Jelinek (jj@ultra.linux.cz) 9 # for more details. << 10 # << 11 # Copyright (C) 1994 by Linus Torvalds << 12 # Portions Copyright (C) 1999 The Puffin Group << 13 # << 14 # Modified for PA-RISC Linux by Paul Lahaie, A << 15 # Mike Shaver, Helge Deller and Martin K. Pete << 16 # << 17 << 18 boot := arch/parisc/boot << 19 KBUILD_IMAGE := $(boot)/bzImage << 20 << 21 CHECKFLAGS += -D__hppa__=1 << 22 << 23 ifdef CONFIG_64BIT << 24 UTS_MACHINE := parisc64 << 25 CHECKFLAGS += -D__LP64__=1 << 26 LD_BFD := elf64-hppa-linux << 27 else # 32-bit << 28 LD_BFD := elf32-hppa-linux << 29 endif << 30 9 31 # select defconfig based on actual architectur !! 10 # We are not yet configured - so test on arch 32 ifeq ($(ARCH),parisc64) !! 11 ifeq ($(ARCH),sparc) 33 KBUILD_DEFCONFIG := generic-64bit_defc !! 12 KBUILD_DEFCONFIG := sparc32_defconfig 34 CC_ARCHES := hppa64 << 35 else 13 else 36 KBUILD_DEFCONFIG := generic-32bit_defc !! 14 KBUILD_DEFCONFIG := sparc64_defconfig 37 CC_ARCHES := hppa hppa2.0 hppa1.1 << 38 endif 15 endif 39 16 40 export LD_BFD !! 17 ifeq ($(CONFIG_SPARC32),y) 41 !! 18 ##### 42 # Set default 32 bits cross compilers for vdso !! 19 # sparc32 43 CC_ARCHES_32 = hppa hppa2.0 hppa1.1 !! 20 # 44 CC_SUFFIXES = linux linux-gnu unknown-linux-g << 45 CROSS32_COMPILE := $(call cc-cross-prefix, \ << 46 $(foreach a,$(CC_ARCHES_32), \ << 47 $(foreach s,$(CC_SUFFIXES),$(a)-$(s)-) << 48 CROSS32CC := $(CROSS32_COMPILE)gcc << 49 export CROSS32CC << 50 << 51 # Set default cross compiler for kernel build << 52 ifdef cross_compiling << 53 ifeq ($(CROSS_COMPILE),) << 54 CC_SUFFIXES = linux linux-gnu << 55 CROSS_COMPILE := $(call cc-cro << 56 $(foreach a,$(CC_ARCHE << 57 $(foreach s,$(CC_SUFFI << 58 endif << 59 endif << 60 << 61 ifdef CONFIG_DYNAMIC_FTRACE << 62 ifdef CONFIG_64BIT << 63 NOP_COUNT := 8 << 64 else << 65 NOP_COUNT := 5 << 66 endif << 67 << 68 export CC_USING_RECORD_MCOUNT:=1 << 69 export CC_USING_PATCHABLE_FUNCTION_ENTRY:=1 << 70 21 71 KBUILD_AFLAGS += -DCC_USING_PATCHABLE_FUNCTION !! 22 # 72 KBUILD_CFLAGS += -DCC_USING_PATCHABLE_FUNCTION !! 23 # Uncomment the first KBUILD_CFLAGS if you are doing kgdb source level 73 -DFTRACE_PATCHABLE_FUNCTION_S !! 24 # debugging of the kernel to get the proper debugging information. 74 25 75 CC_FLAGS_FTRACE := -fpatchable-function-entry= !! 26 AS := $(AS) -32 76 endif !! 27 LDFLAGS := -m elf32_sparc >> 28 CHECKFLAGS += -D__sparc__ >> 29 export BITS := 32 >> 30 UTS_MACHINE := sparc >> 31 >> 32 #KBUILD_CFLAGS += -g -pipe -fcall-used-g5 -fcall-used-g7 >> 33 KBUILD_CFLAGS += -m32 -pipe -mno-fpu -fcall-used-g5 -fcall-used-g7 >> 34 KBUILD_AFLAGS += -m32 -Wa,-Av8 >> 35 >> 36 #LDFLAGS_vmlinux = -N -Ttext 0xf0004000 >> 37 # Since 2.5.40, the first stage is left not btfix-ed. >> 38 # Actual linking is done with "make image". >> 39 LDFLAGS_vmlinux = -r 77 40 78 OBJCOPY_FLAGS =-O binary -R .note -R .comment !! 41 else >> 42 ##### >> 43 # sparc64 >> 44 # 79 45 80 cflags-y := -pipe !! 46 CHECKFLAGS += -D__sparc__ -D__sparc_v9__ -D__arch64__ -m64 81 47 82 # These flags should be implied by an hppa-lin !! 48 LDFLAGS := -m elf64_sparc 83 # are not in gcc 3.2. !! 49 export BITS := 64 84 cflags-y += -mno-space-regs !! 50 UTS_MACHINE := sparc64 85 51 86 # -mfast-indirect-calls is only relevant for 3 !! 52 KBUILD_CFLAGS += -m64 -pipe -mno-fpu -mcpu=ultrasparc -mcmodel=medlow \ 87 ifndef CONFIG_64BIT !! 53 -ffixed-g4 -ffixed-g5 -fcall-used-g7 -Wno-sign-compare \ 88 cflags-y += -mfast-indirect-calls !! 54 -Wa,--undeclared-regs 89 endif !! 55 KBUILD_CFLAGS += $(call cc-option,-mtune=ultrasparc3) >> 56 KBUILD_AFLAGS += -m64 -mcpu=ultrasparc -Wa,--undeclared-regs 90 57 91 # Currently we save and restore fpregs on all !! 58 ifeq ($(CONFIG_MCOUNT),y) 92 # If that gets optimized, we might need to dis !! 59 KBUILD_CFLAGS += -pg 93 # kernel. << 94 cflags-y += -mdisable-fpregs << 95 << 96 # Use long jumps instead of long branches (nee << 97 # link a too big vmlinux executable). Not enab << 98 ifdef CONFIG_MLONGCALLS << 99 KBUILD_CFLAGS_KERNEL += -mlong-calls << 100 endif 60 endif 101 61 102 # Without this, "ld -r" results in .text secti << 103 # for branches to reach stubs. And multiple .t << 104 # when creating the sysfs module information s << 105 ifndef CONFIG_64BIT << 106 KBUILD_CFLAGS_MODULE += -ffunction-sections << 107 endif 62 endif 108 63 109 # select which processor to optimise for !! 64 head-y := arch/sparc/kernel/head_$(BITS).o 110 cflags-$(CONFIG_PA7000) += -march=1.1 !! 65 head-y += arch/sparc/kernel/init_task.o 111 cflags-$(CONFIG_PA7200) += -march=1.1 << 112 cflags-$(CONFIG_PA7100LC) += -march=1.1 << 113 cflags-$(CONFIG_PA7300LC) += -march=1.1 << 114 cflags-$(CONFIG_PA8X00) += -march=2.0 << 115 << 116 KBUILD_CFLAGS += $(cflags-y) << 117 LIBGCC := $(shell $(CC) -print-libgcc << 118 export LIBGCC << 119 << 120 libs-y += arch/parisc/lib/ $(LIBGCC) << 121 << 122 drivers-$(CONFIG_VIDEO) += arch/parisc/video/ << 123 << 124 boot := arch/parisc/boot << 125 << 126 PALO := $(shell if (which palo 2>&1); then : ; << 127 elif [ -x /sbin/palo ]; then echo /sbi << 128 fi) << 129 << 130 PALOCONF := $(shell if [ -f $(srctree)/palo.co << 131 else echo $(objtree)/palo.conf; \ << 132 fi) << 133 << 134 palo lifimage: vmlinuz << 135 @if test ! -x "$(PALO)"; then \ << 136 echo 'ERROR: Please install pa << 137 echo 'or build it from source << 138 false; \ << 139 fi << 140 @if test ! -f "$(PALOCONF)"; then \ << 141 cp $(srctree)/arch/parisc/defp << 142 echo 'A generic palo config fi << 143 echo 'You should check it and << 144 echo 'WARNING: the "lifimage" << 145 false; \ << 146 fi << 147 $(PALO) -f $(PALOCONF) << 148 << 149 BOOT_TARGETS = zImage Image palo lifimage << 150 INSTALL_TARGETS = zinstall install << 151 << 152 PHONY += bzImage $(BOOT_TARGETS) $(INSTALL_TAR << 153 66 154 # Default kernel to build !! 67 core-y += arch/sparc/kernel/ 155 all: bzImage !! 68 core-y += arch/sparc/mm/ arch/sparc/math-emu/ 156 69 157 zImage: vmlinuz !! 70 libs-y += arch/sparc/prom/ 158 Image: vmlinux !! 71 libs-y += arch/sparc/lib/ 159 72 160 bzImage: vmlinux !! 73 drivers-$(CONFIG_OPROFILE) += arch/sparc/oprofile/ 161 $(Q)$(MAKE) $(build)=$(boot) $(boot)/$ << 162 74 163 vmlinuz: bzImage !! 75 # Export what is needed by arch/sparc/boot/Makefile 164 $(OBJCOPY) $(boot)/bzImage $@ !! 76 export VMLINUX_INIT VMLINUX_MAIN >> 77 VMLINUX_INIT := $(head-y) $(init-y) >> 78 VMLINUX_MAIN := $(core-y) kernel/ mm/ fs/ ipc/ security/ crypto/ block/ >> 79 VMLINUX_MAIN += $(patsubst %/, %/lib.a, $(libs-y)) $(libs-y) >> 80 VMLINUX_MAIN += $(drivers-y) $(net-y) 165 81 166 ifeq ($(KBUILD_EXTMOD),) !! 82 ifdef CONFIG_KALLSYMS 167 # We need to generate vdso-offsets.h before co !! 83 export kallsyms.o := .tmp_kallsyms2.o 168 # In order to do that, we should use the archp << 169 # asm-offsets.h is included in some files used << 170 # asm-offsets.h is built in prepare0, for whic << 171 # Therefore we need to generate the header aft << 172 # this hack. << 173 prepare: vdso_prepare << 174 vdso_prepare: prepare0 << 175 $(if $(CONFIG_64BIT),$(Q)$(MAKE) \ << 176 $(build)=arch/parisc/kernel/vd << 177 $(Q)$(MAKE) $(build)=arch/parisc/kerne << 178 endif 84 endif 179 85 180 vdso-install-y += arch/parisc !! 86 boot := arch/sparc/boot 181 vdso-install-$(CONFIG_64BIT) += arch/parisc !! 87 >> 88 # Default target >> 89 all: zImage 182 90 183 install: KBUILD_IMAGE := vmlinux !! 91 image zImage tftpboot.img vmlinux.aout: vmlinux 184 zinstall: KBUILD_IMAGE := vmlinuz !! 92 $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@ 185 install zinstall: !! 93 186 $(call cmd,install) !! 94 archclean: >> 95 $(Q)$(MAKE) $(clean)=$(boot) 187 96 188 CLEAN_FILES += lifimage !! 97 # This is the image used for packaging 189 MRPROPER_FILES += palo.conf !! 98 KBUILD_IMAGE := $(boot)/zImage 190 99 >> 100 # Don't use tabs in echo arguments. >> 101 ifeq ($(ARCH),sparc) 191 define archhelp 102 define archhelp 192 @echo '* vmlinux - Uncompressed !! 103 echo '* image - kernel image ($(boot)/image)' 193 @echo ' vmlinuz - Compressed k !! 104 echo '* zImage - stripped kernel image ($(boot)/zImage)' 194 @echo ' palo - Bootable ima !! 105 echo ' tftpboot.img - image prepared for tftp' 195 @echo ' install - Install unco << 196 @echo ' (your) ~/bin << 197 @echo ' (distributio << 198 @echo ' copy to $$(I << 199 @echo ' zinstall - Install comp << 200 endef 106 endef 201 !! 107 else 202 archheaders: !! 108 define archhelp 203 $(Q)$(MAKE) $(build)=arch/parisc/kerne !! 109 echo '* vmlinux - standard sparc64 kernel' >> 110 echo '* zImage - stripped and compressed sparc64 kernel ($(boot)/zImage)' >> 111 echo ' vmlinux.aout - a.out kernel for sparc64' >> 112 echo ' tftpboot.img - image prepared for tftp' >> 113 endef >> 114 endif
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.