public inbox for cgroups@vger.kernel.org
 help / color / mirror / Atom feed
From: Haitao Huang <haitao.huang-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
To: jarkko-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org,
	dave.hansen-VuQAYsv1563Yd54FQh9/CA@public.gmane.org,
	tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org,
	linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	linux-sgx-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	x86-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org,
	cgroups-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	tglx-hfZtesqFncYOwBW4kG4KsQ@public.gmane.org,
	mingo-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org,
	bp-Gina5bIWoIWzQB+pC5nmwQ@public.gmane.org,
	hpa-YMNOUZJC4hwAvxtiuMwx3w@public.gmane.org,
	sohil.mehta-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org
Cc: zhiquan1.li-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org,
	kristen-VuQAYsv1563Yd54FQh9/CA@public.gmane.org,
	seanjc-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org,
	zhanb-0li6OtcxBFHby3iVrkZq2A@public.gmane.org,
	anakrish-0li6OtcxBFHby3iVrkZq2A@public.gmane.org,
	mikko.ylinen-VuQAYsv1563Yd54FQh9/CA@public.gmane.org,
	yangjie-0li6OtcxBFHby3iVrkZq2A@public.gmane.org
Subject: [PATCH v5 04/18] x86/sgx: Use sgx_epc_lru_lists for existing active page list
Date: Fri, 22 Sep 2023 20:06:43 -0700	[thread overview]
Message-ID: <20230923030657.16148-5-haitao.huang@linux.intel.com> (raw)
In-Reply-To: <20230923030657.16148-1-haitao.huang-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>

From: Sean Christopherson <sean.j.christopherson-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>

All EPC pages of enclaves including Version Array (VA) and SGX Enclave
Control Structure (SECS) will be tracked in sgx_epc_lru_lists structs,
one per cgroup. For now just replace the existing sgx_active_page_list
in the reclaimer and its spinlock with a global sgx_epc_lru_lists
struct. VA and SECS pages are still not tracked at this point but they
will be tracked after an unreclaimable LRU list is added to the
sgx_epc_lru_lists struct.

Signed-off-by: Sean Christopherson <sean.j.christopherson-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
Co-developed-by: Kristen Carlson Accardi <kristen-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
Signed-off-by: Kristen Carlson Accardi <kristen-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
Co-developed-by: Haitao Huang <haitao.huang-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
Signed-off-by: Haitao Huang <haitao.huang-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
Cc: Sean Christopherson <seanjc-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>
---
V5:
- Spelled out SECS, VA (Jarkko)

V4:
- No change, only reordered the patch.

V3:
- Remove usage of list wrapper
---
 arch/x86/kernel/cpu/sgx/main.c | 39 +++++++++++++++++-----------------
 1 file changed, 20 insertions(+), 19 deletions(-)

diff --git a/arch/x86/kernel/cpu/sgx/main.c b/arch/x86/kernel/cpu/sgx/main.c
index 166692f2d501..afce51d6e94a 100644
--- a/arch/x86/kernel/cpu/sgx/main.c
+++ b/arch/x86/kernel/cpu/sgx/main.c
@@ -26,10 +26,9 @@ static DEFINE_XARRAY(sgx_epc_address_space);
 
 /*
  * These variables are part of the state of the reclaimer, and must be accessed
- * with sgx_reclaimer_lock acquired.
+ * with sgx_global_lru.lock acquired.
  */
-static LIST_HEAD(sgx_active_page_list);
-static DEFINE_SPINLOCK(sgx_reclaimer_lock);
+static struct sgx_epc_lru_lists sgx_global_lru;
 
 static atomic_long_t sgx_nr_free_pages = ATOMIC_LONG_INIT(0);
 
@@ -304,13 +303,13 @@ static void sgx_reclaim_pages(void)
 	int ret;
 	int i;
 
-	spin_lock(&sgx_reclaimer_lock);
+	spin_lock(&sgx_global_lru.lock);
 	for (i = 0; i < SGX_NR_TO_SCAN; i++) {
-		if (list_empty(&sgx_active_page_list))
+		epc_page = list_first_entry_or_null(&sgx_global_lru.reclaimable,
+						    struct sgx_epc_page, list);
+		if (!epc_page)
 			break;
 
-		epc_page = list_first_entry(&sgx_active_page_list,
-					    struct sgx_epc_page, list);
 		list_del_init(&epc_page->list);
 		encl_page = epc_page->owner;
 
@@ -322,7 +321,7 @@ static void sgx_reclaim_pages(void)
 			 */
 			epc_page->flags &= ~SGX_EPC_PAGE_RECLAIMER_TRACKED;
 	}
-	spin_unlock(&sgx_reclaimer_lock);
+	spin_unlock(&sgx_global_lru.lock);
 
 	for (i = 0; i < cnt; i++) {
 		epc_page = chunk[i];
@@ -345,9 +344,9 @@ static void sgx_reclaim_pages(void)
 		continue;
 
 skip:
-		spin_lock(&sgx_reclaimer_lock);
-		list_add_tail(&epc_page->list, &sgx_active_page_list);
-		spin_unlock(&sgx_reclaimer_lock);
+		spin_lock(&sgx_global_lru.lock);
+		list_add_tail(&epc_page->list, &sgx_global_lru.reclaimable);
+		spin_unlock(&sgx_global_lru.lock);
 
 		kref_put(&encl_page->encl->refcount, sgx_encl_release);
 
@@ -378,7 +377,7 @@ static void sgx_reclaim_pages(void)
 static bool sgx_should_reclaim(unsigned long watermark)
 {
 	return atomic_long_read(&sgx_nr_free_pages) < watermark &&
-	       !list_empty(&sgx_active_page_list);
+	       !list_empty(&sgx_global_lru.reclaimable);
 }
 
 /*
@@ -430,6 +429,8 @@ static bool __init sgx_page_reclaimer_init(void)
 
 	ksgxd_tsk = tsk;
 
+	sgx_lru_init(&sgx_global_lru);
+
 	return true;
 }
 
@@ -505,10 +506,10 @@ struct sgx_epc_page *__sgx_alloc_epc_page(void)
  */
 void sgx_mark_page_reclaimable(struct sgx_epc_page *page)
 {
-	spin_lock(&sgx_reclaimer_lock);
+	spin_lock(&sgx_global_lru.lock);
 	page->flags |= SGX_EPC_PAGE_RECLAIMER_TRACKED;
-	list_add_tail(&page->list, &sgx_active_page_list);
-	spin_unlock(&sgx_reclaimer_lock);
+	list_add_tail(&page->list, &sgx_global_lru.reclaimable);
+	spin_unlock(&sgx_global_lru.lock);
 }
 
 /**
@@ -523,18 +524,18 @@ void sgx_mark_page_reclaimable(struct sgx_epc_page *page)
  */
 int sgx_unmark_page_reclaimable(struct sgx_epc_page *page)
 {
-	spin_lock(&sgx_reclaimer_lock);
+	spin_lock(&sgx_global_lru.lock);
 	if (page->flags & SGX_EPC_PAGE_RECLAIMER_TRACKED) {
 		/* The page is being reclaimed. */
 		if (list_empty(&page->list)) {
-			spin_unlock(&sgx_reclaimer_lock);
+			spin_unlock(&sgx_global_lru.lock);
 			return -EBUSY;
 		}
 
 		list_del(&page->list);
 		page->flags &= ~SGX_EPC_PAGE_RECLAIMER_TRACKED;
 	}
-	spin_unlock(&sgx_reclaimer_lock);
+	spin_unlock(&sgx_global_lru.lock);
 
 	return 0;
 }
@@ -567,7 +568,7 @@ struct sgx_epc_page *sgx_alloc_epc_page(void *owner, bool reclaim)
 			break;
 		}
 
