blob: b7f2e2d5cd2e5d05ffd80c59c1e5bb5cb0777ae4 [file] [log] [blame]
Greg Ungerer281eff52011-06-21 14:03:30 +10001#
2# m68k/Makefile
3#
4# This file is included by the global makefile so that you can add your own
5# architecture-specific flags and dependencies. Remember to do have actions
6# for "archclean" and "archdep" for cleaning up and making dependencies for
7# this architecture
8#
9# This file is subject to the terms and conditions of the GNU General Public
10# License. See the file "COPYING" in the main directory of this archive
11# for more details.
12#
13# Copyright (C) 1994 by Hamish Macdonald
14# Copyright (C) 2002,2011 Greg Ungerer <gerg@snapgear.com>
15#
16
Adrian Bunkb7399122008-07-17 21:16:14 +020017KBUILD_DEFCONFIG := multi_defconfig
Adrian Bunkef85ecbf2008-04-04 14:57:38 +020018
Geert Uytterhoevenf25e9182012-05-12 22:14:36 +020019ifneq ($(SUBARCH),$(ARCH))
20 ifeq ($(CROSS_COMPILE),)
21 CROSS_COMPILE := $(call cc-cross-prefix, \
22 m68k-linux-gnu- m68k-linux- m68k-unknown-linux-gnu-)
23 endif
24endif
25
Greg Ungerer281eff52011-06-21 14:03:30 +100026#
27# Enable processor type. Ordering of these is important - we want to
28# use the minimum processor type of the range we support. The logic
29# for 680x0 will only allow use of the -m68060 or -m68040 if no other
30# 680x0 type is specified - and no option is specified for 68030 or
31# 68020. The other m68k/ColdFire types always specify some type of
32# compiler cpu type flag.
33#
34ifndef CONFIG_M68040
35cpuflags-$(CONFIG_M68060) := -m68060
Linus Torvalds1da177e2005-04-16 15:20:36 -070036endif
Greg Ungerer281eff52011-06-21 14:03:30 +100037ifndef CONFIG_M68060
38cpuflags-$(CONFIG_M68040) := -m68040
39endif
40cpuflags-$(CONFIG_M68030) :=
41cpuflags-$(CONFIG_M68020) :=
42cpuflags-$(CONFIG_M68360) := -m68332
43cpuflags-$(CONFIG_M68000) := -m68000
44cpuflags-$(CONFIG_M54xx) := $(call cc-option,-mcpu=5475,-m5200)
45cpuflags-$(CONFIG_M5407) := $(call cc-option,-mcpu=5407,-m5200)
46cpuflags-$(CONFIG_M532x) := $(call cc-option,-mcpu=532x,-m5307)
47cpuflags-$(CONFIG_M5307) := $(call cc-option,-mcpu=5307,-m5200)
48cpuflags-$(CONFIG_M528x) := $(call cc-option,-mcpu=528x,-m5307)
49cpuflags-$(CONFIG_M5275) := $(call cc-option,-mcpu=5275,-m5307)
50cpuflags-$(CONFIG_M5272) := $(call cc-option,-mcpu=5272,-m5307)
51cpuflags-$(CONFIG_M5271) := $(call cc-option,-mcpu=5271,-m5307)
52cpuflags-$(CONFIG_M523x) := $(call cc-option,-mcpu=523x,-m5307)
53cpuflags-$(CONFIG_M5249) := $(call cc-option,-mcpu=5249,-m5200)
54cpuflags-$(CONFIG_M520x) := $(call cc-option,-mcpu=5208,-m5200)
55cpuflags-$(CONFIG_M5206e) := $(call cc-option,-mcpu=5206e,-m5200)
56cpuflags-$(CONFIG_M5206) := $(call cc-option,-mcpu=5206,-m5200)
57
58KBUILD_AFLAGS += $(cpuflags-y)
59KBUILD_CFLAGS += $(cpuflags-y) -pipe
60ifdef CONFIG_MMU
61# without -fno-strength-reduce the 53c7xx.c driver fails ;-(
62KBUILD_CFLAGS += -fno-strength-reduce -ffixed-a2
63else
64# we can use a m68k-linux-gcc toolchain with these in place
65KBUILD_CFLAGS += -DUTS_SYSNAME=\"uClinux\"
66KBUILD_CFLAGS += -D__uClinux__
67KBUILD_AFLAGS += -D__uClinux__
68endif
69
70LDFLAGS := -m m68kelf
71KBUILD_LDFLAGS_MODULE += -T $(srctree)/arch/m68k/kernel/module.lds
Greg Ungerer281eff52011-06-21 14:03:30 +100072
73ifdef CONFIG_SUN3
74LDFLAGS_vmlinux = -N
75endif
76
77CHECKFLAGS += -D__mc68000__
78
79
80ifdef CONFIG_KGDB
81# If configured for kgdb support, include debugging infos and keep the
82# frame pointer
83KBUILD_CFLAGS := $(subst -fomit-frame-pointer,,$(KBUILD_CFLAGS)) -g
84endif
85
86#
87# Select the assembler head startup code. Order is important. The default
88# head code is first, processor specific selections can override it after.
89#
90head-y := arch/m68k/kernel/head.o
91head-$(CONFIG_SUN3) := arch/m68k/kernel/sun3-head.o
92head-$(CONFIG_M68360) := arch/m68k/platform/68360/head.o
93head-$(CONFIG_M68000) := arch/m68k/platform/68328/head.o
94head-$(CONFIG_COLDFIRE) := arch/m68k/platform/coldfire/head.o
95
96core-y += arch/m68k/kernel/ arch/m68k/mm/
97libs-y += arch/m68k/lib/
98
99core-$(CONFIG_Q40) += arch/m68k/q40/
100core-$(CONFIG_AMIGA) += arch/m68k/amiga/
101core-$(CONFIG_ATARI) += arch/m68k/atari/
102core-$(CONFIG_MAC) += arch/m68k/mac/
103core-$(CONFIG_HP300) += arch/m68k/hp300/
104core-$(CONFIG_APOLLO) += arch/m68k/apollo/
105core-$(CONFIG_MVME147) += arch/m68k/mvme147/
106core-$(CONFIG_MVME16x) += arch/m68k/mvme16x/
107core-$(CONFIG_BVME6000) += arch/m68k/bvme6000/
108core-$(CONFIG_SUN3X) += arch/m68k/sun3x/ arch/m68k/sun3/
109core-$(CONFIG_SUN3) += arch/m68k/sun3/ arch/m68k/sun3/prom/
110core-$(CONFIG_NATFEAT) += arch/m68k/emu/
111core-$(CONFIG_M68040) += arch/m68k/fpsp040/
112core-$(CONFIG_M68060) += arch/m68k/ifpsp060/
113core-$(CONFIG_M68KFPU_EMU) += arch/m68k/math-emu/
114core-$(CONFIG_M68360) += arch/m68k/platform/68360/
115core-$(CONFIG_M68000) += arch/m68k/platform/68328/
116core-$(CONFIG_M68EZ328) += arch/m68k/platform/68EZ328/
117core-$(CONFIG_M68VZ328) += arch/m68k/platform/68VZ328/
118core-$(CONFIG_COLDFIRE) += arch/m68k/platform/coldfire/
Greg Ungerer281eff52011-06-21 14:03:30 +1000119
120
121all: zImage
122
123lilo: vmlinux
124 if [ -f $(INSTALL_PATH)/vmlinux ]; then mv -f $(INSTALL_PATH)/vmlinux $(INSTALL_PATH)/vmlinux.old; fi
125 if [ -f $(INSTALL_PATH)/System.map ]; then mv -f $(INSTALL_PATH)/System.map $(INSTALL_PATH)/System.old; fi
126 cat vmlinux > $(INSTALL_PATH)/vmlinux
127 cp System.map $(INSTALL_PATH)/System.map
128 if [ -x /sbin/lilo ]; then /sbin/lilo; else /etc/lilo/install; fi
129
130zImage compressed: vmlinux.gz
131
132vmlinux.gz: vmlinux
133
134ifndef CONFIG_KGDB
135 cp vmlinux vmlinux.tmp
136 $(STRIP) vmlinux.tmp
137 gzip -9c vmlinux.tmp >vmlinux.gz
138 rm vmlinux.tmp
139else
140 gzip -9c vmlinux >vmlinux.gz
141endif
142
143bzImage: vmlinux.bz2
144
145vmlinux.bz2: vmlinux
146
147ifndef CONFIG_KGDB
148 cp vmlinux vmlinux.tmp
149 $(STRIP) vmlinux.tmp
150 bzip2 -1c vmlinux.tmp >vmlinux.bz2
151 rm vmlinux.tmp
152else
153 bzip2 -1c vmlinux >vmlinux.bz2
154endif
155
156archclean:
157 rm -f vmlinux.gz vmlinux.bz2
158
159install:
160 sh $(srctree)/arch/m68k/install.sh $(KERNELRELEASE) vmlinux.gz System.map "$(INSTALL_PATH)"