blob: 881cb913e23abbc416ffdee4e744334d0d989955 [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
Luc Van Oostenryck1f2f01b2018-05-30 22:48:38 +020014CHECKFLAGS += -D__alpha__
Will Deaconcd8d2332013-04-07 21:36:10 +120015cflags-y := -pipe -mno-fp-regs -ffixed-8
Ivan Kokshayskyede42692008-06-21 03:26:21 +040016cflags-y += $(call cc-option, -fno-jump-tables)
Linus Torvalds1da177e2005-04-16 15:20:36 -070017
Ivan Kokshaysky9548b202007-12-17 16:19:57 -080018cpuflags-$(CONFIG_ALPHA_EV4) := -mcpu=ev4
19cpuflags-$(CONFIG_ALPHA_EV5) := -mcpu=ev5
20cpuflags-$(CONFIG_ALPHA_EV56) := -mcpu=ev56
Adrian Bunkd9ff5f32007-10-16 01:26:33 -070021cpuflags-$(CONFIG_ALPHA_POLARIS) := -mcpu=pca56
22cpuflags-$(CONFIG_ALPHA_SX164) := -mcpu=pca56
Ivan Kokshaysky9548b202007-12-17 16:19:57 -080023cpuflags-$(CONFIG_ALPHA_EV6) := -mcpu=ev6
24cpuflags-$(CONFIG_ALPHA_EV67) := -mcpu=ev67
Adrian Bunkd9ff5f32007-10-16 01:26:33 -070025# If GENERIC, make sure to turn off any instruction set extensions that
26# the host compiler might have on by default. Given that EV4 and EV5
27# have the same instruction set, prefer EV5 because an EV5 schedule is
28# more likely to keep an EV4 processor busy than vice-versa.
29cpuflags-$(CONFIG_ALPHA_GENERIC) := -mcpu=ev5
Linus Torvalds1da177e2005-04-16 15:20:36 -070030
Adrian Bunkd9ff5f32007-10-16 01:26:33 -070031cflags-y += $(cpuflags-y)
Linus Torvalds1da177e2005-04-16 15:20:36 -070032
33
34# For TSUNAMI, we must have the assembler not emulate our instructions.
35# The same is true for IRONGATE, POLARIS, PYXIS.
36# BWX is most important, but we don't really want any emulation ever.
Sam Ravnborga0f97e02007-10-14 22:21:35 +020037KBUILD_CFLAGS += $(cflags-y) -Wa,-mev6
Linus Torvalds1da177e2005-04-16 15:20:36 -070038
39head-y := arch/alpha/kernel/head.o
40
Linus Torvalds1da177e2005-04-16 15:20:36 -070041libs-y += arch/alpha/lib/
42
43# export what is needed by arch/alpha/boot/Makefile
44LIBS_Y := $(patsubst %/, %/lib.a, $(libs-y))
45export LIBS_Y
46
47boot := arch/alpha/boot
48
49#Default target when executing make with no arguments
50all boot: $(boot)/vmlinux.gz
51
52$(boot)/vmlinux.gz: vmlinux
53 $(Q)$(MAKE) $(build)=$(boot) $@
54
55bootimage bootpfile bootpzfile: vmlinux
56 $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@
57
Firoz Khana8faab52018-11-13 15:01:53 +053058archheaders:
59 $(Q)$(MAKE) $(build)=arch/alpha/kernel/syscalls all
60
Linus Torvalds1da177e2005-04-16 15:20:36 -070061define archhelp
62 echo '* boot - Compressed kernel image (arch/alpha/boot/vmlinux.gz)'
63 echo ' bootimage - SRM bootable image (arch/alpha/boot/bootimage)'
64 echo ' bootpfile - BOOTP bootable image (arch/alpha/boot/bootpfile)'
65 echo ' bootpzfile - compressed kernel BOOTP image (arch/alpha/boot/bootpzfile)'
66endef