X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=target%2Flinux%2Fbrcm2708%2Fimage%2FMakefile;h=85c72e27da0905fb86e382748e8787a3fe5c8dba;hb=2b1c6b21b5e6c82ebb55d7fb7df90e60e88cbb14;hp=00bee225550748da25b40c0696d45ea5f872c9c9;hpb=8ef50ec40b825a2937eb90570eccb91a2ad79b9d;p=oweals%2Fopenwrt.git diff --git a/target/linux/brcm2708/image/Makefile b/target/linux/brcm2708/image/Makefile index 00bee22555..85c72e27da 100644 --- a/target/linux/brcm2708/image/Makefile +++ b/target/linux/brcm2708/image/Makefile @@ -1,5 +1,6 @@ # # Copyright (C) 2012-2015 OpenWrt.org +# Copyright (C) 2016 LEDE project # # This is free software, licensed under the GNU General Public License v2. # See /LICENSE for more information. @@ -12,73 +13,67 @@ FAT32_BLOCK_SIZE=1024 FAT32_BLOCKS=$(shell echo $$(($(CONFIG_BRCM2708_SD_BOOT_PARTSIZE)*1024*1024/$(FAT32_BLOCK_SIZE)))) ### Image scripts ### -define Build/build-dtb - $(LINUX_DIR)/scripts/dtc/dtc -O dtb -o $@.dtb $(DTS_DIR)/$(DEVICE_DTS).dts -endef - -define Build/gen-cfg - cat config.txt > $@.config - echo -e "\ndevice_tree=$(DEVICE_DTS).dtb" >> $@.config +define Build/kernel-img + perl $(LINUX_DIR)/scripts/mkknlimg $@ $@.tmp + mv $@.tmp $@ endef define Build/boot-img rm -f $@.boot mkfs.fat -C $@.boot $(FAT32_BLOCKS) + mcopy -i $@.boot $(LINUX_DIR)/COPYING ::COPYING.linux mcopy -i $@.boot $(KDIR)/bootcode.bin :: - mcopy -i $@.boot $(KDIR)/COPYING.linux :: mcopy -i $@.boot $(KDIR)/LICENCE.broadcom :: mcopy -i $@.boot $(KDIR)/start.elf :: mcopy -i $@.boot $(KDIR)/start_cd.elf :: mcopy -i $@.boot $(KDIR)/fixup.dat :: mcopy -i $@.boot $(KDIR)/fixup_cd.dat :: mcopy -i $@.boot cmdline.txt :: - mcopy -i $@.boot $@.config ::config.txt - mcopy -i $@.boot $(word 1,$^) ::kernel.img - mcopy -i $@.boot $@.dtb ::$(DEVICE_DTS).dtb + mcopy -i $@.boot config.txt :: + mcopy -i $@.boot $(IMAGE_KERNEL) ::kernel.img + $(foreach dts,$(shell echo $(DEVICE_DTS)),mcopy -i $@.boot $(DTS_DIR)/$(dts).dtb ::;) + mmd -i $@.boot ::/overlays + mcopy -i $@.boot $(DTS_DIR)/overlays/*.dtbo ::/overlays/ + mcopy -i $@.boot $(DTS_DIR)/overlays/README ::/overlays/ endef define Build/sdcard-img - ./gen_rpi_sdcard_img.sh $@ $@.boot $(word 2,$^) \ + ./gen_rpi_sdcard_img.sh $@ $@.boot $(IMAGE_ROOTFS) \ $(CONFIG_BRCM2708_SD_BOOT_PARTSIZE) $(CONFIG_TARGET_ROOTFS_PARTSIZE) + $(if $(CONFIG_TARGET_IMAGES_GZIP),gzip -9n -c $@ > $(BIN_DIR)/$(notdir $@).gz) endef -### Device macros ### +### Devices ### define Device/Default FILESYSTEMS := ext4 - PROFILES = Default $$(DEVICE_PROFILE) - KERNEL := kernel-bin - IMAGES := sdcard.bin - IMAGE/sdcard.bin := build-dtb | gen-cfg | boot-img | sdcard-img - DEVICE_PROFILE := - DEVICE_NAME := - DEVICE_DTS := + KERNEL := kernel-bin | kernel-img + IMAGES := sdcard.img + IMAGE/sdcard.img := boot-img | sdcard-img endef -DEVICE_VARS += DEVICE_PROFILE DEVICE_NAME DEVICE_DTS -# $(1) = profile -# $(2) = image name -# $(3) = dts -define add_bcm2708 - define Device/$(2) - DEVICE_PROFILE := $(1) - DEVICE_NAME := $(2) - DEVICE_DTS := $(3) - endef - TARGET_DEVICES += $(2) +define Device/rpi + DEVICE_TITLE := Raspberry Pi B/B+/CM/Zero + DEVICE_DTS := bcm2708-rpi-b bcm2708-rpi-b-plus bcm2708-rpi-cm endef - -### BCM2708/BCM2835 ### ifeq ($(SUBTARGET),bcm2708) - # Raspberry Pi Model B - $(eval $(call add_bcm2708,RaspberryPi_B,rpi-b,bcm2708-rpi-b)) - # Raspberry Pi Model B+ - $(eval $(call add_bcm2708,RaspberryPi_BPlus,rpi-b-plus,bcm2708-rpi-b-plus)) + TARGET_DEVICES += rpi endif -### BCM2709/BCM2836 ### +define Device/rpi-2 + DEVICE_TITLE := Raspberry Pi 2 B + DEVICE_DTS := bcm2709-rpi-2-b +endef ifeq ($(SUBTARGET),bcm2709) - # Raspberry Pi 2 Model B - $(eval $(call add_bcm2708,RaspberryPi_2,rpi-2-b,bcm2709-rpi-2-b)) + TARGET_DEVICES += rpi-2 +endif + +define Device/rpi-3 + DEVICE_TITLE := Raspberry Pi 3 B/CM + DEVICE_DTS := bcm2710-rpi-3-b bcm2710-rpi-cm3 + DEVICE_PACKAGES := brcmfmac43430-firmware-sdio kmod-brcmfmac wpad-mini +endef +ifeq ($(SUBTARGET),bcm2710) + TARGET_DEVICES += rpi-3 endif $(eval $(call BuildImage))