Kyle Swenson | 8d8f654 | 2021-03-15 11:02:55 -0600 | [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 | |
| 9 | ifeq ($(CROSS_COMPILE),) |
| 10 | CROSS_COMPILE := bfin-uclinux- |
| 11 | endif |
| 12 | LDFLAGS_vmlinux := -X |
| 13 | OBJCOPYFLAGS := -O binary -R .note -R .comment -S |
| 14 | GZFLAGS := -9 |
| 15 | |
| 16 | KBUILD_CFLAGS += $(call cc-option,-mno-fdpic) |
| 17 | ifeq ($(CONFIG_ROMKERNEL),y) |
| 18 | KBUILD_CFLAGS += -mlong-calls |
| 19 | endif |
| 20 | KBUILD_AFLAGS += $(call cc-option,-mno-fdpic) |
| 21 | KBUILD_CFLAGS_MODULE += -mlong-calls |
| 22 | LDFLAGS += -m elf32bfin |
| 23 | |
| 24 | KBUILD_DEFCONFIG := BF537-STAMP_defconfig |
| 25 | |
| 26 | # setup the machine name and the machine dependent settings |
| 27 | machine-$(CONFIG_BF512) := bf518 |
| 28 | machine-$(CONFIG_BF514) := bf518 |
| 29 | machine-$(CONFIG_BF516) := bf518 |
| 30 | machine-$(CONFIG_BF518) := bf518 |
| 31 | machine-$(CONFIG_BF522) := bf527 |
| 32 | machine-$(CONFIG_BF523) := bf527 |
| 33 | machine-$(CONFIG_BF524) := bf527 |
| 34 | machine-$(CONFIG_BF525) := bf527 |
| 35 | machine-$(CONFIG_BF526) := bf527 |
| 36 | machine-$(CONFIG_BF527) := bf527 |
| 37 | machine-$(CONFIG_BF531) := bf533 |
| 38 | machine-$(CONFIG_BF532) := bf533 |
| 39 | machine-$(CONFIG_BF533) := bf533 |
| 40 | machine-$(CONFIG_BF534) := bf537 |
| 41 | machine-$(CONFIG_BF536) := bf537 |
| 42 | machine-$(CONFIG_BF537) := bf537 |
| 43 | machine-$(CONFIG_BF538) := bf538 |
| 44 | machine-$(CONFIG_BF539) := bf538 |
| 45 | machine-$(CONFIG_BF542) := bf548 |
| 46 | machine-$(CONFIG_BF542M) := bf548 |
| 47 | machine-$(CONFIG_BF544) := bf548 |
| 48 | machine-$(CONFIG_BF544M) := bf548 |
| 49 | machine-$(CONFIG_BF547) := bf548 |
| 50 | machine-$(CONFIG_BF547M) := bf548 |
| 51 | machine-$(CONFIG_BF548) := bf548 |
| 52 | machine-$(CONFIG_BF548M) := bf548 |
| 53 | machine-$(CONFIG_BF549) := bf548 |
| 54 | machine-$(CONFIG_BF549M) := bf548 |
| 55 | machine-$(CONFIG_BF561) := bf561 |
| 56 | machine-$(CONFIG_BF609) := bf609 |
| 57 | MACHINE := $(machine-y) |
| 58 | export MACHINE |
| 59 | |
| 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 |
| 79 | cpu-$(CONFIG_BF542M) := bf542m |
| 80 | cpu-$(CONFIG_BF544) := bf544 |
| 81 | cpu-$(CONFIG_BF544M) := bf544m |
| 82 | cpu-$(CONFIG_BF547) := bf547 |
| 83 | cpu-$(CONFIG_BF547M) := bf547m |
| 84 | cpu-$(CONFIG_BF548) := bf548 |
| 85 | cpu-$(CONFIG_BF548M) := bf548m |
| 86 | cpu-$(CONFIG_BF549) := bf549 |
| 87 | cpu-$(CONFIG_BF549M) := bf549m |
| 88 | cpu-$(CONFIG_BF561) := bf561 |
| 89 | cpu-$(CONFIG_BF609) := bf609 |
| 90 | |
| 91 | rev-$(CONFIG_BF_REV_0_0) := 0.0 |
| 92 | rev-$(CONFIG_BF_REV_0_1) := 0.1 |
| 93 | rev-$(CONFIG_BF_REV_0_2) := 0.2 |
| 94 | rev-$(CONFIG_BF_REV_0_3) := 0.3 |
| 95 | rev-$(CONFIG_BF_REV_0_4) := 0.4 |
| 96 | rev-$(CONFIG_BF_REV_0_5) := 0.5 |
| 97 | rev-$(CONFIG_BF_REV_0_6) := 0.6 |
| 98 | rev-$(CONFIG_BF_REV_NONE) := none |
| 99 | rev-$(CONFIG_BF_REV_ANY) := any |
| 100 | |
| 101 | CPU_REV := $(cpu-y)-$(rev-y) |
| 102 | export CPU_REV |
| 103 | |
| 104 | KBUILD_CFLAGS += -mcpu=$(CPU_REV) |
| 105 | KBUILD_AFLAGS += -mcpu=$(CPU_REV) |
| 106 | |
| 107 | # - we utilize the silicon rev from the toolchain, so move it over to the checkflags |
| 108 | CHECKFLAGS_SILICON = $(shell echo "" | $(CPP) $(KBUILD_CFLAGS) -dD - 2>/dev/null | awk '$$2 == "__SILICON_REVISION__" { print $$3 }') |
| 109 | CHECKFLAGS += -D__SILICON_REVISION__=$(CHECKFLAGS_SILICON) -D__bfin__ |
| 110 | |
| 111 | core-y += arch/$(ARCH)/kernel/ arch/$(ARCH)/mm/ arch/$(ARCH)/mach-common/ |
| 112 | |
| 113 | # If we have a machine-specific directory, then include it in the build. |
| 114 | ifneq ($(machine-y),) |
| 115 | core-y += arch/$(ARCH)/mach-$(MACHINE)/ |
| 116 | core-y += arch/$(ARCH)/mach-$(MACHINE)/boards/ |
| 117 | endif |
| 118 | |
| 119 | ifeq ($(CONFIG_MPU),y) |
| 120 | core-y += arch/$(ARCH)/kernel/cplb-mpu/ |
| 121 | else |
| 122 | core-y += arch/$(ARCH)/kernel/cplb-nompu/ |
| 123 | endif |
| 124 | |
| 125 | drivers-$(CONFIG_OPROFILE) += arch/$(ARCH)/oprofile/ |
| 126 | |
| 127 | libs-y += arch/$(ARCH)/lib/ |
| 128 | |
| 129 | machdirs := $(patsubst %,arch/blackfin/mach-%/, $(machine-y)) |
| 130 | |
| 131 | KBUILD_CFLAGS += -Iarch/$(ARCH)/include/ |
| 132 | KBUILD_CFLAGS += -Iarch/$(ARCH)/mach-$(MACHINE)/include |
| 133 | |
| 134 | KBUILD_CPPFLAGS += $(patsubst %,-I$(srctree)/%include,$(machdirs)) |
| 135 | |
| 136 | CLEAN_FILES += \ |
| 137 | arch/$(ARCH)/kernel/asm-offsets.s \ |
| 138 | |
| 139 | archclean: |
| 140 | $(Q)$(MAKE) $(clean)=$(boot) |
| 141 | |
| 142 | INSTALL_PATH ?= /tftpboot |
| 143 | boot := arch/$(ARCH)/boot |
| 144 | BOOT_TARGETS = uImage uImage.bin uImage.bz2 uImage.gz uImage.lzma uImage.lzo uImage.xip |
| 145 | PHONY += $(BOOT_TARGETS) install |
| 146 | KBUILD_IMAGE := $(boot)/uImage |
| 147 | |
| 148 | all: uImage |
| 149 | |
| 150 | $(BOOT_TARGETS): vmlinux |
| 151 | $(Q)$(MAKE) $(build)=$(boot) $(boot)/$@ |
| 152 | |
| 153 | install: |
| 154 | $(Q)$(MAKE) $(build)=$(boot) BOOTIMAGE=$(KBUILD_IMAGE) install |
| 155 | |
| 156 | define archhelp |
| 157 | echo '* vmImage - Alias to selected kernel format (vmImage.gz by default)' |
| 158 | echo ' vmImage.bin - Uncompressed Kernel-only image for U-Boot (arch/$(ARCH)/boot/vmImage.bin)' |
| 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)' |
| 162 | echo ' vmImage.lzo - Kernel-only image for U-Boot (arch/$(ARCH)/boot/vmImage.lzo)' |
| 163 | echo ' vmImage.xip - XIP Kernel-only image for U-Boot (arch/$(ARCH)/boot/vmImage.xip)' |
| 164 | echo ' install - Install kernel using' |
| 165 | echo ' (your) ~/bin/$(INSTALLKERNEL) or' |
| 166 | echo ' (distribution) PATH: $(INSTALLKERNEL) or' |
| 167 | echo ' install to $$(INSTALL_PATH)' |
| 168 | endef |