mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 02:30:34 +02:00 
			
		
		
		
	sparc,sparc64: unify Makefile
To unify Makefile for sparc and sparc64 a few other steps was needed:
1) separate defconfig files for sparc and sparc64 is required,
   so locate these in arch/sparc/configs
2) removoval of hack in toplevel Makefile to deal with that
   headers was in a separate directory compared to the rest
The unification of the Makefile required usage of several
    foo-$(CONFIG_SPARCnn) +=
due to a few directories pending unification.
This will be cleaned up when we unify the remaining directories.
Included in this patch are the deletion of a few files in
sparc64 as they are no longer needed: Makefile + Kconfig.
arch/sparc64/ will after this patch is applied only
have four directories (prom, lib, kernel, boot)
Signed-off-by: Sam Ravnborg <sam@ravnborg.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
			
			
This commit is contained in:
		
							parent
							
								
									14ae84c993
								
							
						
					
					
						commit
						5e53879008
					
				
					 7 changed files with 81 additions and 66 deletions
				
			
		
							
								
								
									
										9
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										9
									
								
								Makefile
									
									
									
									
									
								
							| 
						 | 
					@ -205,13 +205,14 @@ ifeq ($(ARCH),x86_64)
 | 
				
			||||||
        SRCARCH := x86
 | 
					        SRCARCH := x86
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Where to locate arch specific headers
 | 
					# Additional ARCH settings for sparc
 | 
				
			||||||
ifeq ($(ARCH),sparc64)
 | 
					ifeq ($(ARCH),sparc64)
 | 
				
			||||||
       hdr-arch  := sparc
 | 
					       SRCARCH := sparc
 | 
				
			||||||
else
 | 
					 | 
				
			||||||
       hdr-arch  := $(SRCARCH)
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Where to locate arch specific headers
 | 
				
			||||||
 | 
					hdr-arch  := $(SRCARCH)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
KCONFIG_CONFIG	?= .config
 | 
					KCONFIG_CONFIG	?= .config
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# SHELL used by kbuild
 | 
					# SHELL used by kbuild
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -41,6 +41,13 @@ config SPARC64
 | 
				
			||||||
	select RTC_DRV_SUN4V
 | 
						select RTC_DRV_SUN4V
 | 
				
			||||||
	select RTC_DRV_STARFIRE
 | 
						select RTC_DRV_STARFIRE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					config ARCH_DEFCONFIG
 | 
				
			||||||
 | 
						string
 | 
				
			||||||
 | 
						default "arch/sparc/configs/sparc32_defconfig" if SPARC32
 | 
				
			||||||
 | 
						default "arch/sparc/configs/sparc64_defconfig" if SPARC64
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
config 64BIT
 | 
					config 64BIT
 | 
				
			||||||
	def_bool y if SPARC64
 | 
						def_bool y if SPARC64
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -2,9 +2,21 @@
 | 
				
			||||||
# sparc/Makefile
 | 
					# sparc/Makefile
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# Makefile for the architecture dependent flags and dependencies on the
 | 
					# Makefile for the architecture dependent flags and dependencies on the
 | 
				
			||||||
# Sparc.
 | 
					# Sparc and sparc64.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# Copyright (C) 1994 David S. Miller (davem@caip.rutgers.edu)
 | 
					# Copyright (C) 1994,1996,1998 David S. Miller (davem@caip.rutgers.edu)
 | 
				
			||||||
 | 
					# Copyright (C) 1998 Jakub Jelinek (jj@ultra.linux.cz)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# We are not yet configured - so test on arch
 | 
				
			||||||
 | 
					ifeq ($(ARCH),sparc)
 | 
				
			||||||
 | 
					        KBUILD_DEFCONFIG := sparc32_defconfig
 | 
				
			||||||
 | 
					else
 | 
				
			||||||
 | 
					        KBUILD_DEFCONFIG := sparc64_defconfig
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifeq ($(CONFIG_SPARC32),y)
 | 
				
			||||||
 | 
					#####
 | 
				
			||||||
 | 
					# sparc32
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					@ -26,10 +38,48 @@ CPPFLAGS_vmlinux.lds += -m32
 | 
				
			||||||
#  Actual linking is done with "make image".
 | 
					#  Actual linking is done with "make image".
 | 
				
			||||||
LDFLAGS_vmlinux = -r
 | 
					LDFLAGS_vmlinux = -r
 | 
				
			||||||
 | 
					
 | 
				
			||||||
