dediprog: Try to request 32B device string (instead of 16B)

It looks like `dpcmd' first tries 26B, then 32B. However, older devices
return only 16B.  We get a short, but otherwise valid transfer, so only
try once with 32B and allow any string length between 16B and 32B.

This allows to read the full version string from newer programmers. It
includes a hardware version now, probably since the first SF600.

Tested with "SF600PG2. V:01.01.012 HW:01.00".
Tested with "SF100   V:5.1.9".

Change-Id: Id137e4cfe3e1dbffb71ab4b16482822661117e39
Signed-off-by: Nico Huber <nico.h@gmx.de>
Reviewed-on: https://review.sourcearcade.org/c/flashprog/+/91
Reviewed-by: Arthur Heymans <arthur@aheymans.xyz>
diff --git a/dediprog.c b/dediprog.c
index 8337166..0d474f9 100644
--- a/dediprog.c
+++ b/dediprog.c
@@ -813,17 +813,17 @@
 
 static int dediprog_check_devicestring(struct dediprog_data *dp_data)
 {
-	const int devstr_len = 16;
+	const int devstr_len = 32, old_devstr_len = 16;
 	char buf[devstr_len + 1];
 	int ret;
 
 	/* Command Receive Device String. */
 	ret = dediprog_read(dp_data->handle, CMD_READ_PROG_INFO, 0, 0, (uint8_t *)buf, devstr_len);
-	if (ret != devstr_len) {
+	if (ret < old_devstr_len || ret > devstr_len) {
 		msg_perr("Incomplete/failed Command Receive Device String!\n");
 		return 1;
 	}
-	buf[devstr_len] = '\0';
+	buf[ret] = '\0';
 	msg_pdbg("Found a %s\n", buf);
 	if (memcmp(buf, "SF100", 5) == 0)
 		dp_data->devicetype = DEV_SF100;