Page MenuHomeFreeBSD

libc: fix WRONLY/RDONLY test in fmemopen
ClosedPublic

Authored by emaste on Oct 23 2024, 1:43 PM.
Tags
None
Referenced Files
F107371709: D47265.id145394.diff
Mon, Jan 13, 5:04 AM
F107371118: D47265.id145386.diff
Mon, Jan 13, 4:50 AM
F107368739: D47265.id145393.diff
Mon, Jan 13, 3:54 AM
F107357144: D47265.id.diff
Mon, Jan 13, 12:00 AM
Unknown Object (File)
Sun, Jan 12, 8:56 PM
Unknown Object (File)
Sun, Jan 12, 6:49 PM
Unknown Object (File)
Sat, Jan 11, 8:00 PM
Unknown Object (File)
Sat, Jan 11, 8:00 PM
Subscribers

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

emaste created this revision.
This revision is now accepted and ready to land.Oct 23 2024, 3:28 PM
fuz requested changes to this revision.Oct 23 2024, 3:35 PM
fuz added a subscriber: fuz.

Code should account for O_RDWR case.
The earlier test if (!(flags & O_RDWR) && buf == NULL) in the same file fmemopen.c is also dubious and should be adjusted similarly.
Test should also check a read/write mode like "r+" or "w+".

lib/libc/stdio/fmemopen.c
141

What happens if fmemopen() is called with mode "r+" or "w+", yielding (flags & O_ACCMODE) == O_RDWR?

This revision now requires changes to proceed.Oct 23 2024, 3:35 PM
lib/libc/stdio/fmemopen.c
141

oops, that's a nice catch.

lib/libc/stdio/fmemopen.c
141

Then both tests are false and we use fmemopen_read and fmemopen_write?

lib/libc/stdio/fmemopen.c
141

yep, that sounds correct.

r+ and w+ are implicitly tested in other test cases; I'm not sure we need to duplicate that (but could add a comment).

add a comment, fix another case reported by @fuz (that worked by accident, as it turns out)

This revision is now accepted and ready to land.Oct 23 2024, 4:28 PM
This revision was automatically updated to reflect the committed changes.
jrtc27 added inline comments.
lib/libc/tests/stdio/fmemopen2_test.c
298

as above