Page MenuHomeFreeBSD

ifconfig: fix endianness bug displaying pfsync interfaces
ClosedPublic

Authored by asomers on Jan 28 2019, 4:48 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jun 8, 5:54 PM
Unknown Object (File)
May 17 2024, 5:52 PM
Unknown Object (File)
May 17 2024, 4:41 PM
Unknown Object (File)
May 7 2024, 10:01 AM
Unknown Object (File)
Apr 26 2024, 5:43 AM
Unknown Object (File)
Apr 20 2024, 3:22 AM
Unknown Object (File)
Apr 9 2024, 5:56 AM
Unknown Object (File)
Apr 8 2024, 3:31 PM
Subscribers

Details

Summary

ifconfig: fix endianness bug displaying pfsync interfaces

Test Plan

ifconfig tun0 create
kldload pfsync
ifconfig pfsync syncdev tun0
ifconfig pfsync0 # Verify that peer address doesn't display

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

kp added inline comments.
sbin/ifconfig/ifpfsync.c
198 ↗(On Diff #53316)

I think that needs to be 'htonl()'.

It'll work of course, but INADDR_PFSYNC_GROUP is in host byte order, and preq.pfsyncr_syncpeer.s_addr is in network order, so you want to go from host to network order, and not the other way around.

sbin/ifconfig/ifpfsync.c
198 ↗(On Diff #53316)

Oh, my mistake. I saw the definition and read it as a byte array, ignoring the leading (in_addr_t)

#define INADDR_PFSYNC_GROUP     ((in_addr_t)0xe00000f0) /* 224.0.0.240 */
This revision is now accepted and ready to land.Jan 28 2019, 5:44 PM
This revision was automatically updated to reflect the committed changes.