Page MenuHomeFreeBSD

Copy flags over ifr_union directly rather than via casts through ifr_data.
ClosedPublic

Authored by brooks on Mar 27 2018, 7:04 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Apr 19, 1:48 PM
Unknown Object (File)
Mon, Apr 14, 8:30 AM
Unknown Object (File)
Mon, Apr 14, 4:07 AM
Unknown Object (File)
Mon, Apr 14, 12:39 AM
Unknown Object (File)
Mon, Apr 14, 12:02 AM
Unknown Object (File)
Sat, Apr 12, 5:58 PM
Unknown Object (File)
Feb 24 2025, 10:27 AM
Unknown Object (File)
Jan 24 2025, 12:24 AM
Subscribers

Details

Summary

No functional change. If the sbni driver supported 64-bit big-endian
system, this would be an ABI changes, but it is i386-only. The old version
also leaked a word of stack on 64-bit systems.

This eliminates the only assignment to ifr_data.

Diff Detail

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

Event Timeline

An alternative approach might be to add an char ifru_bytes[sizeof(struct sockaddr)] to ifreq's union and target that.

kib added inline comments.
sys/dev/sbni/if_sbni.c
1147 ↗(On Diff #40816)

I think this leaks a word of stack on 64bit machines.

This revision is now accepted and ready to land.Mar 27 2018, 8:23 PM
sys/dev/sbni/if_sbni.c
1147 ↗(On Diff #40816)

ioctl handles this for us because it copied in the whole ifreq in sys_ioctl().

sys/dev/sbni/if_sbni.c
1147 ↗(On Diff #40816)

No, you are right. The old one does.

This revision was automatically updated to reflect the committed changes.