Page MenuHomeFreeBSD

ifconfig: Pacify a sign comparison warning in regdomain_sort.
ClosedPublic

Authored by jhb on Jun 19 2023, 5:06 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Nov 4, 1:09 AM
Unknown Object (File)
Mon, Nov 4, 1:09 AM
Unknown Object (File)
Mon, Nov 4, 1:08 AM
Unknown Object (File)
Mon, Nov 4, 12:48 AM
Unknown Object (File)
Fri, Oct 25, 5:25 AM
Unknown Object (File)
Oct 1 2024, 7:50 AM
Unknown Object (File)
Oct 1 2024, 7:35 AM
Unknown Object (File)
Oct 1 2024, 5:04 AM
Subscribers

Details

Summary

Both ic_flags values are unsigned (uint32_t), so cast them to a signed
int to generate a signed result. Both ic_req values are also
unsigned, but since they are uint16_t, they are implicitly promited to
int before the subtraction.

Reported by: GCC -Wsign-compare

Diff Detail

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

Event Timeline

I think this is fine and suspect that the actual order is not that important, but I wonder if it would be more clear to make it explicit?

something like

if (ca->ic_freq > cb->ic_freq)
        return 1;
else if (ca->ic_freq < cb->ic_freq)
        return -1;
else if (ca->ic_flags & CHAN_ALL > cb->ic_flags & CHAN_ALL)
...

(signs might be backwards)

This revision is now accepted and ready to land.Jun 19 2023, 5:17 PM

I almost did a broken out version like that, but it is a fair bit more verbose.