blob: 2003ded054c25c779e2f19422acf130b61b7213c [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
22#
Sam Ravnborga0f97e02007-10-14 22:21:35 +020023# Uncomment the first KBUILD_CFLAGS if you are doing kgdb source level
Linus Torvalds1da177e2005-04-16 15:20:36 -070024# debugging of the kernel to get the proper debugging information.
25
Sam Ravnborgb0cdd592008-11-16 20:04:20 -080026AS := $(AS) -32
27LDFLAGS := -m elf32_sparc
28CHECKFLAGS += -D__sparc__
29export BITS := 32
Linus Torvalds1da177e2005-04-16 15:20:36 -070030
Sam Ravnborga0f97e02007-10-14 22:21:35 +020031#KBUILD_CFLAGS += -g -pipe -fcall-used-g5 -fcall-used-g7
32KBUILD_CFLAGS += -m32 -pipe -mno-fpu -fcall-used-g5 -fcall-used-g7
Sam Ravnborg222d3942007-10-15 21:59:31 +020033KBUILD_AFLAGS += -m32
Stephen Rothwell4a0a0882008-07-22 15:47:17 -070034CPPFLAGS_vmlinux.lds += -m32
Linus Torvalds1da177e2005-04-16 15:20:36 -070035
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".
39LDFLAGS_vmlinux = -r
40
Sam Ravnborg5e538792008-12-02 23:17:12 -080041# Default target
42all: zImage
Linus Torvalds1da177e2005-04-16 15:20:36 -070043
Sam Ravnborg5e538792008-12-02 23:17:12 -080044
45else
46#####
47# sparc64
48#
49
50CHECKFLAGS += -D__sparc__ -D__sparc_v9__ -D__arch64__ -m64
51
52# Undefine sparc when processing vmlinux.lds - it is used
53# And teach CPP we are doing 64 bit builds (for this case)
54CPPFLAGS_vmlinux.lds += -m64 -Usparc
55LDFLAGS := -m elf64_sparc
56export BITS := 64
57
58KBUILD_CFLAGS += -m64 -pipe -mno-fpu -mcpu=ultrasparc -mcmodel=medlow \
59 -ffixed-g4 -ffixed-g5 -fcall-used-g7 -Wno-sign-compare \
60 -Wa,--undeclared-regs
61KBUILD_CFLAGS += $(call cc-option,-mtune=ultrasparc3)
62KBUILD_AFLAGS += -m64 -mcpu=ultrasparc -Wa,--undeclared-regs
63
64ifeq ($(CONFIG_MCOUNT),y)
65 KBUILD_CFLAGS += -pg
66endif
67
68endif
69
Sam Ravnborga88b5ba2008-12-03 03:11:52 -080070head-y := arch/sparc/kernel/head_$(BITS).o
Sam Ravnborgb28017f2008-12-04 13:28:09 -080071head-y += arch/sparc/kernel/init_task.o
Sam Ravnborg5e538792008-12-02 23:17:12 -080072
Sam Ravnborga88b5ba2008-12-03 03:11:52 -080073core-y += arch/sparc/kernel/
Sam Ravnborg5e538792008-12-02 23:17:12 -080074core-y += arch/sparc/mm/ arch/sparc/math-emu/
75
Sam Ravnborg5de18cd2008-11-29 22:16:52 -080076libs-y += arch/sparc/prom/
Sam Ravnborg478b8fe2008-12-03 03:10:25 -080077libs-y += arch/sparc/lib/
Linus Torvalds1da177e2005-04-16 15:20:36 -070078
Martin Habets9550e592006-10-17 19:21:48 -070079drivers-$(CONFIG_OPROFILE) += arch/sparc/oprofile/
80
Linus Torvalds1da177e2005-04-16 15:20:36 -070081# Export what is needed by arch/sparc/boot/Makefile
Sam Ravnborgdb5ea212008-12-02 23:15:42 -080082export VMLINUX_INIT VMLINUX_MAIN
83VMLINUX_INIT := $(head-y) $(init-y)
84VMLINUX_MAIN := $(core-y) kernel/ mm/ fs/ ipc/ security/ crypto/ block/
85VMLINUX_MAIN += $(patsubst %/, %/lib.a, $(libs-y)) $(libs-y)
86VMLINUX_MAIN += $(drivers-y) $(net-y)
Linus Torvalds1da177e2005-04-16 15:20:36 -070087
88ifdef CONFIG_KALLSYMS
Sam Ravnborgdb5ea212008-12-02 23:15:42 -080089export kallsyms.o := .tmp_kallsyms2.o
Linus Torvalds1da177e2005-04-16 15:20:36 -070090endif
91
Sam Ravnborga8c601c2008-12-03 03:14:26 -080092boot := arch/sparc/boot
Linus Torvalds1da177e2005-04-16 15:20:36 -070093
Sam Ravnborg5e538792008-12-02 23:17:12 -080094image zImage tftpboot.img vmlinux.aout: vmlinux
Sam Ravnborga8c601c2008-12-03 03:14:26 -080095 $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@
Linus Torvalds1da177e2005-04-16 15:20:36 -070096
97archclean:
Sam Ravnborga8c601c2008-12-03 03:14:26 -080098 $(Q)$(MAKE) $(clean)=$(boot)
Linus Torvalds1da177e2005-04-16 15:20:36 -070099
Martin Habets349101d2008-08-18 22:37:18 -0700100# This is the image used for packaging
Sam Ravnborga8c601c2008-12-03 03:14:26 -0800101KBUILD_IMAGE := $(boot)/zImage
Martin Habets349101d2008-08-18 22:37:18 -0700102
Linus Torvalds1da177e2005-04-16 15:20:36 -0700103# Don't use tabs in echo arguments.
Sam Ravnborg5e538792008-12-02 23:17:12 -0800104ifeq ($(ARCH),sparc)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700105define archhelp
106 echo '* image - kernel image ($(boot)/image)'
Martin Habets349101d2008-08-18 22:37:18 -0700107 echo '* zImage - stripped kernel image ($(boot)/zImage)'
Linus Torvalds1da177e2005-04-16 15:20:36 -0700108 echo ' tftpboot.img - image prepared for tftp'
109endef
Sam Ravnborg5e538792008-12-02 23:17:12 -0800110else
111define archhelp
112 echo '* vmlinux - Standard sparc64 kernel'
113 echo ' vmlinux.aout - a.out kernel for sparc64'
114 echo ' tftpboot.img - image prepared for tftp'
115endef
116endif