Date: Tue, 11 Aug 2015 18:34:02 +0200 From: Baptiste Daroussin <bapt@freebsd.org> To: Ed Schouten <ed@nuxi.nl> Cc: svn-src-head@freebsd.org, svn-src-all@freebsd.org, src-committers <src-committers@freebsd.org> Subject: Re: svn commit: r286491 - head/lib/libc/locale Message-ID: <20150811163314.GB10390@ivaldir.etoilebsd.net> In-Reply-To: <CABh_MKk7=WRYOF6KKEap_QenWJDGXDh=svv6DYcX0hVxP5XhoQ@mail.gmail.com> References: <201508090006.t7906vbK031238@repo.freebsd.org> <CABh_MKk7=WRYOF6KKEap_QenWJDGXDh=svv6DYcX0hVxP5XhoQ@mail.gmail.com>
next in thread | previous in thread | raw e-mail | index | archive | help
[-- Attachment #1 --]
On Tue, Aug 11, 2015 at 06:28:06PM +0200, Ed Schouten wrote:
> 2015-08-09 2:06 GMT+02:00 Baptiste Daroussin <bapt@freebsd.org>:
> > Per rfc3629 value greater than 0x10ffff should be rejected
>
> Not only that, values between 0xd800 and 0xdfff also need to be rejected:
>
> diff --git a/lib/libc/locale/utf8.c b/lib/libc/locale/utf8.c
> index 55e2931..8ccfdb1 100644
> --- a/lib/libc/locale/utf8.c
> +++ b/lib/libc/locale/utf8.c
> @@ -318,6 +318,10 @@ _UTF8_wcrtomb(char * __restrict s, wchar_t wc,
> mbstate_t * __restrict ps)
> lead = 0xc0;
> len = 2;
> } else if ((wc & ~0xffff) == 0) {
> + if (wc >= 0xd800 && wc <= 0xdfff) {
> + errno = EILSEQ;
> + return ((size_t)-1);
> + }
> lead = 0xe0;
> len = 3;
> } else if (wc >= 0 && wc <= 0x10ffff) {
Good catch please go ahead
Bapt
[-- Attachment #2 --]
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1
iEYEARECAAYFAlXKI/kACgkQ8kTtMUmk6EwOhwCfdFSCi8nWDVRI59hxO4dASTUK
4kcAn3GEXDSOaRZ1Lte6EuAaPWGrz/MF
=xnk5
-----END PGP SIGNATURE-----
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20150811163314.GB10390>