head-y := arch/sparc/kernel/head.o arch/sparc/kernel/init_task.o
 | 
					# Default target
 | 
				
			||||||
 | 
					all: zImage
 | 
				
			||||||
 | 
					
 | 
				
			||||||
core-y += arch/sparc/kernel/ arch/sparc/mm/ arch/sparc/math-emu/
 | 
					
 | 
				
			||||||
libs-y += arch/sparc/prom/ arch/sparc/lib/
 | 
					else
 | 
				
			||||||
 | 
					#####
 | 
				
			||||||
 | 
					# sparc64
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					CHECKFLAGS      += -D__sparc__ -D__sparc_v9__ -D__arch64__ -m64
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Undefine sparc when processing vmlinux.lds - it is used
 | 
				
			||||||
 | 
					# And teach CPP we are doing 64 bit builds (for this case)
 | 
				
			||||||
 | 
					CPPFLAGS_vmlinux.lds += -m64 -Usparc
 | 
				
			||||||
 | 
					LDFLAGS              := -m elf64_sparc
 | 
				
			||||||
 | 
					export BITS          := 64
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					KBUILD_CFLAGS += -m64 -pipe -mno-fpu -mcpu=ultrasparc -mcmodel=medlow   \
 | 
				
			||||||
 | 
					                 -ffixed-g4 -ffixed-g5 -fcall-used-g7 -Wno-sign-compare \
 | 
				
			||||||
 | 
					                 -Wa,--undeclared-regs
 | 
				
			||||||
 | 
					KBUILD_CFLAGS += $(call cc-option,-mtune=ultrasparc3)
 | 
				
			||||||
 | 
					KBUILD_AFLAGS += -m64 -mcpu=ultrasparc -Wa,--undeclared-regs
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ifeq ($(CONFIG_MCOUNT),y)
 | 
				
			||||||
 | 
					  KBUILD_CFLAGS += -pg
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					head-$(CONFIG_SPARC32) := arch/sparc/kernel/head.o
 | 
				
			||||||
 | 
					head-$(CONFIG_SPARC32) += arch/sparc/kernel/init_task.o
 | 
				
			||||||
 | 
					head-$(CONFIG_SPARC64) := arch/sparc64/kernel/head.o
 | 
				
			||||||
 | 
					head-$(CONFIG_SPARC64) += arch/sparc64/kernel/init_task.o
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					core-$(CONFIG_SPARC32) += arch/sparc/kernel/
 | 
				
			||||||
 | 
					core-$(CONFIG_SPARC64) += arch/sparc64/kernel/
 | 
				
			||||||
 | 
					core-y                 += arch/sparc/mm/ arch/sparc/math-emu/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					libs-$(CONFIG_SPARC32) += arch/sparc/prom/
 | 
				
			||||||
 | 
					libs-$(CONFIG_SPARC32) += arch/sparc/lib/
 | 
				
			||||||
 | 
					libs-$(CONFIG_SPARC64) += arch/sparc64/prom/
 | 
				
			||||||
 | 
					libs-$(CONFIG_SPARC64) += arch/sparc64/lib/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
drivers-$(CONFIG_OPROFILE)	+= arch/sparc/oprofile/
 | 
					drivers-$(CONFIG_OPROFILE)	+= arch/sparc/oprofile/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -44,23 +94,29 @@ ifdef CONFIG_KALLSYMS
 | 
				
			||||||
export kallsyms.o := .tmp_kallsyms2.o
 | 
					export kallsyms.o := .tmp_kallsyms2.o
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Default target
 | 
					boot-y                 := arch/sparc/boot
 | 
				
			||||||
all: zImage
 | 
					boot-$(CONFIG_SPARC64) := arch/sparc64/boot
 | 
				
			||||||
 | 
					
 | 
				
			||||||
boot := arch/sparc/boot
 | 
					image zImage tftpboot.img vmlinux.aout: vmlinux
 | 
				
			||||||
 | 
						$(Q)$(MAKE) $(build)=$(boot-y) $(boot-y)/$@
 | 
				
			||||||
image zImage tftpboot.img: vmlinux
 | 
					 | 
				
			||||||
	$(Q)$(MAKE) $(build)=$(boot) $(boot)/$@
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
archclean:
 | 
					archclean:
 | 
				
			||||||
	$(Q)$(MAKE) $(clean)=$(boot)
 | 
						$(Q)$(MAKE) $(clean)=$(boot-y)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# This is the image used for packaging
 | 
					# This is the image used for packaging
 | 
				
			||||||