-		if (list_empty(&sgx_active_page_list))
+		if (list_empty(&sgx_global_lru.reclaimable))
 			return ERR_PTR(-ENOMEM);
 
 		if (!reclaim) {
-- 
2.25.1


  parent reply	other threads:[~2023-09-23  3:06 UTC|newest]

Thread overview: 126+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-09-23  3:06 [PATCH v5 00/18] Add Cgroup support for SGX EPC memory Haitao Huang
2023-09-23  3:06 ` [PATCH v5 03/18] x86/sgx: Add sgx_epc_lru_lists to encapsulate LRU lists Haitao Huang
     [not found] ` <20230923030657.16148-1-haitao.huang-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2023-09-23  3:06   ` [PATCH v5 01/18] cgroup/misc: Add per resource callbacks for CSS events Haitao Huang
     [not found]     ` <20230923030657.16148-2-haitao.huang-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2023-09-25 17:09       ` Jarkko Sakkinen
2023-09-25 17:09         ` Jarkko Sakkinen
2023-09-26  3:04         ` Haitao Huang
     [not found]           ` <op.2buytfetwjvjmi-yDQzE4XY+yVaPPhiJ6yCxLKMmGWinSIL2HeeBUIffwg@public.gmane.org>
2023-09-26 13:10             ` Jarkko Sakkinen
2023-09-26 13:10               ` Jarkko Sakkinen
2023-09-26 13:13               ` Jarkko Sakkinen
2023-09-26 13:13                 ` Jarkko Sakkinen
2023-09-27  1:56                 ` Haitao Huang
2023-10-02 22:47                   ` Jarkko Sakkinen
2023-10-02 22:55                     ` Jarkko Sakkinen
2023-10-04 15:45                       ` Haitao Huang
2023-10-04 17:18                         ` Tejun Heo
2023-09-27  9:20     ` Huang, Kai
2023-10-03 14:29       ` Haitao Huang
2023-10-17 18:55     ` Michal Koutný
2023-09-23  3:06   ` [PATCH v5 02/18] cgroup/misc: Add SGX EPC resource type and export APIs for SGX driver Haitao Huang
     [not found]     ` <20230923030657.16148-3-haitao.huang-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2023-09-25 18:50       ` Tejun Heo
2023-09-25 18:50         ` Tejun Heo
2023-09-28  3:59     ` Huang, Kai
2023-10-03  7:00       ` Haitao Huang
2023-10-03 19:33         ` Huang, Kai
2023-09-23  3:06   ` Haitao Huang [this message]
2023-09-23  3:06   ` [PATCH v5 05/18] x86/sgx: Store reclaimable EPC pages in sgx_epc_lru_lists Haitao Huang
2023-09-27 10:14     ` Huang, Kai
2023-09-23  3:06   ` [PATCH v5 06/18] x86/sgx: Introduce EPC page states Haitao Huang
     [not found]     ` <20230923030657.16148-7-haitao.huang-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2023-09-25 17:11       ` Jarkko Sakkinen
2023-09-25 17:11         ` Jarkko Sakkinen
2023-09-27 10:28     ` Huang, Kai
2023-10-03  4:49       ` Haitao Huang
2023-10-03 20:03         ` Huang, Kai
2023-10-04 15:24           ` Haitao Huang
2023-10-04 21:05             ` Huang, Kai
2023-09-23  3:06   ` [PATCH v5 07/18] x86/sgx: Introduce RECLAIM_IN_PROGRESS state Haitao Huang
2023-09-25 17:13     ` Jarkko Sakkinen
2023-09-25 17:13       ` Jarkko Sakkinen
2023-09-27 10:42     ` Huang, Kai
2023-09-23  3:06   ` [PATCH v5 08/18] x86/sgx: Use a list to track to-be-reclaimed pages Haitao Huang
2023-09-28  9:28     ` Huang, Kai
2023-10-03  5:09       ` Haitao Huang
2023-09-23  3:06   ` [PATCH v5 09/18] x86/sgx: Store struct sgx_encl when allocating new VA pages Haitao Huang
2023-09-27 11:14     ` Huang, Kai
2023-09-27 15:35       ` Haitao Huang
2023-09-27 21:21         ` Huang, Kai
2023-09-29 15:06           ` Haitao Huang
2023-10-02 11:05             ` Huang, Kai
2023-09-27 11:35     ` Huang, Kai
2023-10-03  6:45       ` Haitao Huang
2023-10-03 20:07         ` Huang, Kai
2023-10-04 15:03           ` Haitao Huang
2023-10-04 21:13             ` Huang, Kai
2023-10-05  4:22               ` Haitao Huang
2023-10-05  6:49                 ` Huang, Kai
2023-09-23  3:06   ` [PATCH v5 10/18] x86/sgx: Add EPC page flags to identify owner types Haitao Huang
2023-09-23  3:06   ` [PATCH v5 11/18] x86/sgx: store unreclaimable pages in LRU lists Haitao Huang
2023-09-27 11:57     ` Huang, Kai
2023-10-03  5:42       ` Haitao Huang
2023-09-28  9:41     ` Huang, Kai
2023-10-03  5:15       ` Haitao Huang
2023-10-03 20:12         ` Huang, Kai
2023-09-23  3:06   ` [PATCH v5 12/18] x86/sgx: Add EPC OOM path to forcefully reclaim EPC Haitao Huang
2023-10-09 23:45     ` Huang, Kai
2023-10-10  0:23       ` Sean Christopherson
2023-10-10  0:50         ` Huang, Kai
2023-10-10  1:34           ` Huang, Kai
2023-10-10 16:49             ` Haitao Huang
2023-10-11  0:51               ` Huang, Kai
2023-10-12 13:27                 ` Haitao Huang
2023-10-16 10:57                   ` Huang, Kai
2023-10-16 19:52                     ` Haitao Huang
2023-10-16 21:09                       ` Huang, Kai
2023-10-17  0:10                         ` Haitao Huang
2023-10-17  1:34                           ` Huang, Kai
2023-10-17 12:58                             ` Haitao Huang
2023-10-17 18:54                               ` Michal Koutný
2023-10-17 19:13                                 ` Michal Koutný
2023-10-18  4:39                                   ` Haitao Huang
2023-10-18  4:37                                 ` Haitao Huang
2023-10-18 13:55                                   ` Dave Hansen
2023-10-18 15:26                                     ` Haitao Huang
2023-10-18 15:37                                       ` Dave Hansen
2023-10-18 15:52                                         ` Michal Koutný
2023-10-18 16:25                                           ` Haitao Huang
2023-10-16 21:32                       ` Sean Christopherson
2023-10-17  0:09                         ` Haitao Huang
2023-10-17 15:43                           ` Sean Christopherson
2023-10-17 11:49                         ` Mikko Ylinen
2023-10-11  1:14               ` Huang, Kai
2023-10-16 11:02                 ` Huang, Kai
2023-10-10  1:42         ` Haitao Huang
2023-10-10  2:23           ` Huang, Kai
2023-10-10 13:26             ` Haitao Huang
2023-10-11  0:01               ` Sean Christopherson
2023-10-11 15:02                 ` Haitao Huang
2023-10-10  1:04       ` Haitao Huang
2023-10-10  1:18         ` Huang, Kai
2023-10-10  1:38           ` Haitao Huang
2023-10-10  2:12             ` Huang, Kai
2023-10-10 17:05               ` Haitao Huang
2023-10-11  0:31                 ` Huang, Kai
2023-10-11 16:04                   ` Haitao Huang
2023-09-23  3:06   ` [PATCH v5 13/18] x86/sgx: Expose sgx_reclaim_pages() for use by EPC cgroup Haitao Huang
2023-10-05 12:24     ` Huang, Kai
2023-10-05 19:23       ` Haitao Huang
2023-10-05 20:25         ` Huang, Kai
2023-09-23  3:06   ` [PATCH v5 14/18] x86/sgx: Add helper to grab pages from an arbitrary EPC LRU Haitao Huang
2023-09-23  3:06   ` [PATCH v5 15/18] x86/sgx: Prepare for multiple LRUs Haitao Huang
2023-10-05 12:30     ` Huang, Kai
2023-10-05 19:33       ` Haitao Huang
2023-10-05 20:38         ` Huang, Kai
2023-09-23  3:06   ` [PATCH v5 16/18] x86/sgx: Limit process EPC usage with misc cgroup controller Haitao Huang
     [not found]     ` <20230923030657.16148-17-haitao.huang-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2023-09-25 17:15       ` Jarkko Sakkinen
2023-09-25 17:15         ` Jarkko Sakkinen
2023-10-05 21:01     ` Huang, Kai
2023-10-10  0:12     ` Huang, Kai
2023-10-10  0:16     ` Huang, Kai
2023-10-10  0:26     ` Huang, Kai
2023-10-22 18:26       ` Haitao Huang
2023-10-10  9:19     ` Huang, Kai
2023-10-10  9:32     ` Huang, Kai
2023-10-17 18:54     ` Michal Koutný
2023-10-19 16:05       ` Haitao Huang
2023-09-23  3:06   ` [PATCH v5 17/18] Docs/x86/sgx: Add description for cgroup support Haitao Huang
2023-09-23  3:06   ` [PATCH v5 18/18] selftests/sgx: Add scripts for EPC cgroup testing Haitao Huang

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20230923030657.16148-5-haitao.huang@linux.intel.com \
    --to=haitao.huang-vuqaysv1563yd54fqh9/ca@public.gmane.org \
    --cc=anakrish-0li6OtcxBFHby3iVrkZq2A@public.gmane.org \
    --cc=bp-Gina5bIWoIWzQB+pC5nmwQ@public.gmane.org \
    --cc=cgroups-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=dave.hansen-VuQAYsv1563Yd54FQh9/CA@public.gmane.org \
    --cc=hpa-YMNOUZJC4hwAvxtiuMwx3w@public.gmane.org \
    --cc=jarkko-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org \
    --cc=kristen-VuQAYsv1563Yd54FQh9/CA@public.gmane.org \
    --cc=linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=linux-sgx-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=mikko.ylinen-VuQAYsv1563Yd54FQh9/CA@public.gmane.org \
    --cc=mingo-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org \
    --cc=seanjc-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org \
    --cc=sohil.mehta-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org \
    --cc=tglx-hfZtesqFncYOwBW4kG4KsQ@public.gmane.org \
    --cc=tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org \
    --cc=x86-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org \
    --cc=yangjie-0li6OtcxBFHby3iVrkZq2A@public.gmane.org \
    --cc=zhanb-0li6OtcxBFHby3iVrkZq2A@public.gmane.org \
    --cc=zhiquan1.li-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox