blob: d1004b4d942fce7d75daccf7d6ea641bce233f0b [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#
2# alpha/Makefile
3#
4# This file is subject to the terms and conditions of the GNU General Public
5# License. See the file "COPYING" in the main directory of this archive
6# for more details.
7#
8# Copyright (C) 1994 by Linus Torvalds
9#
10
11NM := $(NM) -B
12
13LDFLAGS_vmlinux := -static -N #-relax
14CHECKFLAGS += -D__alpha__ -m64
Adrian Bunkd9ff5f32007-10-16 01:26:33 -070015cflags-y := -pipe -mno-fp-regs -ffixed-8 -msmall-data
Linus Torvalds1da177e2005-04-16 15:20:36 -070016
Adrian Bunkd9ff5f32007-10-16 01:26:33 -070017cpuflags-$(CONFIG_ALPHA_EV67) := -mcpu=ev67
18cpuflags-$(CONFIG_ALPHA_EV6) := -mcpu=ev6
19cpuflags-$(CONFIG_ALPHA_POLARIS) := -mcpu=pca56
20cpuflags-$(CONFIG_ALPHA_SX164) := -mcpu=pca56
21cpuflags-$(CONFIG_ALPHA_EV56) := -mcpu=ev56
22cpuflags-$(CONFIG_ALPHA_EV5) := -mcpu=ev5
23cpuflags-$(CONFIG_ALPHA_EV4) := -mcpu=ev4
24# If GENERIC, make sure to turn off any instruction set extensions that
25# the host compiler might have on by default. Given that EV4 and EV5
26# have the same instruction set, prefer EV5 because an EV5 schedule is
27# more likely to keep an EV4 processor busy than vice-versa.
28cpuflags-$(CONFIG_ALPHA_GENERIC) := -mcpu=ev5
Linus Torvalds1da177e2005-04-16 15:20:36 -070029
Adrian Bunkd9ff5f32007-10-16 01:26:33 -070030cflags-y += $(cpuflags-y)
Linus Torvalds1da177e2005-04-16 15:20:36 -070031
32
33# For TSUNAMI, we must have the assembler not emulate our instructions.
34# The same is true for IRONGATE, POLARIS, PYXIS.
35# BWX is most important, but we don't really want any emulation ever.
36CFLAGS += $(cflags-y) -Wa,-mev6
37
38head-y := arch/alpha/kernel/head.o
39
40core-y += arch/alpha/kernel/ arch/alpha/mm/
41core-$(CONFIG_MATHEMU) += arch/alpha/math-emu/
42drivers-$(CONFIG_OPROFILE) += arch/alpha/oprofile/
43libs-y += arch/alpha/lib/
44
45# export what is needed by arch/alpha/boot/Makefile
46LIBS_Y := $(patsubst %/, %/lib.a, $(libs-y))
47export LIBS_Y
48
49boot := arch/alpha/boot
50
51#Default target when executing make with no arguments
52all boot: $(boot)/vmlinux.gz
53
54$(boot)/vmlinux.gz: vmlinux
55 $(Q)$(MAKE) $(build)=$(boot) $@
56
57bootimage bootpfile bootpzfile: vmlinux
58 $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@
59
Linus Torvalds1da177e2005-04-16 15:20:36 -070060archclean:
61 $(Q)$(MAKE) $(clean)=$(boot)
62
Linus Torvalds1da177e2005-04-16 15:20:36 -070063define archhelp
64 echo '* boot - Compressed kernel image (arch/alpha/boot/vmlinux.gz)'
65 echo ' bootimage - SRM bootable image (arch/alpha/boot/bootimage)'
66 echo ' bootpfile - BOOTP bootable image (arch/alpha/boot/bootpfile)'
67 echo ' bootpzfile - compressed kernel BOOTP image (arch/alpha/boot/bootpzfile)'
68endef