Message ID | 20230712230202.47929-12-haitao.huang@linux.intel.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | Add Cgroup support for SGX EPC memory | expand |
Hi! > From: Sean Christopherson <sean.j.christopherson@intel.com> > > Return the number of reclaimed pages from sgx_reclaim_pages(), the EPC > cgroup will use the result to track the success rate of its reclaim > calls, e.g. to escalate to a more forceful reclaiming mode if > necessary. Subject says x85. While some would love to see support of Linux on Intel 8085, I guess it should be x86. Best regards, Pavel
On Sat Jul 29, 2023 at 12:47 PM UTC, Pavel Machek wrote: > Hi! > > > From: Sean Christopherson <sean.j.christopherson@intel.com> > > > > Return the number of reclaimed pages from sgx_reclaim_pages(), the EPC > > cgroup will use the result to track the success rate of its reclaim > > calls, e.g. to escalate to a more forceful reclaiming mode if > > necessary. > > Subject says x85. While some would love to see support of Linux on > Intel 8085, I guess it should be x86. hmm... that could potentially be also a step towards also to zilog z80 compatibility :-) BR, Jarkko
diff --git a/arch/x86/kernel/cpu/sgx/main.c b/arch/x86/kernel/cpu/sgx/main.c index cd5e5517866a..4fc931156972 100644 --- a/arch/x86/kernel/cpu/sgx/main.c +++ b/arch/x86/kernel/cpu/sgx/main.c @@ -299,15 +299,15 @@ static void sgx_reclaimer_write(struct sgx_epc_page *epc_page, * problematic as it would increase the lock contention too much, which would * halt forward progress. */ -static void sgx_reclaim_pages(int nr_to_scan) +static size_t sgx_reclaim_pages(size_t nr_to_scan) { struct sgx_backing backing[SGX_NR_TO_SCAN_MAX]; struct sgx_epc_page *epc_page, *tmp; struct sgx_encl_page *encl_page; pgoff_t page_index; LIST_HEAD(iso); - int ret; - int i; + size_t ret; + size_t i; spin_lock(&sgx_global_lru.lock); for (i = 0; i < SGX_NR_TO_SCAN; i++) { @@ -333,7 +333,7 @@ static void sgx_reclaim_pages(int nr_to_scan) spin_unlock(&sgx_global_lru.lock); if (list_empty(&iso)) - return; + return 0; i = 0; list_for_each_entry_safe(epc_page, tmp, &iso, list) { @@ -378,6 +378,7 @@ static void sgx_reclaim_pages(int nr_to_scan) sgx_free_epc_page(epc_page); } + return i; } static bool sgx_should_reclaim(unsigned long watermark)