]> git.ipfire.org Git - thirdparty/grub.git/commitdiff
efi: Add grub_efi_set_variable_to_string()
authorOliver Steffen <osteffen@redhat.com>
Fri, 26 May 2023 11:35:48 +0000 (13:35 +0200)
committerDaniel Kiper <daniel.kiper@oracle.com>
Thu, 1 Jun 2023 09:45:00 +0000 (11:45 +0200)
Add a function that sets an EFI variable to a string value.
The string is converted from UTF-8 to UTF-16.

Signed-off-by: Oliver Steffen <osteffen@redhat.com>
Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
grub-core/kern/efi/efi.c
include/grub/efi/efi.h

index bd3b125a4e595361ec4f61e850f41b166bdd2594..f54fdcacd9b0a9c450f9c69f0deba4b7d34d9943 100644 (file)
@@ -286,6 +286,28 @@ grub_efi_get_variable_with_attributes (const char *var,
   return status;
 }
 
+grub_err_t
+grub_efi_set_variable_to_string (const char *name, const grub_guid_t *guid,
+                                const char *value, grub_efi_uint32_t attributes)
+{
+  grub_efi_char16_t *value_16;
+  grub_ssize_t len16;
+  grub_err_t status;
+
+  len16 = grub_utf8_to_utf16_alloc (value, &value_16, NULL);
+
+  if (len16 < 0)
+    return grub_errno;
+
+  status = grub_efi_set_variable_with_attributes (name, guid,
+                       (void *) value_16, (len16 + 1) * sizeof (value_16[0]),
+                       attributes);
+
+  grub_free (value_16);
+
+  return status;
+}
+
 grub_efi_status_t
 grub_efi_get_variable (const char *var, const grub_guid_t *guid,
                       grub_size_t *datasize_out, void **data_out)
index 3d056a0a45b52958bb819e58b76435067dbfb798..cd977cbbcfb08bb4ad8653bd2f1a5c7cdfd7870f 100644 (file)
@@ -108,6 +108,9 @@ EXPORT_FUNC (grub_efi_set_variable) (const char *var,
                                     const grub_guid_t *guid,
                                     void *data,
                                     grub_size_t datasize);
+grub_err_t
+EXPORT_FUNC (grub_efi_set_variable_to_string) (const char *name, const grub_guid_t *guid,
+                                              const char *value, grub_efi_uint32_t attributes);
 int
 EXPORT_FUNC (grub_efi_compare_device_paths) (const grub_efi_device_path_t *dp1,
                                             const grub_efi_device_path_t *dp2);