On Fri, May 8, 2020 at 9:37 PM Stephen Smalley <stephen.smalley.work@xxxxxxxxx> wrote: > As per the man page, quotactl(2) expects to be passed a pointer to > a 4-byte buffer for Q_GETFMT. The kernel copies a single u32 value. > On Ubuntu, this was detected as a stack smash when running the test. > Fix the test program. > > Signed-off-by: Stephen Smalley <stephen.smalley.work@xxxxxxxxx> > --- > tests/filesystem/quotas_test.c | 10 +++++----- > 1 file changed, 5 insertions(+), 5 deletions(-) > > diff --git a/tests/filesystem/quotas_test.c b/tests/filesystem/quotas_test.c > index 8359811..1424362 100644 > --- a/tests/filesystem/quotas_test.c > +++ b/tests/filesystem/quotas_test.c > @@ -33,7 +33,7 @@ int main(int argc, char *argv[]) > int opt, result, qcmd, save_err, test_id = geteuid(); > char *context, *src = NULL, *tgt = NULL; > bool verbose = false; > - char fmt_buf[2]; > + unsigned int fmtval; I wish we could use something like uint32_t here to make the size explicit, but that's a C99 thing... OTOH the binder test code already happily uses C99 stuff, so I'm not sure how to best handle this... (Add -std=c99 to CFLAGS? Just use <stdint.h> and assume the compiler has it? Avoid using C99 library features?) > > while ((opt = getopt(argc, argv, "s:t:v")) != -1) { > switch (opt) { > @@ -77,7 +77,7 @@ int main(int argc, char *argv[]) > printf("User Quota - ON\n"); > > qcmd = QCMD(Q_GETFMT, USRQUOTA); > - result = quotactl(qcmd, src, test_id, fmt_buf); > + result = quotactl(qcmd, src, test_id, (caddr_t)&fmtval); > save_err = errno; > if (result < 0) { > fprintf(stderr, "quotactl(Q_GETFMT, USRQUOTA) Failed: %s\n", > @@ -85,7 +85,7 @@ int main(int argc, char *argv[]) > return save_err; > } > if (verbose) > - printf("User Format: 0x%x\n", fmt_buf[0]); > + printf("User Format: 0x%x\n", fmtval); > > qcmd = QCMD(Q_QUOTAOFF, USRQUOTA); > result = quotactl(qcmd, src, QFMT_VFS_V0, tgt); > @@ -113,7 +113,7 @@ int main(int argc, char *argv[]) > printf("Group Quota - ON\n"); > > qcmd = QCMD(Q_GETFMT, GRPQUOTA); > - result = quotactl(qcmd, src, test_id, fmt_buf); > + result = quotactl(qcmd, src, test_id, (caddr_t)&fmtval); > save_err = errno; > if (result < 0) { > fprintf(stderr, "quotactl(Q_GETFMT, GRPQUOTA) Failed: %s\n", > @@ -121,7 +121,7 @@ int main(int argc, char *argv[]) > return save_err; > } > if (verbose) > - printf("Group Format: 0x%x\n", fmt_buf[0]); > + printf("Group Format: 0x%x\n", fmtval); > > qcmd = QCMD(Q_QUOTAOFF, GRPQUOTA); > result = quotactl(qcmd, src, QFMT_VFS_V0, tgt); > -- > 2.23.1 > -- Ondrej Mosnacek <omosnace at redhat dot com> Software Engineer, Security Technologies Red Hat, Inc.