[PATCH] Return EINVAL for illegal base in strtol
Corinna Vinschen
vinschen@redhat.com
Tue Dec 17 09:09:00 GMT 2019
On Dec 16 13:55, Keith Packard wrote:
> Signed-off-by: Keith Packard <keithp@keithp.com>
> ---
> newlib/libc/stdlib/strtol.c | 9 +++++++--
> 1 file changed, 7 insertions(+), 2 deletions(-)
>
> diff --git a/newlib/libc/stdlib/strtol.c b/newlib/libc/stdlib/strtol.c
> index f7572b169..897890fe0 100644
> --- a/newlib/libc/stdlib/strtol.c
> +++ b/newlib/libc/stdlib/strtol.c
> @@ -140,6 +140,11 @@ _strtol_l (struct _reent *rptr, const char *__restrict nptr,
> register unsigned long cutoff;
> register int neg = 0, any, cutlim;
>
> + if (base < 0 || base == 1 || base > 36) {
> + errno = EINVAL;
> + return 0;
> + }
> +
> /*
> * Skip white space and pick up leading +/- sign if any.
> * If base is 0, allow 0x for hex and 0 for octal, else
> @@ -193,9 +198,9 @@ _strtol_l (struct _reent *rptr, const char *__restrict nptr,
> break;
> if (c >= base)
> break;
> - if (any < 0 || acc > cutoff || (acc == cutoff && c > cutlim))
> + if (any < 0 || acc > cutoff || (acc == cutoff && c > cutlim)) {
> any = -1;
> - else {
> + } else {
> any = 1;
> acc *= base;
> acc += c;
> --
> 2.24.0
Pushed.
Thanks,
Corinna
--
Corinna Vinschen
Cygwin Maintainer
Red Hat
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: not available
URL: <http://sourceware.org/pipermail/newlib/attachments/20191217/8ffc2e37/attachment.sig>
More information about the Newlib
mailing list