ramips: Add support for Beeline SmartBox TURBO+
[openwrt/openwrt.git] / target / linux / ramips / image / common-sercomm.mk
index 83bb2a742c98f956312d034c46d899664b6b141c..fbe29d701749be31ff004c3d5f2550d8f036e759 100644 (file)
@@ -1,4 +1,5 @@
 DEVICE_VARS += SERCOMM_KERNEL_OFFSET SERCOMM_ROOTFS_OFFSET
+DEVICE_VARS += SERCOMM_KERNEL2_OFFSET SERCOMM_ROOTFS2_OFFSET
 
 define Build/sercomm-crypto
        $(TOPDIR)/scripts/sercomm-crypto.py \
@@ -16,6 +17,23 @@ define Build/sercomm-crypto
        rm -f $@.enc $@.key
 endef
 
+define Build/sercomm-factory-cqr
+       $(TOPDIR)/scripts/sercomm-pid.py \
+               --hw-version $(SERCOMM_HWVER) \
+               --hw-id $(SERCOMM_HWID) \
+               --sw-version $(SERCOMM_SWVER) \
+               --pid-file $@.fhdr
+       printf $$(stat -c%s $(IMAGE_KERNEL)) | \
+               dd seek=$$((0x70)) of=$@.fhdr bs=1 conv=notrunc 2>/dev/null
+       printf $$(($$(stat -c%s $@)-$$(stat -c%s $(IMAGE_KERNEL))-$$((0x200)))) | \
+               dd seek=$$((0x80)) of=$@.fhdr bs=1 conv=notrunc 2>/dev/null
+       dd bs=$$((0x200)) skip=1 if=$@ conv=notrunc 2>/dev/null | \
+               $(MKHASH) md5 | awk '{print $$1}' | tr -d '\n' | \
+               dd seek=$$((0x1e0)) of=$@.fhdr bs=1 conv=notrunc 2>/dev/null
+       dd if=$@ >> $@.fhdr 2>/dev/null
+       mv $@.fhdr $@
+endef
+
 define Build/sercomm-kernel
        $(TOPDIR)/scripts/sercomm-kernel-header.py \
                --kernel-image $@ \
@@ -26,6 +44,22 @@ define Build/sercomm-kernel
        mv $@.hdr $@
 endef
 
+define Build/sercomm-kernel-factory
+       $(TOPDIR)/scripts/sercomm-kernel-header.py \
+               --kernel-image $@ \
+               --kernel-offset $(SERCOMM_KERNEL_OFFSET) \
+               --rootfs-offset $(SERCOMM_ROOTFS_OFFSET) \
+               --output-header $@.khdr1
+       $(TOPDIR)/scripts/sercomm-kernel-header.py \
+               --kernel-image $@ \
+               --kernel-offset $(SERCOMM_KERNEL2_OFFSET) \
+               --rootfs-offset $(SERCOMM_ROOTFS2_OFFSET) \
+               --output-header $@.khdr2
+       cat $@.khdr1 $@.khdr2 > $@.khdr
+       dd if=$@ >> $@.khdr 2>/dev/null
+       mv $@.khdr $@
+endef
+
 define Build/sercomm-part-tag
        $(call Build/sercomm-part-tag-common,$(word 1,$(1)) $@)
 endef
@@ -64,24 +98,37 @@ define Build/sercomm-prepend-tagged-kernel
        mv $(IMAGE_KERNEL).tagged $@
 endef
 
-define Device/sercomm_dxx
-  $(Device/dsa-migration)
-  BLOCKSIZE := 128k
-  PAGESIZE := 2048
-  KERNEL_SIZE := 6144k
-  UBINIZE_OPTS := -E 5
+define Device/sercomm
+  $(Device/nand)
   LOADER_TYPE := bin
+  KERNEL_SIZE := 6144k
   KERNEL_LOADADDR := 0x81001000
   LZMA_TEXT_START := 0x82800000
+  SERCOMM_KERNEL_OFFSET := 0x400100
+  SERCOMM_ROOTFS_OFFSET := 0x1000000
+  IMAGES += factory.img
+endef
+
+define Device/sercomm_cxx
+  $(Device/sercomm)
+  SERCOMM_KERNEL2_OFFSET := 0xa00100
+  SERCOMM_ROOTFS2_OFFSET := 0x3000000
+  KERNEL := kernel-bin | append-dtb | lzma | loader-kernel | lzma -a0 | \
+       uImage lzma
+  IMAGE/sysupgrade.bin := append-kernel | sercomm-kernel | \
+       sysupgrade-tar kernel=$$$$@ | append-metadata
+  IMAGE/factory.img := append-kernel | sercomm-kernel-factory | \
+       append-ubi | sercomm-factory-cqr
+endef
+
+define Device/sercomm_dxx
+  $(Device/sercomm)
   KERNEL := kernel-bin | append-dtb | lzma | loader-kernel | lzma -a0 | \
        uImage lzma | sercomm-kernel
   KERNEL_INITRAMFS := kernel-bin | append-dtb | lzma | loader-kernel | \
        lzma -a0 | uImage lzma
-  IMAGES += factory.img
   IMAGE/sysupgrade.bin := sysupgrade-tar | append-metadata
   IMAGE/factory.img := append-ubi | check-size | \
        sercomm-part-tag rootfs | sercomm-prepend-tagged-kernel kernel | \
        gzip | sercomm-payload | sercomm-crypto
-  SERCOMM_KERNEL_OFFSET := 0x400100
-  SERCOMM_ROOTFS_OFFSET := 0x1000000
 endef