]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
efi_loader: fix device path to text protocol
authorHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Sat, 29 Jan 2022 18:01:07 +0000 (19:01 +0100)
committerHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Sat, 5 Feb 2022 19:20:01 +0000 (20:20 +0100)
The printing of a file path node must properly handle:

* odd length of the device path node
* UTF-16 character only partially contained in device path node
* buffer overflow due to very long file path

Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
lib/efi_loader/efi_device_path_to_text.c

index d8a83c8849339ac34aaa603de0ced0ff40b14386..97b3d3e815ea93cef8bdb77640b8bee5005084ce 100644 (file)
@@ -8,6 +8,7 @@
 #include <common.h>
 #include <blk.h>
 #include <efi_loader.h>
+#include <malloc.h>
 
 #define MAC_OUTPUT_LEN 22
 #define UNKNOWN_OUTPUT_LEN 23
@@ -292,10 +293,18 @@ static char *dp_media(char *s, struct efi_device_path *dp)
        case DEVICE_PATH_SUB_TYPE_FILE_PATH: {
                struct efi_device_path_file_path *fp =
                        (struct efi_device_path_file_path *)dp;
-               int slen = (dp->length - sizeof(*dp)) / 2;
-               if (slen > MAX_NODE_LEN - 2)
-                       slen = MAX_NODE_LEN - 2;
-               s += sprintf(s, "%-.*ls", slen, fp->str);
+               u16 *buffer;
+               int slen = dp->length - sizeof(*dp);
+
+               /* two bytes for \0, extra byte if dp->length is odd */
+               buffer = calloc(1, slen + 3);
+               if (!buffer) {
+                       log_err("Out of memory\n");
+                       return s;
+               }
+               memcpy(buffer, fp->str, dp->length - sizeof(*dp));
+               s += snprintf(s, MAX_NODE_LEN - 1, "%ls", buffer);
+               free(buffer);
                break;
        }
        default: