blob: e21e09c946172a2d8c284c188bcbf4d0cf4a5f42 [file] [log] [blame]
AKASHI Takahiro077153e2020-10-29 13:47:46 +09001// SPDX-License-Identifier: GPL-2.0+
2/*
3 * String functions
4 *
5 * Copyright (c) 2020 AKASHI Takahiro, Linaro Limited
6 */
7
8#include <common.h>
9#include <charset.h>
Heinrich Schuchardta07ee3c2021-04-21 12:39:15 +020010#include <efi_loader.h>
Paul Barker39434a92022-10-05 13:18:35 +010011#include <malloc.h>
AKASHI Takahiro077153e2020-10-29 13:47:46 +090012
13/**
14 * efi_create_indexed_name - create a string name with an index
15 * @buffer: Buffer
16 * @name: Name string
17 * @index: Index
18 *
19 * Create a utf-16 string with @name, appending @index.
Simon Glass156ccbc2022-01-23 12:55:12 -070020 * For example, u"Capsule0001"
AKASHI Takahiro077153e2020-10-29 13:47:46 +090021 *
22 * The caller must ensure that the buffer has enough space for the resulting
23 * string including the trailing L'\0'.
24 *
25 * Return: A pointer to the next position after the created string
26 * in @buffer, or NULL otherwise
27 */
Ilias Apalodimasfe179d72020-12-31 12:26:46 +020028u16 *efi_create_indexed_name(u16 *buffer, size_t buffer_size, const char *name,
29 unsigned int index)
AKASHI Takahiro077153e2020-10-29 13:47:46 +090030{
31 u16 *p = buffer;
32 char index_buf[5];
Ilias Apalodimasfe179d72020-12-31 12:26:46 +020033 size_t size;
AKASHI Takahiro077153e2020-10-29 13:47:46 +090034
Ilias Apalodimasfe179d72020-12-31 12:26:46 +020035 size = (utf8_utf16_strlen(name) * sizeof(u16) +
36 sizeof(index_buf) * sizeof(u16));
37 if (buffer_size < size)
38 return NULL;
AKASHI Takahiro077153e2020-10-29 13:47:46 +090039 utf8_utf16_strcpy(&p, name);
Ilias Apalodimasfe179d72020-12-31 12:26:46 +020040 snprintf(index_buf, sizeof(index_buf), "%04X", index);
AKASHI Takahiro077153e2020-10-29 13:47:46 +090041 utf8_utf16_strcpy(&p, index_buf);
42
43 return p;
44}
Paul Barker39434a92022-10-05 13:18:35 +010045
46/**
47 * efi_convert_string - Convert an ASCII or UTF-8 string to UTF-16
48 * @str: String to be converted
49 *
50 * Return: Converted string in UTF-16 format. The caller is responsible for
51 * freeing this string when it is no longer needed.
52 */
53efi_string_t efi_convert_string(const char *str)
54{
55 efi_string_t str_16, tmp;
56 size_t sz_16;
57
58 sz_16 = utf8_utf16_strlen(str);
59 str_16 = calloc(sz_16 + 1, sizeof(u16));
60 if (!str_16)
61 return NULL;
62
63 tmp = str_16;
64 utf8_utf16_strcpy(&tmp, str);
65
66 return str_16;
67}