diff --git a/target/linux/ar71xx/base-files/lib/upgrade/openmesh.sh b/target/linux/ar71xx/base-files/lib/upgrade/openmesh.sh
index 751d4ac13c488285d50408b6fe3dd7c044535ed1..6085b300a00ffc1bb32d3e6a6b4ed4e155906cd6 100644
--- a/target/linux/ar71xx/base-files/lib/upgrade/openmesh.sh
+++ b/target/linux/ar71xx/base-files/lib/upgrade/openmesh.sh
@@ -42,6 +42,7 @@ platform_check_image_target_openmesh()
 
 	case "$img_board_target" in
 		A60)
+			[ "$board" = "a40" ] && return 0
 			[ "$board" = "a60" ] && return 0
 			echo "Invalid image board target ($img_board_target) for this platform: $board. Use the correct image for this platform"
 			return 1
diff --git a/target/linux/ar71xx/base-files/lib/upgrade/platform.sh b/target/linux/ar71xx/base-files/lib/upgrade/platform.sh
index c65770fd46ab2fc1a501f37a99ac4adf6bc438f3..76273b30e021e8dc99d675b8babdf2c4974b0e7f 100755
--- a/target/linux/ar71xx/base-files/lib/upgrade/platform.sh
+++ b/target/linux/ar71xx/base-files/lib/upgrade/platform.sh
@@ -498,6 +498,7 @@ platform_check_image() {
 		tplink_pharos_check_image "$1" && return 0
 		return 1
 		;;
+	a40|\
 	a60|\
 	mr1750v2|\
 	mr1750|\
@@ -678,6 +679,7 @@ platform_do_upgrade() {
 	tew-673gru)
 		platform_do_upgrade_dir825b "$ARGV"
 		;;
+	a40|\
 	a60|\
 	mr1750v2|\
 	mr1750|\