X-Git-Url: http://git.openwrt.org/?a=blobdiff_plain;f=target%2Flinux%2Fkirkwood%2Fimage%2FMakefile;h=1fb482f1e757ad8d7cf47f046ed675d5390c188b;hb=b9a55277d590410ee69cc3f8fda029c60977a029;hp=0989d35f0a1e4289adfa5a10219519b1107c1d7f;hpb=0e974c50edac8e4e5607e9eb1fcf68e1e822c3be;p=openwrt%2Fstaging%2Frmilecki.git diff --git a/target/linux/kirkwood/image/Makefile b/target/linux/kirkwood/image/Makefile index 0989d35f0a1..1fb482f1e75 100644 --- a/target/linux/kirkwood/image/Makefile +++ b/target/linux/kirkwood/image/Makefile @@ -1,60 +1,172 @@ # -# Copyright (C) 2009-2010 OpenWrt.org +# Copyright (C) 2009-2013 OpenWrt.org # # This is free software, licensed under the GNU General Public License v2. # See /LICENSE for more information. # + +NAND_BLOCKSIZE := 2048-128k + include $(TOPDIR)/rules.mk include $(INCLUDE_DIR)/image.mk -JFFS2OPTS_NAND += --little-endian --pagesize=0x800 --no-cleanmarkers --pad +KERNEL_LOADADDR:=0x8000 +TARGET_DEVICES = linksys-audi linksys-viper dockstar goflexnet goflexhome + +UBI_OPTS := -m 2048 -p 128KiB -s 512 +UBIFS_OPTS := -m 2048 -e 126KiB -c 4096 + +define Device/Default + KERNEL_DEPENDS = $$(wildcard $(DTS_DIR)/$$(DEVICE_DTS).dts) + KERNEL := kernel-bin | append-dtb | uImage none + KERNEL_NAME := zImage + KERNEL_SUFFIX := -uImage + KERNEL_INSTALL := 1 -define Image/mkfs/jffs2/sub/sub - $(STAGING_DIR_HOST)/bin/mkfs.jffs2 $(3) \ - -e $(patsubst %k,%KiB,$(1)) -o $(KDIR)/root.jffs2-$(1)-$(2) -d $(TARGET_DIR) -v 2>&1 1>/dev/null | awk '/^.+$$$$/' + PAGESIZE := 2048 + SUBPAGESIZE := 512 + BLOCKSIZE := 128k + IMAGES := sysupgrade.tar + UBINIZE_OPTS := -E 5 + IMAGE/sysupgrade.tar := sysupgrade-tar endef -define Image/mkfs/jffs2/sub - # Do not remov this line - $(call Image/mkfs/jffs2/sub/sub,$(1),nor,$(JFFS2OPTS)) - ( \ - dd if=$(KDIR)/uImage bs=4096k conv=sync; \ - dd if=$(KDIR)/root.jffs2-$(1)-nor bs=128k conv=sync; \ - ) > $(BIN_DIR)/$(IMG_PREFIX)-jffs2-$(1)-nor.img +define Device/dockstar + DEVICE_DTS := kirkwood-dockstar + FILESYSTEMS := squashfs + PROFILES := Generic DOCKSTAR + IMAGES += factory.bin + IMAGE/factory.bin := append-ubi + KERNEL_IN_UBI := 1 +endef - $(call Image/mkfs/jffs2/sub/sub,$(1),nand,$(JFFS2OPTS) $(JFFS2OPTS_NAND)) - $(call add_jffs2_mark,$(KDIR)/root.jffs2-$(1)-nand) - cp $(KDIR)/root.jffs2-$(1)-nand $(BIN_DIR)/$(IMG_PREFIX)-jffs2-$(1)-nand.img +define Device/goflexnet +$(Device/dockstar) + PROFILES := Generic GOFLEXNET + DEVICE_DTS := kirkwood-goflexnet endef -define Image/Prepare - cp $(LINUX_DIR)/arch/arm/boot/uImage $(KDIR)/uImage +define Device/goflexhome +$(Device/dockstar) + PROFILES := Generic GOFLEXHOME + DEVICE_DTS := kirkwood-goflexhome endef -define Image/BuildKernel -# do mach-id fixup here, if needed - cp $(KDIR)/uImage $(BIN_DIR)/$(IMG_PREFIX)-uImage +define Device/linksys-audi + DEVICE_DTS := kirkwood-linksys-audi + KERNEL_SIZE := 2624k + FILESYSTEMS := squashfs + PROFILES := Generic AUDI + IMAGES += factory.bin + IMAGE/factory.bin := append-kernel | pad-to $$$$(KERNEL_SIZE) | append-ubi endef -define Image/Build - $(call Image/Build/$(1),$(1)) +define Device/linksys-viper + DEVICE_DTS := kirkwood-linksys-viper + KERNEL_SIZE := 2688k + FILESYSTEMS := squashfs + PROFILES := Generic VIPER + IMAGES += factory.bin + IMAGE/factory.bin := append-kernel | pad-to $$$$(KERNEL_SIZE) | append-ubi endef -define Image/Build/jffs2-128k - ( \ - dd if=$(KDIR)/uImage bs=4096k conv=sync; \ - dd if=$(KDIR)/root.$(1) bs=128k conv=sync; \ - ) > $(BIN_DIR)/$(IMG_PREFIX)-$(1)-nor.img +define Image/BuildKernel/Template + + $(CP) $(KDIR)/zImage $(BIN_DIR)/$(IMG_PREFIX)-zImage + echo -ne '\x00\x00\x00\x00' >> $(BIN_DIR)/$(IMG_PREFIX)-zImage + $(call Image/BuildKernel/MkuImage, \ + none, 0x8000, 0x8000, \ + $(BIN_DIR)/$(IMG_PREFIX)-zImage, \ + $(BIN_DIR)/$(IMG_PREFIX)-uImage \ + ) + + ifneq ($(CONFIG_TARGET_ROOTFS_INITRAMFS),) + $(CP) $(KDIR)/zImage-initramfs $(BIN_DIR)/$(IMG_PREFIX)-zImage-initramfs + echo -ne '\x00\x00\x00\x00' >> $(BIN_DIR)/$(IMG_PREFIX)-zImage-initramfs + $(call Image/BuildKernel/MkuImage, \ + none, 0x8000, 0x8000, \ + $(BIN_DIR)/$(IMG_PREFIX)-zImage-initramfs, \ + $(BIN_DIR)/$(IMG_PREFIX)-uImage-initramfs \ + ) + endif + + ifneq ($(1),) + $(CP) $(DTS_DIR)/kirkwood-$(1).dtb $(BIN_DIR)/$(IMG_PREFIX)-$(1).dtb + + $(CP) $(KDIR)/zImage $(BIN_DIR)/$(IMG_PREFIX)-$(PROFILE_SANITIZED)-zImage + cat $(BIN_DIR)/$(IMG_PREFIX)-$(1).dtb >> $(BIN_DIR)/$(IMG_PREFIX)-$(PROFILE_SANITIZED)-zImage + $(call Image/BuildKernel/MkuImage, \ + none, 0x8000, 0x8000, \ + $(BIN_DIR)/$(IMG_PREFIX)-$(PROFILE_SANITIZED)-zImage, \ + $(BIN_DIR)/$(IMG_PREFIX)-$(PROFILE_SANITIZED)-uImage \ + ) + + ifneq ($(CONFIG_TARGET_ROOTFS_INITRAMFS),) + $(CP) $(KDIR)/zImage-initramfs $(BIN_DIR)/$(IMG_PREFIX)-$(PROFILE_SANITIZED)-zImage-initramfs + cat $(BIN_DIR)/$(IMG_PREFIX)-$(1).dtb >> $(BIN_DIR)/$(IMG_PREFIX)-$(PROFILE_SANITIZED)-zImage-initramfs + $(call Image/BuildKernel/MkuImage, \ + none, 0x8000, 0x8000, \ + $(BIN_DIR)/$(IMG_PREFIX)-$(PROFILE_SANITIZED)-zImage-initramfs, \ + $(BIN_DIR)/$(IMG_PREFIX)-$(PROFILE_SANITIZED)-uImage-initramfs \ + ) + endif + endif +endef - cp $(KDIR)/root.$(1) $(BIN_DIR)/$(IMG_PREFIX)-$(1)-nand.img +define Image/Build/jffs2-nand-2048-128k + dd if=$(KDIR)/root.$(1) of=$(BIN_DIR)/$(IMG_PREFIX)-$(PROFILE_SANITIZED)-$(1).img \ + bs=2048 conv=sync endef define Image/Build/squashfs $(call prepare_generic_squashfs,$(KDIR)/root.squashfs) ( \ - dd if=$(KDIR)/uImage bs=4096k conv=sync; \ + dd if=$(KDIR)/zImage bs=4096k conv=sync; \ dd if=$(KDIR)/root.$(1) bs=128k conv=sync; \ - ) > $(BIN_DIR)/$(IMG_PREFIX)-$(1).img + ) > $(BIN_DIR)/$(IMG_PREFIX)-$(PROFILE_SANITIZED)-$(1).img +endef + +define Image/Build/ubifs + + ifneq ($($(PROFILE)_UBIFS_OPTS),) + $(CP) $(KDIR)/root.ubifs $(BIN_DIR)/$(IMG_PREFIX)-$(PROFILE_SANITIZED)-rootfs.ubifs + endif +endef + +define Image/Build/ubi + + ifneq ($($(PROFILE)_UBI_OPTS),) + $(CP) $(KDIR)/root.ubi $(BIN_DIR)/$(IMG_PREFIX)-$(PROFILE_SANITIZED)-rootfs.ubi + endif +endef + +IOMEGA_IX2_200_UBIFS_OPTS := -m 512 -e 15872 -c 2048 +IOMEGA_IX2_200_UBI_OPTS := -m 512 -p 16384 -s 256 + +Image/BuildKernel/Template/Generic=$(call Image/BuildKernel/Template) +Image/BuildKernel/Template/IB62X0=$(call Image/BuildKernel/Template,ib62x0) +Image/BuildKernel/Template/ICONNECT=$(call Image/BuildKernel/Template,iconnect) +Image/BuildKernel/Template/IOMEGA_IX2_200=$(call Image/BuildKernel/Template,iomega_ix2_200) +Image/BuildKernel/Template/NSA310S=$(call Image/BuildKernel/Template,nsa310s) +Image/BuildKernel/Template/POGOE02=$(call Image/BuildKernel/Template,pogo_e02) +Image/BuildKernel/Template/SHEEVAPLUG=$(call Image/BuildKernel/Template,sheevaplug) +Image/BuildKernel/Template/SHEEVAPLUGSATA=$(call Image/BuildKernel/Template,sheevaplug-esata) +Image/BuildKernel/Template/GuruplugServerPlus=$(call Image/BuildKernel/Template,guruplug-server-plus) +Image/BuildKernel/Template/Topkick1281P2=$(call Image/BuildKernel/Template,topkick) + +define Image/BuildKernel + $(call Image/BuildKernel/Template/$(PROFILE)) +endef + +define Image/InstallKernel + $(call Image/InstallKernel/Template/$(PROFILE)) +endef + +define Image/Build + $(if $(Image/Build/$(1)), \ + $(call Image/Build/$(1),$(1)), \ + $(CP) $(KDIR)/root.$(1) $(BIN_DIR)/$(IMG_PREFIX)-$(PROFILE_SANITIZED)-$(1).img \ + ) endef $(eval $(call BuildImage))