mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-24 21:07:42 +00:00 
			
		
		
		
	 bf2a4c7270
			
		
	
	
		bf2a4c7270
		
	
	
	
	
		
			
			Between GCC version 3.4.0 and 4.3.3 (including 3.4.0 and 4.3.3), -mtune=merced is implemented in GCC. Starting from 4.4.0, -mtune=merced is deprecated. Even implemented in versions between 3.4.0 and 4.3.3, the -mtune=merced feature has been broken in some of the versions. For example, GCC 4.1.2 reports interanl tuning function errors during kernel building with -mtune=merced. Or GCC Bugzilla 16130 reports another -mtune=merced issue on GCC 3.4.1. So I would remove the -mtune=merced from IA64 kernel build. Without this option, kernel on Merced will remain the same except losing an unstable and out-of-date performance tunning feature. Since GCC version 3.4.0, -mtune=mckinley has been implemented. The -mtune=mckinley option functions the same as mtune=itanium2. And mtune=itanium2 is the default option. So we don't need to add mtune=mckinley either since its been the default option in any GCC version which implements this option. Signed-off-by: Fenghua Yu <fenghua.yu@intel.com>
		
			
				
	
	
		
			107 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			107 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
| #
 | |
| # ia64/Makefile
 | |
| #
 | |
| # This file is included by the global makefile so that you can add your own
 | |
| # architecture-specific flags and dependencies.
 | |
| #
 | |
| # 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) 1998-2004 by David Mosberger-Tang <davidm@hpl.hp.com>
 | |
| #
 | |
| 
 | |
| KBUILD_DEFCONFIG := generic_defconfig
 | |
| 
 | |
| NM := $(CROSS_COMPILE)nm -B
 | |
| READELF := $(CROSS_COMPILE)readelf
 | |
| 
 | |
| export AWK
 | |
| 
 | |
| CHECKFLAGS	+= -m64 -D__ia64=1 -D__ia64__=1 -D_LP64 -D__LP64__
 | |
| 
 | |
| OBJCOPYFLAGS	:= --strip-all
 | |
| LDFLAGS_vmlinux	:= -static
 | |
| LDFLAGS_MODULE	+= -T $(srctree)/arch/ia64/module.lds
 | |
| AFLAGS_KERNEL	:= -mconstant-gp
 | |
| EXTRA		:=
 | |
| 
 | |
| cflags-y	:= -pipe $(EXTRA) -ffixed-r13 -mfixed-range=f12-f15,f32-f127 \
 | |
| 		   -falign-functions=32 -frename-registers -fno-optimize-sibling-calls
 | |
| CFLAGS_KERNEL	:= -mconstant-gp
 | |
| 
 | |
| GAS_STATUS	= $(shell $(srctree)/arch/ia64/scripts/check-gas "$(CC)" "$(OBJDUMP)")
 | |
| KBUILD_CPPFLAGS += $(shell $(srctree)/arch/ia64/scripts/toolchain-flags "$(CC)" "$(OBJDUMP)" "$(READELF)")
 | |
| 
 | |
| ifeq ($(GAS_STATUS),buggy)
 | |
