|
@@ -24,6 +24,14 @@ int pkey_initialize(void)
|
|
{
|
|
{
|
|
int os_reserved, i;
|
|
int os_reserved, i;
|
|
|
|
|
|
|
|
+ /*
|
|
|
|
+ * We define PKEY_DISABLE_EXECUTE in addition to the arch-neutral
|
|
|
|
+ * generic defines for PKEY_DISABLE_ACCESS and PKEY_DISABLE_WRITE.
|
|
|
|
+ * Ensure that the bits a distinct.
|
|
|
|
+ */
|
|
|
|
+ BUILD_BUG_ON(PKEY_DISABLE_EXECUTE &
|
|
|
|
+ (PKEY_DISABLE_ACCESS | PKEY_DISABLE_WRITE));
|
|
|
|
+
|
|
/*
|
|
/*
|
|
* Disable the pkey system till everything is in place. A subsequent
|
|
* Disable the pkey system till everything is in place. A subsequent
|
|
* patch will enable it.
|
|
* patch will enable it.
|
|
@@ -177,10 +185,18 @@ int __arch_set_user_pkey_access(struct task_struct *tsk, int pkey,
|
|
unsigned long init_val)
|
|
unsigned long init_val)
|
|
{
|
|
{
|
|
u64 new_amr_bits = 0x0ul;
|
|
u64 new_amr_bits = 0x0ul;
|
|
|
|
+ u64 new_iamr_bits = 0x0ul;
|
|
|
|
|
|
if (!is_pkey_enabled(pkey))
|
|
if (!is_pkey_enabled(pkey))
|
|
return -EINVAL;
|
|
return -EINVAL;
|
|
|
|
|
|
|
|
+ if (init_val & PKEY_DISABLE_EXECUTE) {
|
|
|
|
+ if (!pkey_execute_disable_supported)
|
|
|
|
+ return -EINVAL;
|
|
|
|
+ new_iamr_bits |= IAMR_EX_BIT;
|
|
|
|
+ }
|
|
|
|
+ init_iamr(pkey, new_iamr_bits);
|
|
|
|
+
|
|
/* Set the bits we need in AMR: */
|
|
/* Set the bits we need in AMR: */
|
|
if (init_val & PKEY_DISABLE_ACCESS)
|
|
if (init_val & PKEY_DISABLE_ACCESS)
|
|
new_amr_bits |= AMR_RD_BIT | AMR_WR_BIT;
|
|
new_amr_bits |= AMR_RD_BIT | AMR_WR_BIT;
|