]> git.ipfire.org Git - people/ms/linux.git/commit - arch/x86/kernel/cpu/sgx/encl.c
x86/sgx: Mark PCMD page as dirty when modifying contents
authorReinette Chatre <reinette.chatre@intel.com>
Thu, 12 May 2022 21:50:58 +0000 (14:50 -0700)
committerDave Hansen <dave.hansen@linux.intel.com>
Mon, 16 May 2022 22:17:14 +0000 (15:17 -0700)
commit2154e1c11b7080aa19f47160bd26b6f39bbd7824
tree50bc0573dea2972a133b154403f73839ec116d92
parent6bd429643cc265e94a9d19839c771bcc5d008fa8
x86/sgx: Mark PCMD page as dirty when modifying contents

Recent commit 08999b2489b4 ("x86/sgx: Free backing memory
after faulting the enclave page") expanded __sgx_encl_eldu()
to clear an enclave page's PCMD (Paging Crypto MetaData)
from the PCMD page in the backing store after the enclave
page is restored to the enclave.

Since the PCMD page in the backing store is modified the page
should be marked as dirty to ensure the modified data is retained.

Cc: stable@vger.kernel.org
Fixes: 08999b2489b4 ("x86/sgx: Free backing memory after faulting the enclave page")
Signed-off-by: Reinette Chatre <reinette.chatre@intel.com>
Signed-off-by: Dave Hansen <dave.hansen@linux.intel.com>
Reviewed-by: Jarkko Sakkinen <jarkko@kernel.org>
Tested-by: Haitao Huang <haitao.huang@intel.com>
Link: https://lkml.kernel.org/r/00cd2ac480db01058d112e347b32599c1a806bc4.1652389823.git.reinette.chatre@intel.com
arch/x86/kernel/cpu/sgx/encl.c