diff options
| author | millert <> | 2010-06-02 12:58:12 +0000 | 
|---|---|---|
| committer | millert <> | 2010-06-02 12:58:12 +0000 | 
| commit | 718f25c6853b9204ccdaaa6947c90c056989f2bd (patch) | |
| tree | c03791883d555a70beaa5db06d879a58baf62eaa | |
| parent | 9743c2689178c056bcbd01ce76a31f5de0e87e01 (diff) | |
| download | openbsd-718f25c6853b9204ccdaaa6947c90c056989f2bd.tar.gz openbsd-718f25c6853b9204ccdaaa6947c90c056989f2bd.tar.bz2 openbsd-718f25c6853b9204ccdaaa6947c90c056989f2bd.zip | |
Avoid using and end pointer since strnlen(string, -1) is legal
and would otherwise result in overflowing the end pointer and
cause strnlen() to return 0.  OK sthen@
Diffstat (limited to '')
| -rw-r--r-- | src/lib/libc/string/strnlen.c | 7 | 
1 files changed, 3 insertions, 4 deletions
| diff --git a/src/lib/libc/string/strnlen.c b/src/lib/libc/string/strnlen.c index 0c6df381fc..2dc7b4fb32 100644 --- a/src/lib/libc/string/strnlen.c +++ b/src/lib/libc/string/strnlen.c | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | /* $OpenBSD: strnlen.c,v 1.2 2010/05/21 06:57:45 chl Exp $ */ | 1 | /* $OpenBSD: strnlen.c,v 1.3 2010/06/02 12:58:12 millert Exp $ */ | 
| 2 | 2 | ||
| 3 | /* | 3 | /* | 
| 4 | * Copyright (c) 2010 Todd C. Miller <Todd.Miller@courtesan.com> | 4 | * Copyright (c) 2010 Todd C. Miller <Todd.Miller@courtesan.com> | 
| @@ -23,10 +23,9 @@ | |||
| 23 | size_t | 23 | size_t | 
| 24 | strnlen(const char *str, size_t maxlen) | 24 | strnlen(const char *str, size_t maxlen) | 
| 25 | { | 25 | { | 
| 26 | const char *cp, *ep; | 26 | const char *cp; | 
| 27 | 27 | ||
| 28 | ep = str + maxlen; | 28 | for (cp = str; maxlen != 0 && *cp != '\0'; cp++, maxlen--) | 
| 29 | for (cp = str; cp < ep && *cp != '\0'; cp++) | ||
| 30 | ; | 29 | ; | 
| 31 | 30 | ||
| 32 | return (size_t)(cp - str); | 31 | return (size_t)(cp - str); | 
