Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 1 | # |
| 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 Frysinger | c71b478 | 2008-07-14 17:10:50 +0800 | [diff] [blame] | 9 | ifeq ($(CROSS_COMPILE),) |
| 10 | CROSS_COMPILE := bfin-uclinux- |
| 11 | endif |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 12 | LDFLAGS_vmlinux := -X |
| 13 | OBJCOPYFLAGS := -O binary -R .note -R .comment -S |
| 14 | GZFLAGS := -9 |
| 15 | |
Bryan Wu | 38f668e | 2007-10-22 10:46:21 +0800 | [diff] [blame] | 16 | KBUILD_CFLAGS += $(call cc-option,-mno-fdpic) |
Barry Song | d86bfb1 | 2010-01-07 04:11:17 +0000 | [diff] [blame^] | 17 | ifeq ($(CONFIG_ROMKERNEL),y) |
| 18 | KBUILD_CFLAGS += -mlong-calls |
| 19 | endif |
Bryan Wu | 38f668e | 2007-10-22 10:46:21 +0800 | [diff] [blame] | 20 | KBUILD_AFLAGS += $(call cc-option,-mno-fdpic) |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 21 | CFLAGS_MODULE += -mlong-calls |
Mike Frysinger | e92d32f | 2009-10-30 04:30:54 +0000 | [diff] [blame] | 22 | LDFLAGS_MODULE += -m elf32bfin |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 23 | KALLSYMS += --symbol-prefix=_ |
| 24 | |
Mike Frysinger | ca9cb6f | 2007-05-21 18:09:35 +0800 | [diff] [blame] | 25 | KBUILD_DEFCONFIG := BF537-STAMP_defconfig |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 26 | |
| 27 | # setup the machine name and the machine dependent settings |
Mike Frysinger | 4c4073d | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 28 | machine-$(CONFIG_BF512) := bf518 |
| 29 | machine-$(CONFIG_BF514) := bf518 |
| 30 | machine-$(CONFIG_BF516) := bf518 |
| 31 | machine-$(CONFIG_BF518) := bf518 |
| 32 | machine-$(CONFIG_BF522) := bf527 |
| 33 | machine-$(CONFIG_BF523) := bf527 |
| 34 | machine-$(CONFIG_BF524) := bf527 |
| 35 | machine-$(CONFIG_BF525) := bf527 |
| 36 | machine-$(CONFIG_BF526) := bf527 |
| 37 | machine-$(CONFIG_BF527) := bf527 |
| 38 | machine-$(CONFIG_BF531) := bf533 |
| 39 | machine-$(CONFIG_BF532) := bf533 |
| 40 | machine-$(CONFIG_BF533) := bf533 |
| 41 | machine-$(CONFIG_BF534) := bf537 |
| 42 | machine-$(CONFIG_BF536) := bf537 |
| 43 | machine-$(CONFIG_BF537) := bf537 |
| 44 | machine-$(CONFIG_BF538) := bf538 |
| 45 | machine-$(CONFIG_BF539) := bf538 |
| 46 | machine-$(CONFIG_BF542) := bf548 |
Mike Frysinger | 2f89c06 | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 47 | machine-$(CONFIG_BF542M) := bf548 |
Mike Frysinger | 4c4073d | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 48 | machine-$(CONFIG_BF544) := bf548 |
Mike Frysinger | 2f89c06 | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 49 | machine-$(CONFIG_BF544M) := bf548 |
Mike Frysinger | 4c4073d | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 50 | machine-$(CONFIG_BF547) := bf548 |
Mike Frysinger | 2f89c06 | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 51 | machine-$(CONFIG_BF547M) := bf548 |
Mike Frysinger | 4c4073d | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 52 | machine-$(CONFIG_BF548) := bf548 |
Mike Frysinger | 2f89c06 | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 53 | machine-$(CONFIG_BF548M) := bf548 |
Mike Frysinger | 4c4073d | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 54 | machine-$(CONFIG_BF549) := bf548 |
Mike Frysinger | 2f89c06 | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 55 | machine-$(CONFIG_BF549M) := bf548 |
Mike Frysinger | 4c4073d | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 56 | machine-$(CONFIG_BF561) := bf561 |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 57 | MACHINE := $(machine-y) |
| 58 | export MACHINE |
| 59 | |
Mike Frysinger | 4c4073d | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 60 | cpu-$(CONFIG_BF512) := bf512 |
| 61 | cpu-$(CONFIG_BF514) := bf514 |
| 62 | cpu-$(CONFIG_BF516) := bf516 |
| 63 | cpu-$(CONFIG_BF518) := bf518 |
| 64 | cpu-$(CONFIG_BF522) := bf522 |
| 65 | cpu-$(CONFIG_BF523) := bf523 |
| 66 | cpu-$(CONFIG_BF524) := bf524 |
| 67 | cpu-$(CONFIG_BF525) := bf525 |
| 68 | cpu-$(CONFIG_BF526) := bf526 |
| 69 | cpu-$(CONFIG_BF527) := bf527 |
| 70 | cpu-$(CONFIG_BF531) := bf531 |
| 71 | cpu-$(CONFIG_BF532) := bf532 |
| 72 | cpu-$(CONFIG_BF533) := bf533 |
| 73 | cpu-$(CONFIG_BF534) := bf534 |
| 74 | cpu-$(CONFIG_BF536) := bf536 |
| 75 | cpu-$(CONFIG_BF537) := bf537 |
| 76 | cpu-$(CONFIG_BF538) := bf538 |
| 77 | cpu-$(CONFIG_BF539) := bf539 |
| 78 | cpu-$(CONFIG_BF542) := bf542 |
Mike Frysinger | 2f89c06 | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 79 | cpu-$(CONFIG_BF542M) := bf542m |
Mike Frysinger | 4c4073d | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 80 | cpu-$(CONFIG_BF544) := bf544 |
Mike Frysinger | 2f89c06 | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 81 | cpu-$(CONFIG_BF544M) := bf544m |
Mike Frysinger | 4c4073d | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 82 | cpu-$(CONFIG_BF547) := bf547 |
Mike Frysinger | 2f89c06 | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 83 | cpu-$(CONFIG_BF547M) := bf547m |
Mike Frysinger | 4c4073d | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 84 | cpu-$(CONFIG_BF548) := bf548 |
Mike Frysinger | 2f89c06 | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 85 | cpu-$(CONFIG_BF548M) := bf548m |
Mike Frysinger | 4c4073d | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 86 | cpu-$(CONFIG_BF549) := bf549 |
Mike Frysinger | 2f89c06 | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 87 | cpu-$(CONFIG_BF549M) := bf549m |
Mike Frysinger | 4c4073d | 2009-02-04 16:49:45 +0800 | [diff] [blame] | 88 | cpu-$(CONFIG_BF561) := bf561 |
Jie Zhang | de3025f | 2007-06-25 18:04:12 +0800 | [diff] [blame] | 89 | |
| 90 | rev-$(CONFIG_BF_REV_0_0) := 0.0 |
| 91 | rev-$(CONFIG_BF_REV_0_1) := 0.1 |
| 92 | rev-$(CONFIG_BF_REV_0_2) := 0.2 |
| 93 | rev-$(CONFIG_BF_REV_0_3) := 0.3 |
| 94 | rev-$(CONFIG_BF_REV_0_4) := 0.4 |
| 95 | rev-$(CONFIG_BF_REV_0_5) := 0.5 |
Mike Frysinger | 49f7253 | 2008-10-09 12:06:27 +0800 | [diff] [blame] | 96 | rev-$(CONFIG_BF_REV_0_6) := 0.6 |
Jie Zhang | de3025f | 2007-06-25 18:04:12 +0800 | [diff] [blame] | 97 | rev-$(CONFIG_BF_REV_NONE) := none |
| 98 | rev-$(CONFIG_BF_REV_ANY) := any |
| 99 | |
Sam Ravnborg | a0f97e0 | 2007-10-14 22:21:35 +0200 | [diff] [blame] | 100 | KBUILD_CFLAGS += -mcpu=$(cpu-y)-$(rev-y) |
Sam Ravnborg | 222d394 | 2007-10-15 21:59:31 +0200 | [diff] [blame] | 101 | KBUILD_AFLAGS += -mcpu=$(cpu-y)-$(rev-y) |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 102 | |
Mike Frysinger | f692940 | 2008-03-07 02:43:48 +0800 | [diff] [blame] | 103 | # - we utilize the silicon rev from the toolchain, so move it over to the checkflags |
| 104 | # - the l1_text attribute is Blackfin specific, so fake it out as used to kill warnings |
| 105 | CHECKFLAGS_SILICON = $(shell echo "" | $(CPP) $(KBUILD_CFLAGS) -dD - 2>/dev/null | awk '$$2 == "__SILICON_REVISION__" { print $$3 }') |
| 106 | CHECKFLAGS += -D__SILICON_REVISION__=$(CHECKFLAGS_SILICON) -Dl1_text=__used__ |
| 107 | |
Michael Hennerich | 73feb5c | 2009-01-07 23:14:39 +0800 | [diff] [blame] | 108 | head-y := arch/$(ARCH)/kernel/init_task.o |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 109 | |
| 110 | core-y += arch/$(ARCH)/kernel/ arch/$(ARCH)/mm/ arch/$(ARCH)/mach-common/ |
| 111 | |
| 112 | # If we have a machine-specific directory, then include it in the build. |
| 113 | ifneq ($(machine-y),) |
| 114 | core-y += arch/$(ARCH)/mach-$(MACHINE)/ |
| 115 | core-y += arch/$(ARCH)/mach-$(MACHINE)/boards/ |
| 116 | endif |
| 117 | |
Bernd Schmidt | b97b8a9 | 2008-01-27 18:39:16 +0800 | [diff] [blame] | 118 | ifeq ($(CONFIG_MPU),y) |
| 119 | core-y += arch/$(ARCH)/kernel/cplb-mpu/ |
| 120 | else |
| 121 | core-y += arch/$(ARCH)/kernel/cplb-nompu/ |
| 122 | endif |
Bernd Schmidt | 7a1a6d0 | 2008-01-11 16:58:44 +0800 | [diff] [blame] | 123 | |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 124 | drivers-$(CONFIG_OPROFILE) += arch/$(ARCH)/oprofile/ |
| 125 | |
Graf Yang | 7be1388 | 2009-01-07 23:14:38 +0800 | [diff] [blame] | 126 | libs-y += arch/$(ARCH)/lib/ |
| 127 | |
Bryan Wu | 639f657 | 2008-08-27 10:51:02 +0800 | [diff] [blame] | 128 | machdirs := $(patsubst %,arch/blackfin/mach-%/, $(machine-y)) |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 129 | |
Bryan Wu | 639f657 | 2008-08-27 10:51:02 +0800 | [diff] [blame] | 130 | KBUILD_CFLAGS += -Iarch/$(ARCH)/include/ |
| 131 | KBUILD_CFLAGS += -Iarch/$(ARCH)/mach-$(MACHINE)/include |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 132 | |
Bryan Wu | 639f657 | 2008-08-27 10:51:02 +0800 | [diff] [blame] | 133 | KBUILD_CPPFLAGS += $(patsubst %,-I$(srctree)/%include,$(machdirs)) |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 134 | |
| 135 | CLEAN_FILES += \ |
Bryan Wu | 639f657 | 2008-08-27 10:51:02 +0800 | [diff] [blame] | 136 | arch/$(ARCH)/include/asm/asm-offsets.h \ |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 137 | arch/$(ARCH)/kernel/asm-offsets.s \ |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 138 | |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 139 | archclean: |
| 140 | $(Q)$(MAKE) $(clean)=$(boot) |
| 141 | |
Mike Frysinger | 16e6da4 | 2008-02-07 14:15:37 +0800 | [diff] [blame] | 142 | INSTALL_PATH ?= /tftpboot |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 143 | boot := arch/$(ARCH)/boot |
Barry Song | d86bfb1 | 2010-01-07 04:11:17 +0000 | [diff] [blame^] | 144 | BOOT_TARGETS = vmImage vmImage.bin vmImage.bz2 vmImage.gz vmImage.lzma vmImage.xip |
Mike Frysinger | 780431e | 2007-10-21 23:37:54 +0800 | [diff] [blame] | 145 | PHONY += $(BOOT_TARGETS) install |
| 146 | KBUILD_IMAGE := $(boot)/vmImage |
| 147 | |
| 148 | all: vmImage |
| 149 | |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 150 | $(BOOT_TARGETS): vmlinux |
| 151 | $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@ |
Mike Frysinger | 780431e | 2007-10-21 23:37:54 +0800 | [diff] [blame] | 152 | |
| 153 | install: |
| 154 | $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(KBUILD_IMAGE) install |
| 155 | |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 156 | define archhelp |
Mike Frysinger | 538067c | 2009-06-07 03:47:01 -0400 | [diff] [blame] | 157 | echo '* vmImage - Alias to selected kernel format (vmImage.gz by default)' |
Mike Frysinger | b2e8dbd | 2009-10-26 21:16:04 +0000 | [diff] [blame] | 158 | echo ' vmImage.bin - Uncompressed Kernel-only image for U-Boot (arch/$(ARCH)/boot/vmImage.bin)' |
Mike Frysinger | 538067c | 2009-06-07 03:47:01 -0400 | [diff] [blame] | 159 | echo ' vmImage.bz2 - Kernel-only image for U-Boot (arch/$(ARCH)/boot/vmImage.bz2)' |
| 160 | echo '* vmImage.gz - Kernel-only image for U-Boot (arch/$(ARCH)/boot/vmImage.gz)' |
| 161 | echo ' vmImage.lzma - Kernel-only image for U-Boot (arch/$(ARCH)/boot/vmImage.lzma)' |
Barry Song | d86bfb1 | 2010-01-07 04:11:17 +0000 | [diff] [blame^] | 162 | echo ' vmImage.xip - XIP Kernel-only image for U-Boot (arch/$(ARCH)/boot/vmImage.xip)' |
Mike Frysinger | 780431e | 2007-10-21 23:37:54 +0800 | [diff] [blame] | 163 | echo ' install - Install kernel using' |
Sam Ravnborg | caa27b6 | 2009-07-20 21:37:11 +0200 | [diff] [blame] | 164 | echo ' (your) ~/bin/$(INSTALLKERNEL) or' |
| 165 | echo ' (distribution) PATH: $(INSTALLKERNEL) or' |
Mike Frysinger | 780431e | 2007-10-21 23:37:54 +0800 | [diff] [blame] | 166 | echo ' install to $$(INSTALL_PATH)' |
Bryan Wu | 1394f03 | 2007-05-06 14:50:22 -0700 | [diff] [blame] | 167 | endef |