diff --git a/patches/openwrt/0046-ar71xx-Generate-sysupgrade-images-for-OpenMesh-devic.patch b/patches/openwrt/0046-ar71xx-Generate-sysupgrade-images-for-OpenMesh-devic.patch
new file mode 100644
index 0000000000000000000000000000000000000000..6470646d4bb8786e6437a8ed889b5bf6b730d37e
--- /dev/null
+++ b/patches/openwrt/0046-ar71xx-Generate-sysupgrade-images-for-OpenMesh-devic.patch
@@ -0,0 +1,30 @@
+From: Sven Eckelmann <sven.eckelmann@open-mesh.com>
+Date: Tue, 17 May 2016 16:38:29 +0200
+Subject: ar71xx: Generate sysupgrade images for OpenMesh devices
+
+Some OpenWrt based firmwares like Gluon expect that a sysupgrade image
+exists when a device firmware can be updated via sysupgrade. This image
+wasn't created until now because OpenMesh devices use the same image for
+factory and sysupgrade flash. Copying the image from *factory.bin to
+*sysupgrade.bin is therefore enough to make the sysupgrade functionality
+visible.
+
+Reported-by: Matthias Schiffer <mschiffer@universe-factory.net>
+Signed-off-by: Sven Eckelmann <sven.eckelmann@open-mesh.com>
+
+Forwarded: https://patchwork.ozlabs.org/patch/624172/
+
+diff --git a/target/linux/ar71xx/image/Makefile b/target/linux/ar71xx/image/Makefile
+index 916d4e2..f91e20e 100644
+--- a/target/linux/ar71xx/image/Makefile
++++ b/target/linux/ar71xx/image/Makefile
+@@ -1877,6 +1877,9 @@ define Image/Build/OpenMesh
+ 		"$(BUILD_DIR)/fwupgrade.cfg-$(4)" "fwupgrade.cfg" \
+ 		"$(KDIR_TMP)/vmlinux-$(2).uImage" "kernel" \
+ 		"$(KDIR)/root.$(1)" "rootfs"
++	if [ -e "$(call factoryname,$(1),$(2))" ]; then \
++		cp "$(call factoryname,$(1),$(2))" "$(call sysupname,$(1),$(2))"; \
++	fi
+ endef
+ 
+ 
diff --git a/targets/ar71xx-generic/profiles.mk b/targets/ar71xx-generic/profiles.mk
index 1b04068c1958d833984dd726b343acf627c1d7ad..f5a57da7674ec33b37a4c57d64ce5bd56afb8bd6 100644
--- a/targets/ar71xx-generic/profiles.mk
+++ b/targets/ar71xx-generic/profiles.mk
@@ -299,19 +299,16 @@ $(eval $(call GluonModel,OMEGA,onion-omega,onion-omega))
 
 # MR600
 $(eval $(call GluonProfile,MR600,om-watchdog uboot-envtools))
-$(eval $(call GluonProfileSysupgradeSuffix,MR600,-squashfs-factory,.bin))
 $(eval $(call GluonModel,MR600,mr600,openmesh-mr600))
 $(eval $(call GluonModelAlias,MR600,openmesh-mr600,openmesh-mr600-v2))
 
 # MR900
 $(eval $(call GluonProfile,MR900,om-watchdog uboot-envtools))
-$(eval $(call GluonProfileSysupgradeSuffix,MR900,-squashfs-factory,.bin))
 $(eval $(call GluonModel,MR900,mr900,openmesh-mr900))
 $(eval $(call GluonModelAlias,MR900,openmesh-mr900,openmesh-mr900-v2))
 
 # OM2P
 $(eval $(call GluonProfile,OM2P,om-watchdog uboot-envtools))
-$(eval $(call GluonProfileSysupgradeSuffix,OM2P,-squashfs-factory,.bin))
 $(eval $(call GluonModel,OM2P,om2p,openmesh-om2p))
 $(eval $(call GluonModelAlias,OM2P,openmesh-om2p,openmesh-om2p-v2))
 $(eval $(call GluonModelAlias,OM2P,openmesh-om2p,openmesh-om2p-hs))
@@ -320,7 +317,6 @@ $(eval $(call GluonModelAlias,OM2P,openmesh-om2p,openmesh-om2p-lc))
 
 # OM5P
 $(eval $(call GluonProfile,OM5P,om-watchdog uboot-envtools))
-$(eval $(call GluonProfileSysupgradeSuffix,OM5P,-squashfs-factory,.bin))
 $(eval $(call GluonModel,OM5P,om5p,openmesh-om5p))
 $(eval $(call GluonModelAlias,OM5P,openmesh-om5p,openmesh-om5p-an))