blob: 6f9533c3d752b6d718ad4712a8de66624ffb49ba [file] [log] [blame]
Bryan Wu1394f032007-05-06 14:50:22 -07001#
2# arch/blackfin/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
Mike Frysingerc71b4782008-07-14 17:10:50 +08009ifeq ($(CROSS_COMPILE),)
10CROSS_COMPILE := bfin-uclinux-
11endif
Bryan Wu1394f032007-05-06 14:50:22 -070012LDFLAGS_vmlinux := -X
13OBJCOPYFLAGS := -O binary -R .note -R .comment -S
14GZFLAGS := -9
15
Bryan Wu38f668e2007-10-22 10:46:21 +080016KBUILD_CFLAGS += $(call cc-option,-mno-fdpic)
17KBUILD_AFLAGS += $(call cc-option,-mno-fdpic)
Bryan Wu1394f032007-05-06 14:50:22 -070018CFLAGS_MODULE += -mlong-calls
19KALLSYMS += --symbol-prefix=_
20
Mike Frysingerca9cb6f2007-05-21 18:09:35 +080021KBUILD_DEFCONFIG := BF537-STAMP_defconfig
Bryan Wu1394f032007-05-06 14:50:22 -070022
23# setup the machine name and the machine dependent settings
Mike Frysinger4c4073d2009-02-04 16:49:45 +080024machine-$(CONFIG_BF512) := bf518
25machine-$(CONFIG_BF514) := bf518
26machine-$(CONFIG_BF516) := bf518
27machine-$(CONFIG_BF518) := bf518
28machine-$(CONFIG_BF522) := bf527
29machine-$(CONFIG_BF523) := bf527
30machine-$(CONFIG_BF524) := bf527
31machine-$(CONFIG_BF525) := bf527
32machine-$(CONFIG_BF526) := bf527
33machine-$(CONFIG_BF527) := bf527
34machine-$(CONFIG_BF531) := bf533
35machine-$(CONFIG_BF532) := bf533
36machine-$(CONFIG_BF533) := bf533
37machine-$(CONFIG_BF534) := bf537
38machine-$(CONFIG_BF536) := bf537
39machine-$(CONFIG_BF537) := bf537
40machine-$(CONFIG_BF538) := bf538
41machine-$(CONFIG_BF539) := bf538
42machine-$(CONFIG_BF542) := bf548
Mike Frysinger2f89c062009-02-04 16:49:45 +080043machine-$(CONFIG_BF542M) := bf548
Mike Frysinger4c4073d2009-02-04 16:49:45 +080044machine-$(CONFIG_BF544) := bf548
Mike Frysinger2f89c062009-02-04 16:49:45 +080045machine-$(CONFIG_BF544M) := bf548
Mike Frysinger4c4073d2009-02-04 16:49:45 +080046machine-$(CONFIG_BF547) := bf548
Mike Frysinger2f89c062009-02-04 16:49:45 +080047machine-$(CONFIG_BF547M) := bf548
Mike Frysinger4c4073d2009-02-04 16:49:45 +080048machine-$(CONFIG_BF548) := bf548
Mike Frysinger2f89c062009-02-04 16:49:45 +080049machine-$(CONFIG_BF548M) := bf548
Mike Frysinger4c4073d2009-02-04 16:49:45 +080050machine-$(CONFIG_BF549) := bf548
Mike Frysinger2f89c062009-02-04 16:49:45 +080051machine-$(CONFIG_BF549M) := bf548
Mike Frysinger4c4073d2009-02-04 16:49:45 +080052machine-$(CONFIG_BF561) := bf561
Bryan Wu1394f032007-05-06 14:50:22 -070053MACHINE := $(machine-y)
54export MACHINE
55
Mike Frysinger4c4073d2009-02-04 16:49:45 +080056cpu-$(CONFIG_BF512) := bf512
57cpu-$(CONFIG_BF514) := bf514
58cpu-$(CONFIG_BF516) := bf516
59cpu-$(CONFIG_BF518) := bf518
60cpu-$(CONFIG_BF522) := bf522
61cpu-$(CONFIG_BF523) := bf523
62cpu-$(CONFIG_BF524) := bf524
63cpu-$(CONFIG_BF525) := bf525
64cpu-$(CONFIG_BF526) := bf526
65cpu-$(CONFIG_BF527) := bf527
66cpu-$(CONFIG_BF531) := bf531
67cpu-$(CONFIG_BF532) := bf532
68cpu-$(CONFIG_BF533) := bf533
69cpu-$(CONFIG_BF534) := bf534
70cpu-$(CONFIG_BF536) := bf536
71cpu-$(CONFIG_BF537) := bf537
72cpu-$(CONFIG_BF538) := bf538
73cpu-$(CONFIG_BF539) := bf539
74cpu-$(CONFIG_BF542) := bf542
Mike Frysinger2f89c062009-02-04 16:49:45 +080075cpu-$(CONFIG_BF542M) := bf542m
Mike Frysinger4c4073d2009-02-04 16:49:45 +080076cpu-$(CONFIG_BF544) := bf544
Mike Frysinger2f89c062009-02-04 16:49:45 +080077cpu-$(CONFIG_BF544M) := bf544m
Mike Frysinger4c4073d2009-02-04 16:49:45 +080078cpu-$(CONFIG_BF547) := bf547
Mike Frysinger2f89c062009-02-04 16:49:45 +080079cpu-$(CONFIG_BF547M) := bf547m
Mike Frysinger4c4073d2009-02-04 16:49:45 +080080cpu-$(CONFIG_BF548) := bf548
Mike Frysinger2f89c062009-02-04 16:49:45 +080081cpu-$(CONFIG_BF548M) := bf548m
Mike Frysinger4c4073d2009-02-04 16:49:45 +080082cpu-$(CONFIG_BF549) := bf549
Mike Frysinger2f89c062009-02-04 16:49:45 +080083cpu-$(CONFIG_BF549M) := bf549m
Mike Frysinger4c4073d2009-02-04 16:49:45 +080084cpu-$(CONFIG_BF561) := bf561
Jie Zhangde3025f2007-06-25 18:04:12 +080085
86rev-$(CONFIG_BF_REV_0_0) := 0.0
87rev-$(CONFIG_BF_REV_0_1) := 0.1
88rev-$(CONFIG_BF_REV_0_2) := 0.2
89rev-$(CONFIG_BF_REV_0_3) := 0.3
90rev-$(CONFIG_BF_REV_0_4) := 0.4
91rev-$(CONFIG_BF_REV_0_5) := 0.5
Mike Frysinger49f72532008-10-09 12:06:27 +080092rev-$(CONFIG_BF_REV_0_6) := 0.6
Jie Zhangde3025f2007-06-25 18:04:12 +080093rev-$(CONFIG_BF_REV_NONE) := none
94rev-$(CONFIG_BF_REV_ANY) := any
95
Sam Ravnborga0f97e02007-10-14 22:21:35 +020096KBUILD_CFLAGS += -mcpu=$(cpu-y)-$(rev-y)
Sam Ravnborg222d3942007-10-15 21:59:31 +020097KBUILD_AFLAGS += -mcpu=$(cpu-y)-$(rev-y)
Bryan Wu1394f032007-05-06 14:50:22 -070098
Mike Frysingerf6929402008-03-07 02:43:48 +080099# - we utilize the silicon rev from the toolchain, so move it over to the checkflags
100# - the l1_text attribute is Blackfin specific, so fake it out as used to kill warnings
101CHECKFLAGS_SILICON = $(shell echo "" | $(CPP) $(KBUILD_CFLAGS) -dD - 2>/dev/null | awk '$$2 == "__SILICON_REVISION__" { print $$3 }')
102CHECKFLAGS += -D__SILICON_REVISION__=$(CHECKFLAGS_SILICON) -Dl1_text=__used__
103
Michael Hennerich73feb5c2009-01-07 23:14:39 +0800104head-y := arch/$(ARCH)/kernel/init_task.o
Bryan Wu1394f032007-05-06 14:50:22 -0700105
106core-y += arch/$(ARCH)/kernel/ arch/$(ARCH)/mm/ arch/$(ARCH)/mach-common/
107
108# If we have a machine-specific directory, then include it in the build.
109ifneq ($(machine-y),)
110core-y += arch/$(ARCH)/mach-$(MACHINE)/
111core-y += arch/$(ARCH)/mach-$(MACHINE)/boards/
112endif
113
Bernd Schmidtb97b8a92008-01-27 18:39:16 +0800114ifeq ($(CONFIG_MPU),y)
115core-y += arch/$(ARCH)/kernel/cplb-mpu/
116else
117core-y += arch/$(ARCH)/kernel/cplb-nompu/
118endif
Bernd Schmidt7a1a6d02008-01-11 16:58:44 +0800119
Bryan Wu1394f032007-05-06 14:50:22 -0700120drivers-$(CONFIG_OPROFILE) += arch/$(ARCH)/oprofile/
121
Graf Yang7be13882009-01-07 23:14:38 +0800122libs-y += arch/$(ARCH)/lib/
123
Bryan Wu639f6572008-08-27 10:51:02 +0800124machdirs := $(patsubst %,arch/blackfin/mach-%/, $(machine-y))
Bryan Wu1394f032007-05-06 14:50:22 -0700125
Bryan Wu639f6572008-08-27 10:51:02 +0800126KBUILD_CFLAGS += -Iarch/$(ARCH)/include/
127KBUILD_CFLAGS += -Iarch/$(ARCH)/mach-$(MACHINE)/include
Bryan Wu1394f032007-05-06 14:50:22 -0700128
Bryan Wu639f6572008-08-27 10:51:02 +0800129KBUILD_CPPFLAGS += $(patsubst %,-I$(srctree)/%include,$(machdirs))
Bryan Wu1394f032007-05-06 14:50:22 -0700130
131CLEAN_FILES += \
Bryan Wu639f6572008-08-27 10:51:02 +0800132 arch/$(ARCH)/include/asm/asm-offsets.h \
Bryan Wu1394f032007-05-06 14:50:22 -0700133 arch/$(ARCH)/kernel/asm-offsets.s \
Bryan Wu1394f032007-05-06 14:50:22 -0700134
Bryan Wu1394f032007-05-06 14:50:22 -0700135archclean:
136 $(Q)$(MAKE) $(clean)=$(boot)
137
Mike Frysinger16e6da42008-02-07 14:15:37 +0800138INSTALL_PATH ?= /tftpboot
Bryan Wu1394f032007-05-06 14:50:22 -0700139boot := arch/$(ARCH)/boot
Mike Frysinger538067c2009-06-07 03:47:01 -0400140BOOT_TARGETS = vmImage vmImage.bz2 vmImage.gz vmImage.lzma
Mike Frysinger780431e2007-10-21 23:37:54 +0800141PHONY += $(BOOT_TARGETS) install
142KBUILD_IMAGE := $(boot)/vmImage
143
144all: vmImage
145
Bryan Wu1394f032007-05-06 14:50:22 -0700146$(BOOT_TARGETS): vmlinux
147 $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@
Mike Frysinger780431e2007-10-21 23:37:54 +0800148
149install:
150 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(KBUILD_IMAGE) install
151
Bryan Wu1394f032007-05-06 14:50:22 -0700152define archhelp
Mike Frysinger538067c2009-06-07 03:47:01 -0400153 echo '* vmImage - Alias to selected kernel format (vmImage.gz by default)'
154 echo ' vmImage.bz2 - Kernel-only image for U-Boot (arch/$(ARCH)/boot/vmImage.bz2)'
155 echo '* vmImage.gz - Kernel-only image for U-Boot (arch/$(ARCH)/boot/vmImage.gz)'
156 echo ' vmImage.lzma - Kernel-only image for U-Boot (arch/$(ARCH)/boot/vmImage.lzma)'
Mike Frysinger780431e2007-10-21 23:37:54 +0800157 echo ' install - Install kernel using'
158 echo ' (your) ~/bin/$(CROSS_COMPILE)installkernel or'
159 echo ' (distribution) PATH: $(CROSS_COMPILE)installkernel or'
160 echo ' install to $$(INSTALL_PATH)'
Bryan Wu1394f032007-05-06 14:50:22 -0700161endef