Page MenuHomeFreeBSD

bhyve: Appease warning about a potentially unaligned pointer.
ClosedPublic

Authored by jhb on Nov 23 2022, 11:16 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Dec 4, 2:33 AM
Unknown Object (File)
Sun, Nov 24, 5:57 PM
Unknown Object (File)
Sun, Nov 24, 9:05 AM
Unknown Object (File)
Sat, Nov 23, 10:02 AM
Unknown Object (File)
Fri, Nov 22, 11:43 AM
Unknown Object (File)
Thu, Nov 21, 5:33 PM
Unknown Object (File)
Thu, Nov 21, 4:05 PM
Unknown Object (File)
Thu, Nov 21, 8:06 AM
Subscribers

Details

Summary

When initializing the device model for a PCI pass through device that
uses MSI-X, bhyve reads the MSI-X capability from the real device to
save a copy in the emulated PCI config space. It also saves a copy in
a local struct msixcap on the stack. Since struct msixcap is packed,
GCC complains that casting a pointer to the struct to a uint32_t
pointer may result in an unaligned pointer.

This path is not performance critical, so to appease the compiler,
simply change the pointer to a char * and use memcpy to copy the 4
bytes read in each iteration of the loop.

Diff Detail

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

Event Timeline

jhb requested review of this revision.Nov 23 2022, 11:16 PM

I realize the person from illumos might have had a different fix for this, but I think this might be the cleanest of the options. I tried adding an __Alignas(4) on the local variable and that didn't appease GCC's warning here.

This revision is now accepted and ready to land.Nov 24 2022, 6:38 AM