diff options
| author | dtucker <> | 2016-10-14 18:19:04 +0000 | 
|---|---|---|
| committer | dtucker <> | 2016-10-14 18:19:04 +0000 | 
| commit | 334be4776e9619a5a075173d94155d509f240f3e (patch) | |
| tree | b6389db570c445961bdaf8c657dc9a09b80b453a /src/lib/libc/string/strlcat.c | |
| parent | b91ed378098865291de996196ca6343ea7bff8f9 (diff) | |
| download | openbsd-334be4776e9619a5a075173d94155d509f240f3e.tar.gz openbsd-334be4776e9619a5a075173d94155d509f240f3e.tar.bz2 openbsd-334be4776e9619a5a075173d94155d509f240f3e.zip  | |
Cast pointers to uintptr_t to avoid potential signedness errors.
Based on patch from yuanjie.huang at windriver.com via OpenSSH bz#2608,
with & ok millert, ok deraadt.
Diffstat (limited to '')
| -rw-r--r-- | src/lib/libc/string/strlcat.c | 12 | 
1 files changed, 9 insertions, 3 deletions
diff --git a/src/lib/libc/string/strlcat.c b/src/lib/libc/string/strlcat.c index 073b0d4259..410f448b56 100644 --- a/src/lib/libc/string/strlcat.c +++ b/src/lib/libc/string/strlcat.c  | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | /* $OpenBSD: strlcat.c,v 1.16 2015/08/31 02:53:57 guenther Exp $ */ | 1 | /* $OpenBSD: strlcat.c,v 1.17 2016/10/14 18:19:04 dtucker Exp $ */ | 
| 2 | 2 | ||
| 3 | /* | 3 | /* | 
| 4 | * Copyright (c) 1998, 2015 Todd C. Miller <Todd.Miller@courtesan.com> | 4 | * Copyright (c) 1998, 2015 Todd C. Miller <Todd.Miller@courtesan.com> | 
| @@ -18,6 +18,7 @@ | |||
| 18 | 18 | ||
| 19 | #include <sys/types.h> | 19 | #include <sys/types.h> | 
| 20 | #include <string.h> | 20 | #include <string.h> | 
| 21 | #include <stdint.h> | ||
| 21 | 22 | ||
| 22 | /* | 23 | /* | 
| 23 | * Appends src to string dst of size dsize (unlike strncat, dsize is the | 24 | * Appends src to string dst of size dsize (unlike strncat, dsize is the | 
| @@ -37,7 +38,7 @@ strlcat(char *dst, const char *src, size_t dsize) | |||
| 37 | /* Find the end of dst and adjust bytes left but don't go past end. */ | 38 | /* Find the end of dst and adjust bytes left but don't go past end. */ | 
| 38 | while (n-- != 0 && *dst != '\0') | 39 | while (n-- != 0 && *dst != '\0') | 
| 39 | dst++; | 40 | dst++; | 
| 40 | dlen = dst - odst; | 41 | dlen = (uintptr_t)dst - (uintptr_t)odst; | 
| 41 | n = dsize - dlen; | 42 | n = dsize - dlen; | 
| 42 | 43 | ||
| 43 | if (n-- == 0) | 44 | if (n-- == 0) | 
| @@ -51,6 +52,11 @@ strlcat(char *dst, const char *src, size_t dsize) | |||
| 51 | } | 52 | } | 
| 52 | *dst = '\0'; | 53 | *dst = '\0'; | 
| 53 | 54 | ||
| 54 | return(dlen + (src - osrc)); /* count does not include NUL */ | 55 | /* | 
| 56 | * Cast pointers to unsigned type before calculation, to avoid signed | ||
| 57 | * overflow when the string ends where the MSB has changed. | ||
| 58 | * Return value does not include NUL. | ||
| 59 | */ | ||
| 60 | return (dlen + ((uintptr_t)src - (uintptr_t)osrc)); | ||
| 55 | } | 61 | } | 
| 56 | DEF_WEAK(strlcat); | 62 | DEF_WEAK(strlcat); | 
