diff options
author | Rich Felker <dalias@aerifal.cx> | 2011-04-06 12:35:05 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2011-04-06 12:35:05 -0400 |
commit | 6b87e941f932a93120383de33f5237395fc1354a (patch) | |
tree | 03505ce053cb81f85493977dd681db728e2a71b6 /src | |
parent | a113434cd68ce30642c4995b1caadcd084be6f09 (diff) | |
download | musl-6b87e941f932a93120383de33f5237395fc1354a.tar.gz musl-6b87e941f932a93120383de33f5237395fc1354a.tar.bz2 musl-6b87e941f932a93120383de33f5237395fc1354a.tar.xz musl-6b87e941f932a93120383de33f5237395fc1354a.zip |
fix completely bogus loop condition in getmntent_r
somehow this worked on my simple fstab, but horribly broke in general,
leading to use of uninitialized offset array and crashes.
Diffstat (limited to 'src')
-rw-r--r-- | src/linux/mntent.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/src/linux/mntent.c b/src/linux/mntent.c index 26d045c2..48c85bd6 100644 --- a/src/linux/mntent.c +++ b/src/linux/mntent.c @@ -26,7 +26,7 @@ struct mntent *getmntent_r(FILE *f, struct mntent *mnt, char *linebuf, int bufle cnt = sscanf(linebuf, " %n%*s%n %n%*s%n %n%*s%n %n%*s%n %d %d", n, n+1, n+2, n+3, n+4, n+5, n+6, n+7, &mnt->mnt_freq, &mnt->mnt_passno); - } while (cnt >= 8 && linebuf[n[0]] != '#'); + } while (cnt < 2 || linebuf[n[0]] == '#'); linebuf[n[1]] = 0; linebuf[n[3]] = 0; |