On Fri, Oct 25, 2024 at 10:24:41AM +0200, Kevin Brodsky wrote:
On 24/10/2024 18:19, Dave Martin wrote:
On Thu, Oct 24, 2024 at 04:42:10PM +0100, Catalin Marinas wrote:
On Thu, Oct 24, 2024 at 04:55:48PM +0200, Kevin Brodsky wrote:
On 24/10/2024 12:59, Catalin Marinas wrote:
On Wed, Oct 23, 2024 at 04:05:09PM +0100, Kevin Brodsky wrote:
+/*
- Save the unpriv access state into ua_state and reset it to disable any
- restrictions.
- */
+static void save_reset_user_access_state(struct user_access_state *ua_state) +{
- if (system_supports_poe()) {
/*
* Enable all permissions in all 8 keys
* (inspired by REPEAT_BYTE())
*/
u64 por_enable_all = (~0u / POE_MASK) * POE_RXW;
I think this should be ~0ul.
It is ~0u on purpose, because unlike in REPEAT_BYTE(), I only wanted the lower 32 bits to be filled with POE_RXW (we only have 8 keys, the top 32 bits are RES0). That said, given that D128 has 4-bit pkeys, we could anticipate and fill the top 32 bits too (should make no difference on D64).
I guess we could leave it as 32-bit for now and remember to update it when we enable more keys with D128. Setting the top RES0 bits doesn't hurt either since they are already documented in the Arm ARM. Up to you, it's fine like above as well.
Can we maybe just have a brute-force loop that constructs the value using the appropriate #define macros?
The compiler will const-fold it; I'd be prepared to bet that the generated code would be identical...
Fine by me, I suppose I was too eager to use the one-liner I had found :) Building that value based on arch_max_pkey() is probably a better idea in the long run. (And indeed the codegen is the same, it boils down to a mov w0, #0x77777777 in both case.)
The one-line was a neat trick (after the brief WTF moment) :)
I guess my uneasiness comes from baking the number of pkeys in via the type of 0u and an implicit relationship that this happens to have with the number bits per pkey in the POR.
[...]
Cheers ---Dave