blob: 8496a074bd0eb74548ce1e38709b8a8dfe7dfb31 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#
2# sparc/Makefile
3#
4# Makefile for the architecture dependent flags and dependencies on the
Sam Ravnborg5e538792008-12-02 23:17:12 -08005# Sparc and sparc64.
Linus Torvalds1da177e2005-04-16 15:20:36 -07006#
Sam Ravnborg5e538792008-12-02 23:17:12 -08007# Copyright (C) 1994,1996,1998 David S. Miller (davem@caip.rutgers.edu)
8# Copyright (C) 1998 Jakub Jelinek (jj@ultra.linux.cz)
9
10# We are not yet configured - so test on arch
11ifeq ($(ARCH),sparc)
12 KBUILD_DEFCONFIG := sparc32_defconfig
13else
14 KBUILD_DEFCONFIG := sparc64_defconfig
15endif
16
17ifeq ($(CONFIG_SPARC32),y)
18#####
19# sparc32
Linus Torvalds1da177e2005-04-16 15:20:36 -070020#
21
Sam Ravnborgb0cdd592008-11-16 20:04:20 -080022CHECKFLAGS += -D__sparc__
Sam Ravnborg38753582012-05-15 21:21:55 +020023LDFLAGS := -m elf32_sparc
Sam Ravnborgb0cdd592008-11-16 20:04:20 -080024export BITS := 32
David S. Miller7f5620a2009-12-05 17:17:55 -080025UTS_MACHINE := sparc
Linus Torvalds1da177e2005-04-16 15:20:36 -070026
David S. Miller22be3b12016-01-17 11:47:29 -050027# We are adding -Wa,-Av8 to KBUILD_CFLAGS to deal with a specs bug in some
28# versions of gcc. Some gcc versions won't pass -Av8 to binutils when you
29# give -mcpu=v8. This silently worked with older bintutils versions but
30# does not any more.
Sam Ravnborg38753582012-05-15 21:21:55 +020031KBUILD_CFLAGS += -m32 -mcpu=v8 -pipe -mno-fpu -fcall-used-g5 -fcall-used-g7
David S. Miller22be3b12016-01-17 11:47:29 -050032KBUILD_CFLAGS += -Wa,-Av8
33
Sam Ravnborg38753582012-05-15 21:21:55 +020034KBUILD_AFLAGS += -m32 -Wa,-Av8
Linus Torvalds1da177e2005-04-16 15:20:36 -070035
Sam Ravnborg5e538792008-12-02 23:17:12 -080036else
37#####
38# sparc64
39#
40
Sam Ravnborg38753582012-05-15 21:21:55 +020041CHECKFLAGS += -D__sparc__ -D__sparc_v9__ -D__arch64__ -m64
42LDFLAGS := -m elf64_sparc
43export BITS := 64
44UTS_MACHINE := sparc64
Sam Ravnborg5e538792008-12-02 23:17:12 -080045
Sam Ravnborg38753582012-05-15 21:21:55 +020046KBUILD_CFLAGS += -m64 -pipe -mno-fpu -mcpu=ultrasparc -mcmodel=medlow
47KBUILD_CFLAGS += -ffixed-g4 -ffixed-g5 -fcall-used-g7 -Wno-sign-compare
48KBUILD_CFLAGS += -Wa,--undeclared-regs
Sam Ravnborg5e538792008-12-02 23:17:12 -080049KBUILD_CFLAGS += $(call cc-option,-mtune=ultrasparc3)
50KBUILD_AFLAGS += -m64 -mcpu=ultrasparc -Wa,--undeclared-regs
51
52ifeq ($(CONFIG_MCOUNT),y)
53 KBUILD_CFLAGS += -pg
54endif
55
56endif
57
Sam Ravnborga88b5ba2008-12-03 03:11:52 -080058head-y := arch/sparc/kernel/head_$(BITS).o
Sam Ravnborg5e538792008-12-02 23:17:12 -080059
Sam Ravnborge1d7de82012-05-15 21:27:15 +020060# See arch/sparc/Kbuild for the core part of the kernel
61core-y += arch/sparc/
Sam Ravnborg5e538792008-12-02 23:17:12 -080062
Sam Ravnborg5de18cd2008-11-29 22:16:52 -080063libs-y += arch/sparc/prom/
Sam Ravnborg478b8fe2008-12-03 03:10:25 -080064libs-y += arch/sparc/lib/
Linus Torvalds1da177e2005-04-16 15:20:36 -070065
Tkhai Kirillbdde6b32013-03-19 15:11:07 +000066drivers-$(CONFIG_PM) += arch/sparc/power/
Martin Habets9550e592006-10-17 19:21:48 -070067drivers-$(CONFIG_OPROFILE) += arch/sparc/oprofile/
68
Sam Ravnborga8c601c2008-12-03 03:14:26 -080069boot := arch/sparc/boot
Linus Torvalds1da177e2005-04-16 15:20:36 -070070
Jurij Smakov48e46b72009-08-16 18:21:47 -070071# Default target
72all: zImage
73
Daniel Hellstrom684151a2011-01-26 06:36:35 +000074image zImage uImage tftpboot.img vmlinux.aout: vmlinux
Sam Ravnborga8c601c2008-12-03 03:14:26 -080075 $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@
Linus Torvalds1da177e2005-04-16 15:20:36 -070076
David L Stevensc78f77e2014-07-25 13:41:51 -040077install:
78 $(Q)$(MAKE) $(build)=$(boot) $@
79
Linus Torvalds1da177e2005-04-16 15:20:36 -070080archclean:
Sam Ravnborga8c601c2008-12-03 03:14:26 -080081 $(Q)$(MAKE) $(clean)=$(boot)
Linus Torvalds1da177e2005-04-16 15:20:36 -070082
Martin Habets349101d2008-08-18 22:37:18 -070083# This is the image used for packaging
Sam Ravnborga8c601c2008-12-03 03:14:26 -080084KBUILD_IMAGE := $(boot)/zImage
Martin Habets349101d2008-08-18 22:37:18 -070085
Linus Torvalds1da177e2005-04-16 15:20:36 -070086# Don't use tabs in echo arguments.
Sam Ravnborg5e538792008-12-02 23:17:12 -080087ifeq ($(ARCH),sparc)
Linus Torvalds1da177e2005-04-16 15:20:36 -070088define archhelp
89 echo '* image - kernel image ($(boot)/image)'
Martin Habets349101d2008-08-18 22:37:18 -070090 echo '* zImage - stripped kernel image ($(boot)/zImage)'
Daniel Hellstrom684151a2011-01-26 06:36:35 +000091 echo ' uImage - U-Boot SPARC32 Image (only for LEON)'
Linus Torvalds1da177e2005-04-16 15:20:36 -070092 echo ' tftpboot.img - image prepared for tftp'
93endef
Sam Ravnborg5e538792008-12-02 23:17:12 -080094else
95define archhelp
Jurij Smakov48e46b72009-08-16 18:21:47 -070096 echo '* vmlinux - standard sparc64 kernel'
97 echo '* zImage - stripped and compressed sparc64 kernel ($(boot)/zImage)'
98 echo ' vmlinux.aout - a.out kernel for sparc64'
Sam Ravnborg5e538792008-12-02 23:17:12 -080099 echo ' tftpboot.img - image prepared for tftp'
100endef
101endif