[lldb] Remove non-address bits from addresses given to memory tag commands
authorDavid Spickett <david.spickett@linaro.org>
Wed, 12 Jan 2022 14:55:31 +0000 (14:55 +0000)
committerDavid Spickett <david.spickett@linaro.org>
Thu, 20 Jan 2022 10:48:14 +0000 (10:48 +0000)
commit787f91b0bb34abeca86ad5c8a60ef044a7942996
treefd034590b4542267c4d17f48c303dd9afa91079c
parent585abe3ba506e410b382f8130f72b9368573a781
[lldb] Remove non-address bits from addresses given to memory tag commands

Although the memory tag commands use a memory tag manager to handle
addresses, that only removes the top byte.

That top byte is 4 bits of memory tag and 4 free bits, which is more
than it should strictly remove but that's how it is for now.

There are other non-address bit uses like pointer authentication.
To ensure the memory tag manager only has to deal with memory tags,
use the ABI plugin to remove the rest.

The tag access test has been updated to sign all the relevant pointers
and require that we're running on a system with pointer authentication
in addition to memory tagging.

The pointers will look like:
<4 bit user tag><4 bit memory tag><signature><bit virtual address>

Note that there is currently no API for reading memory tags. It will
also have to consider this when it arrives.

Reviewed By: omjavaid

Differential Revision: https://reviews.llvm.org/D117672
lldb/source/Commands/CommandObjectMemoryTag.cpp
lldb/test/API/linux/aarch64/mte_tag_access/TestAArch64LinuxMTEMemoryTagAccess.py
lldb/test/API/linux/aarch64/mte_tag_access/main.c