KBUILD_IMAGE := $(boot)/zImage
 | 
					KBUILD_IMAGE := $(boot-y)/zImage
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Don't use tabs in echo arguments.
 | 
					# Don't use tabs in echo arguments.
 | 
				
			||||||
 | 
					ifeq ($(ARCH),sparc)
 | 
				
			||||||
define archhelp
 | 
					define archhelp
 | 
				
			||||||
  echo  '* image        - kernel image ($(boot)/image)'
 | 
					  echo  '* image        - kernel image ($(boot)/image)'
 | 
				
			||||||
  echo  '* zImage       - stripped kernel image ($(boot)/zImage)'
 | 
					  echo  '* zImage       - stripped kernel image ($(boot)/zImage)'
 | 
				
			||||||
  echo  '  tftpboot.img - image prepared for tftp'
 | 
					  echo  '  tftpboot.img - image prepared for tftp'
 | 
				
			||||||
endef
 | 
					endef
 | 
				
			||||||
 | 
					else
 | 
				
			||||||
 | 
					define archhelp
 | 
				
			||||||
 | 
					  echo  '* vmlinux       - Standard sparc64 kernel'
 | 
				
			||||||
 | 
					  echo  '  vmlinux.aout  - a.out kernel for sparc64'
 | 
				
			||||||
 | 
					  echo  '  tftpboot.img - image prepared for tftp'
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1 +0,0 @@
 | 
				
			||||||
source arch/sparc/Kconfig
 | 
					 | 
				
			||||||
| 
						 | 
					@ -1,48 +0,0 @@
 | 
				
			||||||
# sparc64/Makefile
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# Makefile for the architecture dependent flags and dependencies on the
 | 
					 | 
				
			||||||
# 64-bit Sparc.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# Copyright (C) 1996,1998 David S. Miller (davem@caip.rutgers.edu)
 | 
					 | 
				
			||||||
# Copyright (C) 1998 Jakub Jelinek (jj@ultra.linux.cz)
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CHECKFLAGS	+= -D__sparc__ -D__sparc_v9__ -D__arch64__ -m64
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Undefine sparc when processing vmlinux.lds - it is used
 | 
					 | 
				
			||||||
# And teach CPP we are doing 64 bit builds (for this case)
 | 
					 | 
				
			||||||
CPPFLAGS_vmlinux.lds += -m64 -Usparc
 | 
					 | 
				
			||||||
LDFLAGS              := -m elf64_sparc
 | 
					 | 
				
			||||||
export BITS          := 64
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
KBUILD_CFLAGS += -m64 -pipe -mno-fpu -mcpu=ultrasparc -mcmodel=medlow \
 | 
					 | 
				
			||||||
	-ffixed-g4 -ffixed-g5 -fcall-used-g7 -Wno-sign-compare \
 | 
					 | 
				
			||||||
	-Wa,--undeclared-regs
 | 
					 | 
				
			||||||
KBUILD_CFLAGS += $(call cc-option,-mtune=ultrasparc3)
 | 
					 | 
				
			||||||
KBUILD_AFLAGS += -m64 -mcpu=ultrasparc -Wa,--undeclared-regs
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
ifeq ($(CONFIG_MCOUNT),y)
 | 
					 | 
				
			||||||
  KBUILD_CFLAGS += -pg
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
head-y := arch/sparc64/kernel/head.o arch/sparc64/kernel/init_task.o
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
core-y				+= arch/sparc64/kernel/ arch/sparc/mm/
 | 
					 | 
				
			||||||
core-y				+= arch/sparc/math-emu/
 | 
					 | 
				
			||||||
libs-y				+= arch/sparc64/prom/ arch/sparc64/lib/
 | 
					 | 
				
			||||||
drivers-$(CONFIG_OPROFILE)	+= arch/sparc/oprofile/
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
boot := arch/sparc64/boot
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
image tftpboot.img vmlinux.aout: vmlinux
 | 
					 | 
				
			||||||
	$(Q)$(MAKE) $(build)=$(boot) $(boot)/$@
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
archclean:
 | 
					 | 
				
			||||||
	$(Q)$(MAKE) $(clean)=$(boot)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
define archhelp
 | 
					 | 
				
			||||||
  echo  '* vmlinux       - Standard sparc64 kernel'
 | 
					 | 
				
			||||||
  echo  '  vmlinux.aout  - a.out kernel for sparc64'
 | 
					 | 
				
			||||||
  echo  '  tftpboot.img  - Image prepared for tftp'
 | 
					 | 
				
			||||||
endef
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		Loading…
	
		Reference in a new issue