| $(error Sorry, you need a newer version of the assember, one that is built from	\
 | |
| 	a source-tree that post-dates 18-Dec-2002.  You can find a pre-compiled	\
 | |
| 	static binary of such an assembler at:					\
 | |
| 										\
 | |
| 		ftp://ftp.hpl.hp.com/pub/linux-ia64/gas-030124.tar.gz)
 | |
| endif
 | |
| 
 | |
| KBUILD_CFLAGS += $(cflags-y)
 | |
| head-y := arch/ia64/kernel/head.o arch/ia64/kernel/init_task.o
 | |
| 
 | |
| libs-y				+= arch/ia64/lib/
 | |
| core-y				+= arch/ia64/kernel/ arch/ia64/mm/
 | |
| core-$(CONFIG_IA32_SUPPORT)	+= arch/ia64/ia32/
 | |
| core-$(CONFIG_IA64_DIG) 	+= arch/ia64/dig/
 | |
| core-$(CONFIG_IA64_DIG_VTD) 	+= arch/ia64/dig/
 | |
| core-$(CONFIG_IA64_GENERIC) 	+= arch/ia64/dig/
 | |
| core-$(CONFIG_IA64_HP_ZX1)	+= arch/ia64/dig/
 | |
| core-$(CONFIG_IA64_HP_ZX1_SWIOTLB) += arch/ia64/dig/
 | |
| core-$(CONFIG_IA64_XEN_GUEST)	+= arch/ia64/dig/
 | |
| core-$(CONFIG_IA64_SGI_SN2)	+= arch/ia64/sn/
 | |
| core-$(CONFIG_IA64_SGI_UV)	+= arch/ia64/uv/
 | |
| core-$(CONFIG_KVM) 		+= arch/ia64/kvm/
 | |
| core-$(CONFIG_XEN)		+= arch/ia64/xen/
 | |
| 
 | |
| drivers-$(CONFIG_PCI)		+= arch/ia64/pci/
 | |
| drivers-$(CONFIG_IA64_HP_SIM)	+= arch/ia64/hp/sim/
 | |
| drivers-$(CONFIG_IA64_HP_ZX1)	+= arch/ia64/hp/common/ arch/ia64/hp/zx1/
 | |
| drivers-$(CONFIG_IA64_HP_ZX1_SWIOTLB) += arch/ia64/hp/common/ arch/ia64/hp/zx1/
 | |
| drivers-$(CONFIG_IA64_GENERIC)	+= arch/ia64/hp/common/ arch/ia64/hp/zx1/ arch/ia64/hp/sim/ arch/ia64/sn/ arch/ia64/uv/
 | |
| drivers-$(CONFIG_OPROFILE)	+= arch/ia64/oprofile/
 | |
| 
 | |
| boot := arch/ia64/hp/sim/boot
 | |
| 
 | |
| PHONY += boot compressed check
 | |
| 
 | |
| all: compressed unwcheck
 | |
| 
 | |
| compressed: vmlinux.gz
 | |
| 
 | |
| vmlinuz: vmlinux.gz
 | |
| 
 | |
| vmlinux.gz: vmlinux
 | |
| 	$(Q)$(MAKE) $(build)=$(boot) $@
 | |
| 
 | |
| unwcheck: vmlinux
 | |
| 	-$(Q)READELF=$(READELF) python $(srctree)/arch/ia64/scripts/unwcheck.py $<
 | |
| 
 | |
| archclean:
 | |
| 	$(Q)$(MAKE) $(clean)=$(boot)
 | |
| 
 | |
| CLEAN_FILES += vmlinux.gz bootloader
 | |
| 
 | |
| boot:	lib/lib.a vmlinux
 | |
| 	$(Q)$(MAKE) $(build)=$(boot) $@
 | |
| 
 | |
| install: vmlinux.gz
 | |
| 	sh $(srctree)/arch/ia64/install.sh $(KERNELRELEASE) $< System.map "$(INSTALL_PATH)"
 | |
| 
 | |
| define archhelp
 | |
|   echo '* compressed	- Build compressed kernel image'
 | |
|   echo '  install	- Install compressed kernel image'
 | |
|   echo '  boot		- Build vmlinux and bootloader for Ski simulator'
 | |
|   echo '* unwcheck	- Check vmlinux for invalid unwind info'
 | |
| endef
 | |
| 
 | |
| archprepare: make_nr_irqs_h FORCE
 | |
| PHONY += make_nr_irqs_h FORCE
 | |
| 
 | |
| make_nr_irqs_h: FORCE
 | |
| 	$(Q)$(MAKE) $(build)=arch/ia64/kernel include/asm-ia64/nr-irqs.h
 |