Page MenuHomeFreeBSD

Fix overflow errors in sbttous and sbttoms
ClosedPublic

Authored by asomers on Apr 6 2022, 8:07 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 18, 9:30 PM
Unknown Object (File)
Fri, Jan 17, 11:51 AM
Unknown Object (File)
Fri, Jan 10, 11:16 PM
Unknown Object (File)
Fri, Jan 10, 5:59 AM
Unknown Object (File)
Fri, Jan 10, 5:41 AM
Unknown Object (File)
Fri, Jan 10, 5:41 AM
Unknown Object (File)
Thu, Jan 9, 10:45 PM
Unknown Object (File)
Thu, Jan 9, 10:05 PM
Subscribers
None

Details

Summary

Both of these functions would overflow for very large inputs. Add tests
for them. Also, add tests for the inverse functions, *stosbt, whose
overflow errors were fixed by 4c30b9ecd47.

PR: 263073
MFC after: 1 week
Sponsored by: Axcient

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 45036
Build 41924: arc lint + arc unit

Event Timeline

asomers created this revision.

the sys/sys/time.h stuff looks good and matches what I was planning on (thanks!) and should be a separate commit.
I need to study the test cases a little more, but first blush they look like all the right sorts of tests.
Found one issue with our constant foe: printf format mismatches :)

tests/sys/sys/time_test.c
121

I don't think %ld will work on our 32-bit platforms for the SBT.
And it may be more useful to print it as a hex number.
likewise %ld won't work on int64_t on the 32-bit platforms.

  • 32-bit compatible printf format specifiers

Ping @imp . Do you think you could finish reviewing the tests sometime?

Generally, I like this. Couple of small nits, sorry for the delay.

tests/sys/sys/time_test.c
60

I'd do 4s as well, just to be paranoid.

85

ditto on the 4s here.

110

ditto

134

same comments here, and below, about 4s too.

161

where do these numbers come from? Can they be computed instead?

  • Add 4s tests and make some magic numbers less magical.

I think we're good. Thanks

This revision is now accepted and ready to land.May 9 2022, 9:59 PM
This revision was automatically updated to reflect the committed changes.