blob: 3cbe16caad4b98c8e0b2f376c4e954fe4903cc29 [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
9
10CROSS_COMPILE ?= bfin-uclinux-
11LDFLAGS_vmlinux := -X
12OBJCOPYFLAGS := -O binary -R .note -R .comment -S
13GZFLAGS := -9
14
Bryan Wu38f668e2007-10-22 10:46:21 +080015KBUILD_CFLAGS += $(call cc-option,-mno-fdpic)
16KBUILD_AFLAGS += $(call cc-option,-mno-fdpic)
Bryan Wu1394f032007-05-06 14:50:22 -070017CFLAGS_MODULE += -mlong-calls
18KALLSYMS += --symbol-prefix=_
19
Mike Frysingerca9cb6f2007-05-21 18:09:35 +080020KBUILD_DEFCONFIG := BF537-STAMP_defconfig
Bryan Wu1394f032007-05-06 14:50:22 -070021
22# setup the machine name and the machine dependent settings
Michael Hennerich59003142007-10-21 16:54:27 +080023machine-$(CONFIG_BF522) := bf527
Mike Frysinger1545a112007-12-24 16:54:48 +080024machine-$(CONFIG_BF523) := bf527
25machine-$(CONFIG_BF524) := bf527
Michael Hennerich59003142007-10-21 16:54:27 +080026machine-$(CONFIG_BF525) := bf527
Mike Frysinger1545a112007-12-24 16:54:48 +080027machine-$(CONFIG_BF526) := bf527
Michael Hennerich59003142007-10-21 16:54:27 +080028machine-$(CONFIG_BF527) := bf527
Bryan Wu1394f032007-05-06 14:50:22 -070029machine-$(CONFIG_BF531) := bf533
30machine-$(CONFIG_BF532) := bf533
31machine-$(CONFIG_BF533) := bf533
32machine-$(CONFIG_BF534) := bf537
33machine-$(CONFIG_BF536) := bf537
34machine-$(CONFIG_BF537) := bf537
Mike Frysingere2dd3f12007-07-24 18:20:18 +080035machine-$(CONFIG_BF542) := bf548
36machine-$(CONFIG_BF544) := bf548
Mike Frysinger7c7fd172007-11-15 21:10:21 +080037machine-$(CONFIG_BF547) := bf548
Roy Huang24a07a12007-07-12 22:41:45 +080038machine-$(CONFIG_BF548) := bf548
39machine-$(CONFIG_BF549) := bf548
Bryan Wu1394f032007-05-06 14:50:22 -070040machine-$(CONFIG_BF561) := bf561
41MACHINE := $(machine-y)
42export MACHINE
43
Michael Hennerich59003142007-10-21 16:54:27 +080044cpu-$(CONFIG_BF522) := bf522
Mike Frysinger1545a112007-12-24 16:54:48 +080045cpu-$(CONFIG_BF523) := bf523
46cpu-$(CONFIG_BF524) := bf524
Michael Hennerich59003142007-10-21 16:54:27 +080047cpu-$(CONFIG_BF525) := bf525
Mike Frysinger1545a112007-12-24 16:54:48 +080048cpu-$(CONFIG_BF526) := bf526
Michael Hennerich59003142007-10-21 16:54:27 +080049cpu-$(CONFIG_BF527) := bf527
Jie Zhangde3025f2007-06-25 18:04:12 +080050cpu-$(CONFIG_BF531) := bf531
51cpu-$(CONFIG_BF532) := bf532
52cpu-$(CONFIG_BF533) := bf533
53cpu-$(CONFIG_BF534) := bf534
54cpu-$(CONFIG_BF536) := bf536
55cpu-$(CONFIG_BF537) := bf537
Mike Frysingere2dd3f12007-07-24 18:20:18 +080056cpu-$(CONFIG_BF542) := bf542
57cpu-$(CONFIG_BF544) := bf544
Mike Frysinger7c7fd172007-11-15 21:10:21 +080058cpu-$(CONFIG_BF547) := bf547
Jie Zhangde3025f2007-06-25 18:04:12 +080059cpu-$(CONFIG_BF548) := bf548
60cpu-$(CONFIG_BF549) := bf549
61cpu-$(CONFIG_BF561) := bf561
62
63rev-$(CONFIG_BF_REV_0_0) := 0.0
64rev-$(CONFIG_BF_REV_0_1) := 0.1
65rev-$(CONFIG_BF_REV_0_2) := 0.2
66rev-$(CONFIG_BF_REV_0_3) := 0.3
67rev-$(CONFIG_BF_REV_0_4) := 0.4
68rev-$(CONFIG_BF_REV_0_5) := 0.5
69rev-$(CONFIG_BF_REV_NONE) := none
70rev-$(CONFIG_BF_REV_ANY) := any
71
Sam Ravnborga0f97e02007-10-14 22:21:35 +020072KBUILD_CFLAGS += -mcpu=$(cpu-y)-$(rev-y)
Sam Ravnborg222d3942007-10-15 21:59:31 +020073KBUILD_AFLAGS += -mcpu=$(cpu-y)-$(rev-y)
Bryan Wu1394f032007-05-06 14:50:22 -070074
Mike Frysingerf6929402008-03-07 02:43:48 +080075# - we utilize the silicon rev from the toolchain, so move it over to the checkflags
76# - the l1_text attribute is Blackfin specific, so fake it out as used to kill warnings
77CHECKFLAGS_SILICON = $(shell echo "" | $(CPP) $(KBUILD_CFLAGS) -dD - 2>/dev/null | awk '$$2 == "__SILICON_REVISION__" { print $$3 }')
78CHECKFLAGS += -D__SILICON_REVISION__=$(CHECKFLAGS_SILICON) -Dl1_text=__used__
79
Bryan Wu1394f032007-05-06 14:50:22 -070080head-y := arch/$(ARCH)/mach-$(MACHINE)/head.o arch/$(ARCH)/kernel/init_task.o
81
82core-y += arch/$(ARCH)/kernel/ arch/$(ARCH)/mm/ arch/$(ARCH)/mach-common/
83
84# If we have a machine-specific directory, then include it in the build.
85ifneq ($(machine-y),)
86core-y += arch/$(ARCH)/mach-$(MACHINE)/
87core-y += arch/$(ARCH)/mach-$(MACHINE)/boards/
88endif
89
Bernd Schmidtb97b8a92008-01-27 18:39:16 +080090ifeq ($(CONFIG_MPU),y)
91core-y += arch/$(ARCH)/kernel/cplb-mpu/
92else
93core-y += arch/$(ARCH)/kernel/cplb-nompu/
94endif
Bernd Schmidt7a1a6d02008-01-11 16:58:44 +080095
Bryan Wu1394f032007-05-06 14:50:22 -070096libs-y += arch/$(ARCH)/lib/
97
98drivers-$(CONFIG_OPROFILE) += arch/$(ARCH)/oprofile/
99
100
101
102# Update machine arch symlinks if something which affects
103# them changed. We use .mach to indicate when they were updated
104# last, otherwise make uses the target directory mtime.
105
Mike Frysingerc63d4e62008-02-22 16:12:01 +0800106 show_mach_symlink = :
Mike Frysinger4d94bf62008-02-22 16:03:54 +0800107 quiet_show_mach_symlink = echo ' SYMLINK include/asm-$(ARCH)/mach-$(MACHINE) -> include/asm-$(ARCH)/mach'
108silent_show_mach_symlink = :
Bryan Wu1394f032007-05-06 14:50:22 -0700109include/asm-blackfin/.mach: $(wildcard include/config/arch/*.h) include/config/auto.conf
Mike Frysinger4d94bf62008-02-22 16:03:54 +0800110 @$($(quiet)show_mach_symlink)
Bryan Wu1394f032007-05-06 14:50:22 -0700111ifneq ($(KBUILD_SRC),)
112 $(Q)mkdir -p include/asm-$(ARCH)
113 $(Q)ln -fsn $(srctree)/include/asm-$(ARCH)/mach-$(MACHINE) include/asm-$(ARCH)/mach
114else
115 $(Q)ln -fsn mach-$(MACHINE) include/asm-$(ARCH)/mach
116endif
117 @touch $@
118
119CLEAN_FILES += \
120 include/asm-$(ARCH)/asm-offsets.h \
121 arch/$(ARCH)/kernel/asm-offsets.s \
122 include/asm-$(ARCH)/mach \
123 include/asm-$(ARCH)/.mach
124
125archprepare: include/asm-blackfin/.mach
126archclean:
127 $(Q)$(MAKE) $(clean)=$(boot)
128
129
Mike Frysinger16e6da42008-02-07 14:15:37 +0800130INSTALL_PATH ?= /tftpboot
Bryan Wu1394f032007-05-06 14:50:22 -0700131boot := arch/$(ARCH)/boot
132BOOT_TARGETS = vmImage
Mike Frysinger780431e2007-10-21 23:37:54 +0800133PHONY += $(BOOT_TARGETS) install
134KBUILD_IMAGE := $(boot)/vmImage
135
136all: vmImage
137
Bryan Wu1394f032007-05-06 14:50:22 -0700138$(BOOT_TARGETS): vmlinux
139 $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@
Mike Frysinger780431e2007-10-21 23:37:54 +0800140
141install:
142 $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(KBUILD_IMAGE) install
143
Bryan Wu1394f032007-05-06 14:50:22 -0700144define archhelp
145 echo '* vmImage - Kernel-only image for U-Boot (arch/$(ARCH)/boot/vmImage)'
Mike Frysinger780431e2007-10-21 23:37:54 +0800146 echo ' install - Install kernel using'
147 echo ' (your) ~/bin/$(CROSS_COMPILE)installkernel or'
148 echo ' (distribution) PATH: $(CROSS_COMPILE)installkernel or'
149 echo ' install to $$(INSTALL_PATH)'
Bryan Wu1394f032007-05-06 14:50:22 -0700150endef