Page MenuHomeFreeBSD

xdr: store chars consistently
ClosedPublic

Authored by brooks on Jan 9 2023, 7:08 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Oct 18, 11:57 PM
Unknown Object (File)
Sun, Oct 5, 2:52 AM
Unknown Object (File)
Aug 10 2025, 8:44 PM
Unknown Object (File)
Jul 27 2025, 2:16 AM
Unknown Object (File)
Jul 26 2025, 8:48 AM
Unknown Object (File)
Jul 25 2025, 10:06 PM
Unknown Object (File)
Jul 10 2025, 2:47 PM
Unknown Object (File)
Jul 9 2025, 4:19 AM
Subscribers

Details

Summary

Cast char's through unsigned char before storing as an integer in
xdr_char(), this ensures that the encoded form is consistently not
sign-extended following Open Solaris's example.

Prior to this change, platforms with signed chars would sign extend
values with the high bit set but ones without unsigned chars would not
so 0xff would be stored as 0x000000ff on unsigned char platforms and
0xffffffff on signed char platforms. Decoding has the same
result for either form so this is a largely cosmetic change, but it
seems best to produce consistent output.

For more discussion, see https://github.com/openzfs/zfs/issues/14173

Diff Detail

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