Page MenuHomeFreeBSD

Teach DTrace that unaligned accesses are allowed on aarch64, not just x86.
ClosedPublic

Authored by rwatson on Mar 22 2021, 1:51 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 18, 5:13 PM
Unknown Object (File)
Sat, Jan 18, 5:07 PM
Unknown Object (File)
Sun, Jan 12, 6:40 PM
Unknown Object (File)
Sun, Jan 12, 1:56 PM
Unknown Object (File)
Dec 3 2024, 2:29 PM
Unknown Object (File)
Dec 2 2024, 11:54 AM
Unknown Object (File)
Nov 15 2024, 3:52 PM
Unknown Object (File)
Nov 12 2024, 8:18 PM

Diff Detail

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

Event Timeline

I wonder if we should be checking for __NO_STRICT_ALIGNMENT (and defining it for architectures other than x86)

I wonder if we should be checking for __NO_STRICT_ALIGNMENT (and defining it for architectures other than x86)

Hmm. I didn't know that existed.

I think it is the right goal, but I don't think we should aim for it in this patch. Not least, I'm not easily set up to test the various other cases covered by that define currently.

This revision is now accepted and ready to land.Mar 22 2021, 1:42 PM

I wonder if we should be checking for __NO_STRICT_ALIGNMENT (and defining it for architectures other than x86)

Hmm. I didn't know that existed.

I think it is the right goal, but I don't think we should aim for it in this patch. Not least, I'm not easily set up to test the various other cases covered by that define currently.

Note that the architecture must be truly totally alignment-agnostic for __NO_STRICT_ALIGNMENT to work. If aarch64 still has restrictions on some instructions (such as ldm/stm) the compiler may generate those for accessing network data in unaligned packet headers (I ran into this on arm32, where ipv6 address accesses got optimized into ldm instructions to load all 16 bytes at once).