Page MenuHomeFreeBSD

libpmcstat: Fix a few ARM-specific issues with function symbols.
ClosedPublic

Authored by jhb on Mar 2 2022, 11:07 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 2, 9:57 AM
Unknown Object (File)
Nov 29 2024, 9:36 AM
Unknown Object (File)
Nov 24 2024, 4:33 AM
Unknown Object (File)
Nov 23 2024, 11:42 AM
Unknown Object (File)
Nov 21 2024, 4:28 AM
Unknown Object (File)
Nov 20 2024, 5:43 AM
Unknown Object (File)
Nov 6 2024, 9:14 PM
Unknown Object (File)
Oct 29 2024, 12:53 PM
Subscribers

Details

Summary
  • Refine the checks for ARM mapping symbols and apply them on arm64 as well as 32-bit arm. In particular, mapping symbols can have additional characters and are not strictly limited to just "$a" but can append additional characters (e.g. "$a.1"). Add "$x" to the list of mapping symbol prefixes.
  • Clear the LSB of function symbol addresses. Thumb function addresses set the LSB to enable Thumb mode. However, the actual function starts at the aligned address with LSB clear. Not clearing the LSB can cause pmcannotate to pass misaligned addresses to objdump when extracting disassembly.

Obtained from: CheriBSD
Sponsored by: University of Cambridge, Google, Inc.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 44620
Build 41508: arc lint + arc unit

Event Timeline

jhb requested review of this revision.Mar 2 2022, 11:07 PM
jhb created this revision.

I actually tested this on Morello which also sets the LSB to enable capability decoding mode similar to Thumb rather than Thumb. Morello also adds an additional type of mapping symbol ($c.<mumble>).

This revision is now accepted and ready to land.Mar 7 2022, 4:07 PM