diff options
author | Rich Felker <dalias@aerifal.cx> | 2013-02-20 22:58:46 -0500 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2013-02-20 22:58:46 -0500 |
commit | 8d2f8064aa3d2cc7380c447dfbd8929543f36f51 (patch) | |
tree | cb24d2ba08c2eed9f8dd8f38c8c9d265d34ae9eb | |
parent | 3b00675bf51aef47705d8845de24dec8c6063078 (diff) | |
download | musl-8d2f8064aa3d2cc7380c447dfbd8929543f36f51.tar.gz musl-8d2f8064aa3d2cc7380c447dfbd8929543f36f51.tar.bz2 musl-8d2f8064aa3d2cc7380c447dfbd8929543f36f51.tar.xz musl-8d2f8064aa3d2cc7380c447dfbd8929543f36f51.zip |
fix error cases in mkostemps core
1. wrong return value and missing errno for negative suffix len
2. failure to catch suffix len > strlen
3. remove unwanted clearing of input string in invalid case
-rw-r--r-- | src/temp/mkostemps.c | 9 |
1 files changed, 3 insertions, 6 deletions
diff --git a/src/temp/mkostemps.c b/src/temp/mkostemps.c index 804a5475..d87d4b66 100644 --- a/src/temp/mkostemps.c +++ b/src/temp/mkostemps.c @@ -9,18 +9,15 @@ char *__randname(char *); int __mkostemps(char *template, int len, int flags) { - if (len < 0) return EINVAL; - - size_t l = strlen(template)-len; - if (l < 6 || strncmp(template+l-6, "XXXXXX", 6)) { + size_t l = strlen(template); + if (l<6 || len>l-6 || strncmp(template+l-len-6, "XXXXXX", 6)) { errno = EINVAL; - *template = 0; return -1; } int fd, retries = 100; while (retries--) { - __randname(template+l-6); + __randname(template+l-len-6); if ((fd = open(template, flags | O_RDWR | O_CREAT | O_EXCL, 0600))>=0) return fd; if (errno != EEXIST) return -1; |