On Thu, Nov 01, 2018 at 07:10:59AM +0100, Heinrich Schuchardt wrote:
> On 11/01/2018 05:45 AM, AKASHI Takahiro wrote:
> > From: "Akashi Takahiro" <takahiro.aka...@linaro.org>
> > 
> > Add u16_strcpy() and u16_strdup(). The latter function will be
> > used later in implementing efi HII database protocol.
> > 
> > Signed-off-by: Akashi Takahiro <takahiro.aka...@linaro.org>
> > ---
> >  include/charset.h | 18 ++++++++++++++++++
> >  lib/charset.c     | 29 +++++++++++++++++++++++++++++
> >  2 files changed, 47 insertions(+)
> > 
> > diff --git a/include/charset.h b/include/charset.h
> > index 4d45e246e515..5807f02b1a04 100644
> > --- a/include/charset.h
> > +++ b/include/charset.h
> > @@ -191,6 +191,24 @@ size_t u16_strlen(const u16 *in);
> >   */
> >  size_t u16_strnlen(const u16 *in, size_t count);
> >  
> > +/* TODO: add descriptions */
> 
> You could use the descriptions below.

Thanks. Actually I forgot to delete this line :)
I will take your description anyway.

-Takahiro Akashi

> > +/**
> > + * u16_strcpy() - copy u16 string
> 
> Copy u16 string pointed to by src, including terminating null word, to
> the buffer pointed to by dest.
> 
> > + *
> > + * @dest:          destination buffer
> > + * @src:           source buffer (null terminated)
> > + * Return:         'dest' address
> > + */
> > +u16 *u16_strcpy(u16 *dest, const u16 *src);
> > +
> > +/**
> > + * u16_strdup() - duplicate u16 string
> 
> Copy u16 string pointed to by src, including terminating null word, to a
> newly allocated buffer.
> 
> > + *
> > + * @src:           source buffer (null terminated)
> > + * Return:         allocated new buffer on success, NULL on failure
> > + */
> > +u16 *u16_strdup(const u16 *src);
> > +
> >  /**
> >   * utf16_to_utf8() - Convert an utf16 string to utf8
> >   *
> > diff --git a/lib/charset.c b/lib/charset.c
> > index 10557b9e753d..5e349ed5ee45 100644
> > --- a/lib/charset.c
> > +++ b/lib/charset.c
> > @@ -349,6 +349,35 @@ size_t u16_strnlen(const u16 *in, size_t count)
> >     return i;
> >  }
> >  
> > +u16 *u16_strcpy(u16 *dest, const u16 *src)
> > +{
> > +   u16 *tmp = dest;
> > +
> > +   for (;; dest++, src++) {
> > +           *dest = *src;
> > +           if (!*src)
> > +                   break;
> > +   }
> > +
> > +   return tmp;
> > +}
> > +
> > +u16 *u16_strdup(const u16 *src)
> > +{
> > +   u16 *new;
> > +
> > +   if (!src)
> > +           return NULL;
> > +
> > +   new = malloc((u16_strlen(src) + 1) * sizeof(u16));
> > +   if (!new)
> > +           return NULL;
> > +
> > +   u16_strcpy(new, src);
> > +
> > +   return new;
> > +}
> > +
> >  /* Convert UTF-16 to UTF-8.  */
> >  uint8_t *utf16_to_utf8(uint8_t *dest, const uint16_t *src, size_t size)
> >  {
> > 
> 
> For everything I added to charset.c I implemented tests in
> test/unicode_ut.c.
> 
> Reviewed-by: Heinrich Schuchardt <xypron.g...@gmx.de>
_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
https://lists.denx.de/listinfo/u-boot

Reply via email to