X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/b4cd93a0ebf443d25b0a01502a25cc67b466f35a..d7a5a32c176da711e4b454c3b87228d9223eb6d4:/target/linux/ramips/image/Makefile diff --git a/target/linux/ramips/image/Makefile b/target/linux/ramips/image/Makefile index d52c41f0b..24f59663c 100644 --- a/target/linux/ramips/image/Makefile +++ b/target/linux/ramips/image/Makefile @@ -1,5 +1,5 @@ # -# Copyright (C) 2008-2010 OpenWrt.org +# Copyright (C) 2008-2011 OpenWrt.org # # This is free software, licensed under the GNU General Public License v2. # See /LICENSE for more information. @@ -8,7 +8,7 @@ include $(TOPDIR)/rules.mk include $(INCLUDE_DIR)/image.mk define imgname -$(BIN_DIR)/$(IMG_PREFIX)-$(2)-$(patsubst jffs2-%,jffs2,$(patsubst squashfs-%,squashfs,$(1))) +$(BIN_DIR)/$(IMG_PREFIX)-$(2)-$(1) endef VMLINUX:=$(IMG_PREFIX)-vmlinux @@ -18,13 +18,13 @@ ifeq ($(CONFIG_TARGET_ROOTFS_INITRAMFS),y) UIMAGE:=$(IMG_PREFIX)-uImage-initramfs endif -ifeq ($(CONFIG_RALINK_RT305X),y) +ifeq ($(CONFIG_RALINK_RT288X),y) define kernel_entry --a 0x80000000 -e 0x80000000 +-a 0x88000000 -e 0x88000000 endef else define kernel_entry --a 0x88000000 -e 0x88000000 +-a 0x80000000 -e 0x80000000 endef endif @@ -54,15 +54,12 @@ endef define BuildFirmware/Generic $(call PatchKernelLzma,$(2),$(3) $($(4))) - if [ `stat -c%s "$(KDIR)/vmlinux-$(2).bin.lzma"` -gt $(5) ]; then \ - echo "Warning: $(KDIR)/vmlinux-$(2).bin.lzma is too big"; \ + $(call MkImage,lzma,"$(KDIR)/vmlinux-$(2).bin.lzma","$(KDIR)/vmlinux-$(2).uImage") + if [ `stat -c%s "$(KDIR)/vmlinux-$(2).uImage"` -gt $(5) ]; then \ + echo "Warning: $(KDIR)/vmlinux-$(2).uImage is too big"; \ else if [ `stat -c%s $(KDIR)/root.$(1)` -gt $(6) ]; then \ echo "Warning: $(KDIR)/root.$(1) is too big"; \ else \ - mkimage -A mips -O linux -T kernel -C lzma \ - $(call kernel_entry) \ - -n 'MIPS OpenWrt Linux-$(LINUX_VERSION)' \ - -d $(KDIR)/vmlinux-$(2).bin.lzma $(KDIR)/vmlinux-$(2).uImage; \ ( \ dd if=$(KDIR)/vmlinux-$(2).uImage bs=$(5) conv=sync; \ dd if=$(KDIR)/root.$(1) bs=64k conv=sync; \ @@ -70,6 +67,52 @@ define BuildFirmware/Generic fi; fi endef +define BuildFirmware/Buffalo + $(call PatchKernelLzma,$(2),board=$(3) $($(4))) + $(call MkImage,lzma,"$(KDIR)/vmlinux-$(2).bin.lzma","$(KDIR)/vmlinux-$(2).uImage") + if [ `stat -c%s "$(KDIR)/vmlinux-$(2).uImage"` -gt $(5) ]; then \ + echo "Warning: $(KDIR)/vmlinux-$(2).uImage is too big"; \ + else if [ `stat -c%s $(KDIR)/root.$(1)` -gt $(6) ]; then \ + echo "Warning: $(KDIR)/root.$(1) is too big"; \ + else \ + buffalo-enc -p $(3) -v 1.76 \ + -i $(KDIR)/vmlinux-$(2).uImage \ + -o $(KDIR)/vmlinux-$(2).uImage.enc; \ + buffalo-enc -p $(3) -v 1.76 \ + -i $(KDIR)/root.$(1) \ + -o $(KDIR)/root.$(2).enc; \ + buffalo-tag -b $(3) -p $(3) -a ram -v 1.76 -m 1.01 \ + -l mlang8 -f 1 -r EU \ + -i $(KDIR)/vmlinux-$(2).uImage.enc \ + -i $(KDIR)/root.$(2).enc \ + -o $(call imgname,$(1),$(2))-factory-EU.bin; \ + fi; fi +endef + +define BuildFirmware/NW718 + $(call PatchKernelLzma,$(2),$(3) $($(4))) + mkimage -A mips -O linux -T kernel -C lzma $(call kernel_entry) \ + -n "ARA1B4NCRNW718;1" \ + -d "$(KDIR)/vmlinux-$(2).bin.lzma" \ + "$(KDIR)/vmlinux-$(2).uImage" + if [ `stat -c%s "$(KDIR)/vmlinux-$(2).uImage"` -gt $(5) ]; then \ + echo "Warning: $(KDIR)/vmlinux-$(2).uImage is too big"; \ + else if [ `stat -c%s $(KDIR)/root.$(1)` -gt $(6) ]; then \ + echo "Warning: $(KDIR)/root.$(1) is too big"; \ + else \ + ( \ + dd if=$(KDIR)/vmlinux-$(2).uImage bs=$(5) conv=sync; \ + dd if=$(KDIR)/root.$(1) bs=64k conv=sync; \ + ) > $(call imgname,$(1),$(2))-factory.bin; \ + fi; fi +endef + +define BuildFirmware/Edimax + mkedimaximg -i $(call imgname,$(1),$(2))-sysupgrade.bin \ + -o $(call imgname,$(1),$(2))-factory.bin \ + -s $(3) -m $(4) -f $(5) -S $(6) +endef + mtdlayout_4M=mtdparts=physmap-flash.0:192k(u-boot)ro,64k(u-boot-env)ro,64k(factory)ro,832k(kernel),2944k(rootfs),3776k@0x50000(firmware) define Image/Build/Template/GENERIC_4M $(call BuildFirmware/Generic,$(1),$(2),board=$(3),mtdlayout_4M,851968,3014656) @@ -80,28 +123,149 @@ define Image/Build/Template/GENERIC_8M $(call BuildFirmware/Generic,$(1),$(2),board=$(3),mtdlayout_8M,851968,7208960) endef +mtdlayout_dir300b1=mtdparts=physmap-flash.0:192k(u-boot)ro,64k(devdata)ro,64k(devconf)ro,832k(kernel),2944k(rootfs),3776k@0x50000(firmware) +mtd_dir300b1_kernel_part_size=851968 +mtd_dir300b1_rootfs_part_size=3014656 +define Image/Build/Template/DIR300B1 + $(call BuildFirmware/Generic,$(1),$(2),board=$(3),mtdlayout_dir300b1,$(mtd_dir300b1_kernel_part_size),$(mtd_dir300b1_rootfs_part_size)) + mkwrgimg -s $(4) -d /dev/mtdblock/2 \ + -i $(call imgname,$(1),$(2))-sysupgrade.bin \ + -o $(call imgname,$(1),$(2))-factory.bin +endef + +mtdlayout_nw718=mtdparts=spi0.0:192k(u-boot)ro,128k(config)ro,64k(factory)ro,832k(kernel),2880k(rootfs),3712k@0x60000(firmware) +define Image/Build/Template/NW718 + $(call BuildFirmware/Generic,$(1),$(2),board=$(3),mtdlayout_nw718,851968,2949120) + $(call BuildFirmware/NW718,$(1),$(2),board=$(3),mtdlayout_nw718,851968,2949120) +endef + define Image/Build/Profile/DIR300B1 - $(call Image/Build/Template/GENERIC_4M,$(1),dir-300-b1,DIR-300-revB) + $(call Image/Build/Template/DIR300B1,$(1),dir-300-b1,DIR-300-B1,wrgn23_dlwbr_dir300b) + $(call Image/Build/Template/DIR300B1,$(1),dir-600-b1,DIR-600-B1,wrgn23_dlwbr_dir600b) + $(call Image/Build/Template/DIR300B1,$(1),dir-600-b2,DIR-600-B2,wrgn23_dlwbr_dir600b) +endef + +mtdlayout_rtg32b1=mtdparts=spi0.0:192k(u-boot)ro,64k(devdata)ro,64k(devconf)ro,832k(kernel),2944k(rootfs),3776k@0x50000(firmware) +mtd_rtg32b1_kernel_part_size=851968 +mtd_rtg32b1_rootfs_part_size=3014656 +define Image/Build/Template/RTG32B1 + $(call BuildFirmware/Generic,$(1),$(2),board=$(3),mtdlayout_rtg32b1,$(mtd_rtg32b1_kernel_part_size),$(mtd_rtg32b1_rootfs_part_size)) +endef + +define Image/Build/Profile/RTG32B1 + $(call Image/Build/Template/RTG32B1,$(1),rt-g32-b1,RT-G32-B1) endef define Image/Build/Profile/FONERA20N $(call Image/Build/Template/GENERIC_8M,$(1),fonera20n,FONERA20N) + $(call BuildFirmware/Edimax,$(1),fonera20n,RSDK,NL1T,0x50000,0xc0000) +endef + +define Image/Build/Profile/BC2 + $(call Image/Build/Template/GENERIC_8M,$(1),bc2,BC2) +endef + +define Image/Build/Profile/NBG419N + $(call Image/Build/Template/GENERIC_4M,$(1),nbg-419n,NBG-419N) +endef + +define Image/Build/Profile/NW718 + $(call Image/Build/Template/NW718,$(1),nw718,NW718) +endef + +define Image/Build/Profile/PWH2004 + $(call Image/Build/Template/GENERIC_8M,$(1),pwh2004,PWH2004) endef define Image/Build/Profile/V22RW2X2 $(call Image/Build/Template/GENERIC_4M,$(1),v22rw-2x2,V22RW-2X2) endef +mtdlayout_whrg300n=mtdparts=physmap-flash.0:192k(u-boot)ro,64k(u-boot-env)ro,64k(factory)ro,960k(kernel),2752k(rootfs),64k(user)ro,3712k@0x50000(firmware) define Image/Build/Profile/WHRG300N $(call Image/Build/Template/GENERIC_4M,$(1),whr-g300n,WHR-G300N) + $(call BuildFirmware/Buffalo,$(1),whr-g300n,WHR-G300N,mtdlayout_whrg300n,983040,3801088) + ( \ + echo -n -e "# Airstation FirmWare\nrun u_fw\nreset\n\n" | \ + dd bs=512 count=1 conv=sync; \ + dd if=$(call imgname,$(1),whr-g300n)-sysupgrade.bin; \ + ) > $(KDIR)/whr-g300n-tftp.tmp + buffalo-tftp -i $(KDIR)/whr-g300n-tftp.tmp \ + -o $(call imgname,$(1),whr-g300n)-tftp.bin +endef + +define Image/Build/Profile/HW5503G + $(call Image/Build/Template/GENERIC_8M,$(1),hw550-3g,HW550-3G) +endef + +define Image/Build/Profile/MOFI35003GN + $(call Image/Build/Template/GENERIC_8M,$(1),mofi3500-3gn,MOFI3500-3GN) +endef + +define Image/Build/Profile/WCR150GN + $(call Image/Build/Template/GENERIC_4M,$(1),wcr150gn,WCR150GN) +endef + + +mtdlayout_argus_atp52b=mtdparts=physmap-flash.0:192k(bootloader)ro,64k(config),64k(factory),1152k(kernel),6656k(rootfs),7808k@0x50000(firmware) +mtd_argus_atp52b_kernel_part_size=1179648 +mtd_argus_atp52b_rootfs_part_size=6815744 +define Image/Build/Template/ARGUS_ATP52B + $(call BuildFirmware/Generic,$(1),$(2),board=$(3),mtdlayout_argus_atp52b,$(mtd_argus_atp52b_kernel_part_size),$(mtd_argus_atp52b_rootfs_part_size)) +endef + +define Image/Build/Profile/ARGUS_ATP52B + $(call Image/Build/Template/ARGUS_ATP52B,$(1),argus_atp52b,ARGUS_ATP52B) +endef + +mtdlayout_f5d8235=mtdparts=physmap-flash.0:320k(u-boot)ro,1536k(kernel),6208k(rootfs),64k(nvram),64k(factory),7744k@0x50000(firmware) +mtd_f5d8235_kernel_part_size=1572864 +mtd_f5d8235_rootfs_part_size=6356992 +define Image/Build/Template/F5D8235V2 + $(call BuildFirmware/Generic,$(1),$(2),board=$(3),mtdlayout_f5d8235,$(mtd_f5d8235_kernel_part_size),$(mtd_f5d8235_rootfs_part_size)) +endef + +define Image/Build/Profile/F5D8235V2 + $(call Image/Build/Template/F5D8235V2,$(1),f5d8235v2,F5D8235_V2) +endef + + +mtdlayout_wr5123gn=mtdparts=physmap-flash.0:192k(u-boot)ro,64k(u-boot-env)ro,64k(factory)ro,832k(kernel),2944k(rootfs),3776k@0x50000(firmware) +mtdlayout_wr5123gn8m=mtdparts=physmap-flash.0:192k(u-boot)ro,64k(u-boot-env)ro,64k(factory)ro,832k(kernel),7040k(rootfs),7872k@0x50000(firmware) +define Image/Build/Profile/WR5123GN + $(call BuildFirmware/Generic,$(1),wr512-3gn-4M,board="WR512-3GN",mtdlayout_wr5123gn,851968,3014656) + $(call BuildFirmware/Generic,$(1),wr512-3gn-8M,board="WR512-3GN",mtdlayout_wr5123gn8m,851968,7208960) endef + ifeq ($(CONFIG_RALINK_RT305X),y) define Image/Build/Profile/Default + $(call Image/Build/Profile/ARGUS_ATP52B,$(1)) + $(call Image/Build/Profile/BC2,$(1)) $(call Image/Build/Profile/DIR300B1,$(1)) + $(call Image/Build/Profile/RTG32B1,$(1)) $(call Image/Build/Profile/FONERA20N,$(1)) $(call Image/Build/Profile/V22RW2X2,$(1)) + $(call Image/Build/Profile/NBG419N,$(1)) + $(call Image/Build/Profile/NW718,$(1)) + $(call Image/Build/Profile/PWH2004,$(1)) $(call Image/Build/Profile/WHRG300N,$(1)) + $(call Image/Build/Profile/WCR150GN,$(1)) + $(call Image/Build/Profile/F5D8235V2,$(1)) + $(call Image/Build/Profile/HW5503G,$(1)) + $(call Image/Build/Profile/MOFI35003GN,$(1)) + $(call Image/Build/Profile/WR5123GN,$(1)) +endef +endif + + +define Image/Build/Profile/RTN15 + $(call Image/Build/Template/GENERIC_4M,$(1),rt-n15,RT-N15) +endef + +ifeq ($(CONFIG_RALINK_RT288X),y) +define Image/Build/Profile/Default + $(call Image/Build/Profile/RTN15,$(1)) endef endif