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:
Родитель
14ae84c993
Коммит
5e53879008
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
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче