[rdc] allow 1MB extra space for JFFS and other enhancements (#7706)
authorFlorian Fainelli <florian@openwrt.org>
Tue, 17 Aug 2010 15:31:27 +0000 (15:31 +0000)
committerFlorian Fainelli <florian@openwrt.org>
Tue, 17 Aug 2010 15:31:27 +0000 (15:31 +0000)
SVN-Revision: 22690

target/linux/rdc/image/Makefile
target/linux/rdc/image/mkimg_bifferboard.py
target/linux/rdc/profiles/bifferboard.mk

index 00322da..7086b99 100644 (file)
@@ -29,8 +29,7 @@ define Image/Build/sitecom
 endef
 
 define Image/Build/bifferboard
-       $(TOPDIR)/target/linux/rdc/image/mkimg_bifferboard.py $(KDIR)/bzImage $(KDIR)/root.$(1) $(KDIR)/tmp.img
-       $(CP) $(KDIR)/tmp.img $(BIN_DIR)/$(IMG_PREFIX)-$(1)-$(2).img
+       $(TOPDIR)/target/linux/rdc/image/mkimg_bifferboard.py $(KDIR)/bzImage $(KDIR)/root.$(1) $(BIN_DIR)/$(IMG_PREFIX)-$(1)-$(2).img
 endef
 
 define Image/Build/Initramfs
index 040c462..5444abe 100755 (executable)
@@ -1,21 +1,31 @@
 #!/usr/bin/env python
 
 """
-   Create firmware for 8MB Bifferboards
-   Firmware does not include the config blocks
-   Firmware starts just after config
+   Create firmware for 4/8MB Bifferboards, suitable for uploading using
+   either bb_upload8.py or bb_eth_upload8.py
 """
 
 import struct, sys
 
-kernel_extent = 0x200000
-config = 0x6000
+# Increase the kmax value if the script gives errors about the kernel being 
+# too large.  You need to set the Biffboot kmax value to the same value you
+# use here.
+kmax = 0x10
+
+# No need to change this for 4MB devices, it's only used to tell you if 
+# the firmware is too large!
+flash_size = 0x800000
+
+# This is always the same, for 1MB, 4MB and 8MB devices
+config_extent = 0x6000
+
+kernel_extent = kmax * 0x10000
 
 if __name__ == "__main__":
 
   if len(sys.argv) != 4:
-    print  "usage: mkimg_bifferboard.py <kernel> <64k JFFS> <output file>"
-    sys.exit(0)
+    print  "usage: mkimg_bifferboard.py <kernel> <rootfs> <output file>"
+    sys.exit(-1)
     
   bzimage = sys.argv[1]
   rootfs = sys.argv[2]
@@ -23,17 +33,17 @@ if __name__ == "__main__":
 
   # Kernel first
   fw = file(bzimage).read()
-  if len(fw) > (kernel_extent - config):
+  if len(fw) > (kernel_extent - config_extent):
     raise IOError("Kernel too large")
 
-  # Pad up to 0x200000
-  while len(fw) < (kernel_extent - config):
+  # Pad up to end of kernel partition
+  while len(fw) < (kernel_extent - config_extent):
     fw += "\xff"
 
   fw += file(rootfs).read()
 
   # Check length of total
-  if len(fw) > (0x800000 - 0x10000 - 0x6000):
+  if len(fw) > (flash_size - 0x10000 - config_extent):
     raise IOError("Rootfs too large")
 
   file(target,"wb").write(fw)
index 0c12ac7..28e1d0e 100644 (file)
@@ -7,5 +7,7 @@
 
 define Profile/bifferboard
        NAME:=Bifferboard
+       PACKAGES:=kmod-usb-core kmod-usb-ohci kmod-usb2 \
+               kmod-usb-storage kmod-scsi-core kmod-fs-ext3
 endef
 $(eval $(call Profile,bifferboard))