X-Git-Url: http://git.rohieb.name/openwrt.git/blobdiff_plain/c1be68167224a7800a544c5f1c07dc9fd50f495c..eada36fe536b72b8c29f7ca9d211ef8fae80382c:/target/linux/ramips/image/Makefile diff --git a/target/linux/ramips/image/Makefile b/target/linux/ramips/image/Makefile index d177c04ba..29d1f2502 100644 --- a/target/linux/ramips/image/Makefile +++ b/target/linux/ramips/image/Makefile @@ -13,7 +13,9 @@ endef VMLINUX:=$(IMG_PREFIX)-vmlinux UIMAGE:=$(IMG_PREFIX)-uImage +fs_squash:=squashfs-only ifeq ($(CONFIG_TARGET_ROOTFS_INITRAMFS),y) + fs_squash:=initramfs VMLINUX:=$(IMG_PREFIX)-vmlinux-initramfs UIMAGE:=$(IMG_PREFIX)-uImage-initramfs endif @@ -50,6 +52,7 @@ define Image/BuildKernel $(call CompressLzma,$(KDIR)/vmlinux,$(KDIR)/vmlinux.bin.lzma) $(call MkImage,lzma,$(KDIR)/vmlinux.bin.lzma,$(KDIR)/uImage.lzma) cp $(KDIR)/uImage.lzma $(BIN_DIR)/$(UIMAGE).bin + $(call Image/Build/Initramfs) endef define BuildFirmware/Generic @@ -67,6 +70,34 @@ define BuildFirmware/Generic fi; fi endef +define BuildFirmware/Generic/initramfs + $(call PatchKernelLzma,$(2),$(3) $($(4))) + $(call MkImage,lzma,"$(KDIR)/vmlinux-$(2).bin.lzma","$(KDIR)/vmlinux-$(2).uImage") + $(CP) $(KDIR)/vmlinux-$(2).uImage $(call imgname,$(1),$(2))-uImage.bin +endef + +define BuildFirmware/WL341V3 + $(call PatchKernelLzma,$(2),$(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 \ + ( \ + dd if=/dev/zero bs=195936 count=1; \ + echo "1.01"; \ + dd if=/dev/zero bs=581 count=1; \ + echo -n -e "\x73\x45\x72\x43\x6F\x4D\x6D\x00\x01\x00\x00\x59\x4E\x37\x95\x58\x10\x00\x20\x00\x28\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x11\x03\x00\x00\x80\x00\x00\x00\x00\x03\x00\x00\x10\x12\x00\x00\x00\x10\x73\x45\x72\x43\x6F\x4D\x6D"; \ + dd if=/dev/zero bs=65552 count=1; \ + dd if=$(KDIR)/vmlinux-$(2).uImage bs=$(5) conv=sync; \ + dd if=$(KDIR)/root.$(1) bs=64k conv=sync; \ + dd if=/dev/zero bs=`expr 4194304 - 262144 - 16 - $(5) - \( \( \( \`stat -c%s $(KDIR)/root.$(1)\` / 65536 \) + 1 \) \* 65536 \)` count=1; \ + echo -n -e "\x11\x03\x80\x00\x10\x12\x90\xF7\x65\x52\x63\x4F\x6D\x4D\x00\x00"; \ + ) > $(call imgname,$(1),$(2))-factory.bin; \ + fi; fi +endef + define BuildFirmware/Buffalo $(call PatchKernelLzma,$(2),board=$(3) $($(4))) $(call MkImage,lzma,"$(KDIR)/vmlinux-$(2).bin.lzma","$(KDIR)/vmlinux-$(2).uImage") @@ -117,21 +148,37 @@ define BuildFirmware/Edimax -s $(3) -m $(4) -f $(5) -S $(6) endef +define Image/Build/Template/initramfs/initramfs + $(call Image/Build/Template/$(1)/initramfs,initramfs,$(2),$(3),$(4),$(5),$(6),$(7),$(8)) +endef + +define Image/Build/Template/squashfs-only/squashfs + $(call Image/Build/Template/$(1),squashfs,$(2),$(3),$(4),$(5),$(6),$(7),$(8)) +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) endef -mtdlayout_8M=mtdparts=physmap-flash.0:192k(u-boot)ro,64k(u-boot-env)ro,64k(factory)ro,832k(kernel),7040k(rootfs),7872k@0x50000(firmware) -kernel_size_8M=851968 -rootfs_size_8M=7208960 +define Image/Build/Template/GENERIC_4M/initramfs + $(call BuildFirmware/Generic/initramfs,$(1),$(2),board=$(3),mtdlayout_4M) +endef + +mtdlayout_8M=mtdparts=physmap-flash.0:192k(u-boot)ro,64k(u-boot-env)ro,64k(factory)ro,896k(kernel),6976k(rootfs),7872k@0x50000(firmware) +kernel_size_8M=917504 +rootfs_size_8M=7143424 define Image/Build/Template/GENERIC_8M $(call BuildFirmware/Generic,$(1),$(2),board=$(3),mtdlayout_8M,$(kernel_size_8M),$(rootfs_size_8M)) 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/GENERIC_8M/initramfs + $(call BuildFirmware/Generic/initramfs,$(1),$(2),board=$(3),mtdlayout_8M) +endef + +mtdlayout_dir300b1=mtdparts=physmap-flash.0:192k(u-boot)ro,64k(devdata)ro,64k(devconf)ro,896k(kernel),2880k(rootfs),3776k@0x50000(firmware) +mtd_dir300b1_kernel_part_size=917504 +mtd_dir300b1_rootfs_part_size=2949120 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 \ @@ -145,16 +192,36 @@ define Image/Build/Template/NW718 $(call BuildFirmware/NW718,$(1),$(2),board=$(3),mtdlayout_nw718,851968,2949120) endef +console_WR6202=ttyS1,115200 +mtdlayout_WR6202=mtdparts=physmap-flash.0:192k(u-boot)ro,64k(u-boot-env)ro,64k(factory)ro,1024k(kernel),6848k(rootfs),7872k@0x50000(firmware) +define Image/Build/Template/WR6202 + $(call BuildFirmware/Generic,$(1),$(2),board=$(3) console=$(console_WR6202),mtdlayout_WR6202,1048576,7012352) +endef + +define Image/Build/Profile/WR6202 + $(call Image/Build/Template/$(fs_squash)/$(1),WR6202,wr6202,WR6202) +endef + console_OMNIEMB=ttyS1,57600 mtdlayout_ONMIEMB=mtdparts=physmap-flash.0:192k(u-boot)ro,64k(u-boot-env)ro,64k(factory)ro,1024k(kernel),6848k(rootfs),7872k@0x50000(firmware) define Image/Build/Template/OMNIEMB $(call BuildFirmware/Generic,$(1),$(2),board=$(3) console=$(console_OMNIEMB),mtdlayout_OMNIEMB,1048576,7012352) endef +mtdlayout_sercomm_4M=mtdparts=physmap-flash.0:128k(u-boot)ro,64k(board-nvram)ro,64k(u-boot-env)ro,832k(kernel),2944k(rootfs),64k(signature-eRcOmM),3776k@0x40000(firmware),4096k@0x0(fullflash) +define Image/Build/Template/WL341V3 + $(call BuildFirmware/Generic,$(1),$(2),board=$(3),mtdlayout_sercomm_4M,851968,3014656) + $(call BuildFirmware/WL341V3,$(1),$(2),board=$(3),mtdlayout_sercomm_4M,851968,3014656) +endef + +define Image/Build/Profile/WL341V3 + $(call Image/Build/Template/$(fs_squash)/$(1),WL341V3,wl341v3,WL341V3) +endef + define Image/Build/Profile/DIR300B1 - $(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) + $(call Image/Build/Template/$(fs_squash)/$(1),DIR300B1,dir-300-b1,DIR-300-B1,wrgn23_dlwbr_dir300b) + $(call Image/Build/Template/$(fs_squash)/$(1),DIR300B1,dir-600-b1,DIR-600-B1,wrgn23_dlwbr_dir600b) + $(call Image/Build/Template/$(fs_squash)/$(1),DIR300B1,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) @@ -165,48 +232,61 @@ define Image/Build/Template/RTG32B1 endef define Image/Build/Profile/RTG32B1 - $(call Image/Build/Template/RTG32B1,$(1),rt-g32-b1,RT-G32-B1) + $(call Image/Build/Template/$(fs_squash)/$(1),RTG32B1,rt-g32-b1,RT-G32-B1) endef define Image/Build/Profile/ESR9753 - $(call Image/Build/Template/GENERIC_4M,$(1),esr-9753,ESR-9753) + $(call Image/Build/Template/$(fs_squash)/$(1),GENERIC_4M,esr-9753,ESR-9753) endef -define Image/Build/Profile/FONERA20N +define Image/Build/Template/FONERA20N $(call Image/Build/Template/GENERIC_8M,$(1),fonera20n,FONERA20N) $(call BuildFirmware/Edimax,$(1),fonera20n,RSDK,NL1T,0x50000,0xc0000) endef +define Image/Build/Profile/FONERA20N + $(call Image/Build/Template/$(fs_squash)/$(1),FONERA20N) +endef + define Image/Build/Profile/BC2 - $(call Image/Build/Template/GENERIC_8M,$(1),bc2,BC2) + $(call Image/Build/Template/$(fs_squash)/$(1),GENERIC_8M,bc2,BC2) +endef + +mtdlayout_all0256n=mtdparts=spi0.0:192k(u-boot)ro,64k(u-boot-env)ro,64k(factory)ro,832k(kernel),2944k(rootfs),3776k@0x50000(firmware) +define Image/Build/Template/ALL0256N + $(call BuildFirmware/Generic,$(1),all0256n,board=ALL0256N,mtdlayout_all0256n,851968,3014656) +endef + +define Image/Build/Profile/ALL0256N + $(call Image/Build/Template/$(fs_squash)/$(1),ALL0256) endef define Image/Build/Profile/NBG419N - $(call Image/Build/Template/GENERIC_4M,$(1),nbg-419n,NBG-419N) + $(call Image/Build/Template/$(fs_squash)/$(1),GENERIC_4M,nbg-419n,NBG-419N) endef define Image/Build/Profile/WL351 - $(call Image/Build/Template/GENERIC_4M,$(1),wl-351,WL-351) + $(call Image/Build/Template/$(fs_squash)/$(1),GENERIC_4M,wl-351,WL-351) endef define Image/Build/Profile/NW718 - $(call Image/Build/Template/NW718,$(1),nw718,NW718) + $(call Image/Build/Template/$(fs_squash)/$(1),NW718,nw718,NW718) endef define Image/Build/Profile/OMNIEMB - $(call Image/Build/Template/OMNIEMB,$(1),omni-emb,OMNI-EMB) + $(call Image/Build/Template/$(fs_squash)/$(1),OMNIEMB,omni-emb,OMNI-EMB) endef define Image/Build/Profile/PWH2004 - $(call Image/Build/Template/GENERIC_8M,$(1),pwh2004,PWH2004) + $(call Image/Build/Template/$(fs_squash)/$(1),GENERIC_8M,pwh2004,PWH2004) endef define Image/Build/Profile/V22RW2X2 - $(call Image/Build/Template/GENERIC_4M,$(1),v22rw-2x2,V22RW-2X2) + $(call Image/Build/Template/$(fs_squash)/$(1),GENERIC_4M,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 +define Image/Build/Template/WHRG300N $(call Image/Build/Template/GENERIC_4M,$(1),whr-g300n,WHR-G300N) $(call BuildFirmware/Buffalo,$(1),whr-g300n,WHR-G300N,mtdlayout_whrg300n,983040,3801088) ( \ @@ -218,23 +298,31 @@ define Image/Build/Profile/WHRG300N -o $(call imgname,$(1),whr-g300n)-tftp.bin endef +define Image/Build/Profile/WHRG300N + $(call Image/Build/Template/$(fs_squashfs)/$(1),WHRG300N) +endef + define Image/Build/Profile/HW5503G - $(call Image/Build/Template/GENERIC_8M,$(1),hw550-3g,HW550-3G) + $(call Image/Build/Template/$(fs_squash)/$(1),GENERIC_8M,hw550-3g,HW550-3G) endef define Image/Build/Profile/MOFI35003GN - $(call Image/Build/Template/GENERIC_8M,$(1),mofi3500-3gn,MOFI3500-3GN) + $(call Image/Build/Template/$(fs_squash)/$(1),GENERIC_8M,mofi3500-3gn,MOFI3500-3GN) endef define Image/Build/Profile/WCR150GN - $(call Image/Build/Template/GENERIC_4M,$(1),wcr150gn,WCR150GN) + $(call Image/Build/Template/$(fs_squash)/$(1),GENERIC_4M,wcr150gn,WCR150GN) endef w502u_cmdline=board=W502U console=ttyS1,115200 -define Image/Build/Profile/W502U +define Image/Build/Template/W502U $(call BuildFirmware/Generic,$(1),w502u,$(w502u_cmdline),mtdlayout_8M,$(kernel_size_8M),$(rootfs_size_8M)) endef +define Image/Build/Profile/W502U + $(call Image/Build/Template/$(fs_squash)/$(1),W502U) +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 @@ -243,7 +331,7 @@ define Image/Build/Template/ARGUS_ATP52B endef define Image/Build/Profile/ARGUS_ATP52B - $(call Image/Build/Template/ARGUS_ATP52B,$(1),argus_atp52b,ARGUS_ATP52B) + $(call Image/Build/Template/$(fs_squash)/$(1),ARGUS_ATP52B,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) @@ -254,25 +342,27 @@ define Image/Build/Template/F5D8235V2 endef define Image/Build/Profile/F5D8235V2 - $(call Image/Build/Template/F5D8235V2,$(1),f5d8235v2,F5D8235_V2) + $(call Image/Build/Template/$(fs_squash)/$(1),F5D8235V2,f5d8235v2,F5D8235_V2) endef define Image/Build/Template/F5D8235V1 $(call BuildFirmware/Generic,$(1),$(2),board=$(3),mtdlayout_f5d8235,$(mtd_f5d8235_kernel_part_size),$(mtd_f5d8235_rootfs_part_size)) 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) + $(call Image/Build/Template/$(fs_squash)/$(1),GENERIC_4M,wr512-3gn-4M,WR512-3GN) + $(call Image/Build/Template/$(fs_squash)/$(1),GENERIC_8M,wr512-3gn-8M,WR512-3GN) +endef + +define Image/Build/Profile/SLR7205 + $(call Image/Build/Template/$(fs_squash)/$(1),GENERIC_4M,sl-r7205,SL-R7205) 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/ALL0256N,$(1)) $(call Image/Build/Profile/DIR300B1,$(1)) $(call Image/Build/Profile/ESR9753,$(1)) $(call Image/Build/Profile/RTG32B1,$(1)) @@ -282,6 +372,7 @@ define Image/Build/Profile/Default $(call Image/Build/Profile/NW718,$(1)) $(call Image/Build/Profile/OMNIEMB,$(1)) $(call Image/Build/Profile/PWH2004,$(1)) + $(call Image/Build/Profile/SLR7205,$(1)) $(call Image/Build/Profile/WHRG300N,$(1)) $(call Image/Build/Profile/WCR150GN,$(1)) $(call Image/Build/Profile/F5D8235V2,$(1)) @@ -289,31 +380,51 @@ define Image/Build/Profile/Default $(call Image/Build/Profile/MOFI35003GN,$(1)) $(call Image/Build/Profile/W502U,$(1)) $(call Image/Build/Profile/WR5123GN,$(1)) + $(call Image/Build/Profile/WL341V3,$(1)) $(call Image/Build/Profile/WL351,$(1)) + $(call Image/Build/Profile/WR6202,$(1)) endef endif define Image/Build/Profile/F5D8235V1 - $(call Image/Build/Template/F5D8235V1,$(1),f5d8235v1,F5D8235_V1) + $(call Image/Build/Template/$(fs_squash)/$(1),F5D8235V1,f5d8235v1,F5D8235_V1) endef define Image/Build/Profile/RTN15 - $(call Image/Build/Template/GENERIC_4M,$(1),rt-n15,RT-N15) + $(call Image/Build/Template/$(fs_squash)/$(1),GENERIC_4M,rt-n15,RT-N15) +endef + +mtdlayout_v11stfe=mtdparts=physmap-flash.0:192k(u-boot)ro,64k(u-boot-env)ro,64k(factory)ro,1280k(kernel),2112k(rootfs),3392k@0x50000(firmware) +define Image/Build/Template/V11STFE + $(call BuildFirmware/Generic,$(1),v11st-fe,board=V11ST-FE,mtdlayout_v11stfe,1310720,2162688) +endef + +define Image/Build/Profile/V11STFE + $(call Image/Build/Template/$(fs_squash)/$(1),V11STFE) endef mtdlayout_wlitx4ag300n=mtdparts=physmap-flash.0:192k(u-boot)ro,64k(u-boot-env)ro,64k(factory)ro,832k(kernel),2880k(rootfs),64k(user)ro,3712k@0x50000(firmware) -define Image/Build/Profile/WLITX4AG300N +define Image/Build/Template/WLITX4AG300N $(call BuildFirmware/Buffalo2,$(1),wli-tx4-ag300n,WLI-TX4-AG300N,mtdlayout_wlitx4ag300n,851968,2949120) endef +define Image/Build/Profile/WLITX4AG300N + $(call Image/Build/Template/$(fs_squash)/$(1),WLITX4AG300N) +endef + ifeq ($(CONFIG_RALINK_RT288X),y) define Image/Build/Profile/Default $(call Image/Build/Profile/F5D8235V1,$(1)) $(call Image/Build/Profile/RTN15,$(1)) + $(call Image/Build/Profile/V11STFE,$(1)) $(call Image/Build/Profile/WLITX4AG300N,$(1)) endef endif +define Image/Build/Initramfs + $(call Image/Build/Profile/$(PROFILE),initramfs) +endef + define Image/Build/squashfs $(call prepare_generic_squashfs,$(KDIR)/root.squashfs) endef