[PATCH 1/6] charset: Add support for calculating bytes occupied by a u16 string
Heinrich Schuchardt
xypron.glpk at gmx.de
Sat May 9 08:44:39 CEST 2020
On 5/6/20 9:12 PM, Ilias Apalodimas wrote:
> From: Sughosh Ganu <sughosh.ganu at linaro.org>
>
> The current code uses 'u16_strlen(x) + 1) * sizeof(u16)' in various
> places to calculate the number of bytes occupied by a u16 string.
> Let's introduce a wrapper around this. This wrapper is used on following
> patches
>
> Signed-off-by: Sughosh Ganu <sughosh.ganu at linaro.org>
> ---
> include/charset.h | 11 +++++++++++
> lib/charset.c | 5 +++++
> 2 files changed, 16 insertions(+)
>
> diff --git a/include/charset.h b/include/charset.h
> index fde6bddbc2fb..30faa72285e6 100644
> --- a/include/charset.h
> +++ b/include/charset.h
> @@ -195,6 +195,17 @@ int u16_strncmp(const u16 *s1, const u16 *s2, size_t n);
> */
> size_t u16_strlen(const void *in);
>
> +/**
> + * u16_strsize - count size of u16 string in bytes including the null character
Parentheses missing, cf.
https://www.kernel.org/doc/html/latest/doc-guide/kernel-doc.html#function-documentation
A test in test/unicode_ut.c is missing for the function.
I will add both.
Otherwise
Reviewed-by: Heinrich Schuchardt <xypron.glpk at gmx.de>
> + *
> + * Counts the number of bytes occupied by a u16 string
> + *
> + * @in: null terminated u16 string
> + * Return: bytes in a u16 string
> + *
> + */
> +size_t u16_strsize(const void *in);
> +
> /**
> * u16_strlen - count non-zero words
> *
> diff --git a/lib/charset.c b/lib/charset.c
> index 1c6a7f693de4..a28034ee1f1e 100644
> --- a/lib/charset.c
> +++ b/lib/charset.c
> @@ -379,6 +379,11 @@ size_t u16_strnlen(const u16 *in, size_t count)
> return i;
> }
>
> +size_t u16_strsize(const void *in)
> +{
> + return (u16_strlen(in) + 1) * sizeof(u16);
> +}
> +
> u16 *u16_strcpy(u16 *dest, const u16 *src)
> {
> u16 *tmp = dest;
>
More information about the U-Boot
mailing list