blob: b1d691489ed4145e2cbd3e79436718bc2d73cccb [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
70head-$(CONFIG_SPARC32) := arch/sparc/kernel/head.o
71head-$(CONFIG_SPARC32) += arch/sparc/kernel/init_task.o
72head-$(CONFIG_SPARC64) := arch/sparc64/kernel/head.o
73head-$(CONFIG_SPARC64) += arch/sparc64/kernel/init_task.o
74
75core-$(CONFIG_SPARC32) += arch/sparc/kernel/
76core-$(CONFIG_SPARC64) += arch/sparc64/kernel/
77core-y += arch/sparc/mm/ arch/sparc/math-emu/
78
Sam Ravnborg5de18cd2008-11-29 22:16:52 -080079libs-y += arch/sparc/prom/
Sam Ravnborg478b8fe2008-12-03 03:10:25 -080080libs-y += arch/sparc/lib/
Linus Torvalds1da177e2005-04-16 15:20:36 -070081
Martin Habets9550e592006-10-17 19:21:48 -070082drivers-$(CONFIG_OPROFILE) += arch/sparc/oprofile/
83
Linus Torvalds1da177e2005-04-16 15:20:36 -070084# Export what is needed by arch/sparc/boot/Makefile
Sam Ravnborgdb5ea212008-12-02 23:15:42 -080085export VMLINUX_INIT VMLINUX_MAIN
86VMLINUX_INIT := $(head-y) $(init-y)
87VMLINUX_MAIN := $(core-y) kernel/ mm/ fs/ ipc/ security/ crypto/ block/
88VMLINUX_MAIN += $(patsubst %/, %/lib.a, $(libs-y)) $(libs-y)
89VMLINUX_MAIN += $(drivers-y) $(net-y)
Linus Torvalds1da177e2005-04-16 15:20:36 -070090
91ifdef CONFIG_KALLSYMS
Sam Ravnborgdb5ea212008-12-02 23:15:42 -080092export kallsyms.o := .tmp_kallsyms2.o
Linus Torvalds1da177e2005-04-16 15:20:36 -070093endif
94
Sam Ravnborg5e538792008-12-02 23:17:12 -080095boot-y := arch/sparc/boot
96boot-$(CONFIG_SPARC64) := arch/sparc64/boot
Linus Torvalds1da177e2005-04-16 15:20:36 -070097
Sam Ravnborg5e538792008-12-02 23:17:12 -080098image zImage tftpboot.img vmlinux.aout: vmlinux
99 $(Q)$(MAKE) $(build)=$(boot-y) $(boot-y)/$@
Linus Torvalds1da177e2005-04-16 15:20:36 -0700100
101archclean:
Sam Ravnborg5e538792008-12-02 23:17:12 -0800102 $(Q)$(MAKE) $(clean)=$(boot-y)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700103
Martin Habets349101d2008-08-18 22:37:18 -0700104# This is the image used for packaging
Sam Ravnborg5e538792008-12-02 23:17:12 -0800105KBUILD_IMAGE := $(boot-y)/zImage
Martin Habets349101d2008-08-18 22:37:18 -0700106
Linus Torvalds1da177e2005-04-16 15:20:36 -0700107# Don't use tabs in echo arguments.
Sam Ravnborg5e538792008-12-02 23:17:12 -0800108ifeq ($(ARCH),sparc)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700109define archhelp
110 echo '* image - kernel image ($(boot)/image)'
Martin Habets349101d2008-08-18 22:37:18 -0700111 echo '* zImage - stripped kernel image ($(boot)/zImage)'
Linus Torvalds1da177e2005-04-16 15:20:36 -0700112 echo ' tftpboot.img - image prepared for tftp'
113endef
Sam Ravnborg5e538792008-12-02 23:17:12 -0800114else
115define archhelp
116 echo '* vmlinux - Standard sparc64 kernel'
117 echo ' vmlinux.aout - a.out kernel for sparc64'
118 echo ' tftpboot.img - image prepared for tftp'
119endef
120endif