From: Hannu Nyman Date: Sun, 17 Jun 2018 19:59:03 +0000 (+0300) Subject: include/image-commands.mk: shorter version in Netgear factory header X-Git-Tag: v18.06.0-rc1~43 X-Git-Url: http://git.lede-project.org./?a=commitdiff_plain;h=b6c134f254fcc60d0474e037af5e62c94931d743;p=openwrt%2Fstaging%2Fxback.git include/image-commands.mk: shorter version in Netgear factory header Shorten the version string in Netgear factory image header in order to enable u-boot TFTP recovery flash mode to work again. Strip 'r7210-14cb05909a' into 'r7210' in the Netgear image header by removing the hash (anything after "-"). background: Some Netgear routers have recently been unable to flash Openwrt factory image with the TFTP recovery flash mode provided by Netgear u-boot. That is due to over-long Openwrt version string overflowing into the router type string in u-boot code. Modern git versions produce 10-digit short hashes for the Openwrt main repo, and that causes the version string to be too long in the image header, breaking the image ID verification by the TFTP flash routine. (Other option could be to force a shorter hash in scripts/getver.sh, but as the problem only concerns Netgear routers, let's patch just them.) More detailed explanations in FS#1583 Tested with WNDR3800 Signed-off-by: Hannu Nyman (cherry picked from commit dcfe2a461e4b06de6e2b23d29afebbb3c775f647) --- diff --git a/include/image-commands.mk b/include/image-commands.mk index 82ceacd80e..1d8ccedd69 100644 --- a/include/image-commands.mk +++ b/include/image-commands.mk @@ -60,7 +60,7 @@ endef define Build/netgear-dni $(STAGING_DIR_HOST)/bin/mkdniimg \ - -B $(NETGEAR_BOARD_ID) -v $(VERSION_DIST).$(REVISION) \ + -B $(NETGEAR_BOARD_ID) -v $(VERSION_DIST).$(firstword $(subst -, ,$(REVISION))) \ $(if $(NETGEAR_HW_ID),-H $(NETGEAR_HW_ID)) \ -r "$(1)" \ -i $@ -o $@.new