altos: Deal with 8-character version numbers
authorKeith Packard <keithp@keithp.com>
Sat, 19 Feb 2022 23:35:31 +0000 (15:35 -0800)
committerKeith Packard <keithp@keithp.com>
Sat, 19 Feb 2022 23:38:23 +0000 (15:38 -0800)
With 8 characters, the version number isn't null-terminated, so we
need to limit use to the available length in a couple of places.

Signed-off-by: Keith Packard <keithp@keithp.com>
src/kernel/ao_cmd.c
src/product/ao_flash_task.c

index cbee3cd5109cae00f10343519dd7e08540fdc27a..d8ba8372f5d0e308109ad6bd17c84a1a7c0d4541 100644 (file)
@@ -270,6 +270,8 @@ ao_reboot(void)
 #endif
 
 #if HAS_VERSION
+#define _stringify(x) #x
+#define stringify(x) _stringify(x)
 static void
 version(void)
 {
@@ -307,7 +309,7 @@ version(void)
               , (unsigned) ((uint32_t) AO_BOOT_APPLICATION_BOUND - (uint32_t) AO_BOOT_APPLICATION_BASE)
 #endif
                );
-       printf("software-version %s\n", ao_version);
+       printf("software-version %." stringify(AO_MAX_VERSION) "s\n", ao_version);
 }
 #endif
 
index 8ae9b2e5d3fe4b26a4680ee519cbee4911ec02d4..a1daf06a70f9da1514565e329cec8daa538aaaec 100644 (file)
@@ -29,17 +29,26 @@ ao_panic(uint8_t reason)
        for (;;);
 }
 
-void
-ao_put_string(const char *s)
+static void
+ao_put_stringn(const char *s, int max)
 {
        char    c;
-       while ((c = *s++)) {
+       while (max--) {
+               c = *s++;
+               if (!c)
+                       break;
                if (c == '\n')
                        ao_usb_putchar('\r');
                ao_usb_putchar(c);
        }
 }
 
+void
+ao_put_string(const char *s)
+{
+       ao_put_stringn(s, 65535);
+}
+
 static void
 ao_application(void)
 {
@@ -149,7 +158,7 @@ ao_show_version(void)
        ao_put_hex((uint32_t) AO_BOOT_APPLICATION_BASE);
        ao_usb_putchar(' ');
        ao_put_hex((uint32_t) AO_BOOT_APPLICATION_BOUND);
-       ao_put_string("\nsoftware-version "); ao_put_string(ao_version);
+       ao_put_string("\nsoftware-version "); ao_put_stringn(ao_version, AO_MAX_VERSION);
        ao_put_string("\n");
 }