Page MenuHomeFreeBSD

memcmp.3: clarify return value
ClosedPublic

Authored by emaste on Nov 20 2024, 3:46 PM.
Tags
None
Referenced Files
F133313721: D47683.id146753.diff
Fri, Oct 24, 9:01 PM
Unknown Object (File)
Wed, Oct 22, 7:10 PM
Unknown Object (File)
Sat, Oct 18, 3:53 AM
Unknown Object (File)
Thu, Oct 16, 10:30 PM
Unknown Object (File)
Thu, Oct 16, 5:14 AM
Unknown Object (File)
Fri, Oct 3, 12:29 AM
Unknown Object (File)
Sep 19 2025, 1:10 PM
Unknown Object (File)
Sep 12 2025, 12:09 PM

Details

Summary
The return value is not required to be the difference between the
differing bytes, only less than zero, zero, or greater than zero.

Event:          Kitchener-Waterloo Hackathon 202406

Diff Detail

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

Event Timeline

emaste created this revision.

We have always guaranteed the extended behaviour. I don't believe we should change it nor stop documenting it.
Note that as to my knowledge, arm64 currently does not conform to the extended behaviour. This went undiscovered for a long time due to the absence of any unit test checking the return value. There is a unit test now.

Maybe instead we should document in the STANDARDS section that ISO 9899 and POSIX guarantee just the positive/zero/negative behaviour.

I don't believe we should change it nor stop documenting it.

I disagree: this is a standard C function. If our implementation goes beyond the requirements and FreeBSD developers make use of this it just means that we produce non-portable code. I imagine the reason we did not discover arm64's divergence is primarily because memcmp's return value is really only tested as == 0 or != 0 or < 0 or > 0.

lib/libc/string/memcmp.3
58–66
andrew added inline comments.
lib/libc/string/memcmp.3
48
fuz requested changes to this revision.Nov 20 2024, 4:23 PM

Hard disagree on no longer testing the behaviour; removing it is an API break and we should test the API we ship.

If you don't want to document our extended behaviour, that is debatable. In descending order of preference:

  1. document the behaviour fully, but note that this goes beyond what the standard says
  2. don't mention the extended behaviour in the main body of the man page, but add a note that we guarantee more
  3. don't mention it at all (really not a fan of that)
lib/libc/tests/string/memcmp_test.c
48 ↗(On Diff #146749)

Removing that guarantee from code and unit test is an API break. We should not break the API like that. Removing the documentation is one thing, but breaking the API goes to far in any case. Guaranteeing the extended behaviour is cheap or free in all case I know of and our unit tests should validate that.

This revision now requires changes to proceed.Nov 20 2024, 4:23 PM

Looks good.
Comparisons should always say what is compared with what for clarity.

lib/libc/string/memcmp.3
32

Should be adjust to today on commit.

37
62–66
This revision is now accepted and ready to land.Nov 20 2024, 5:04 PM
This revision was automatically updated to reflect the committed changes.