[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <7b53e155-2622-4acb-b7c9-d22e623e4cb3@intel.com>
Date: Mon, 26 Feb 2024 14:38:26 +1300
From: "Huang, Kai" <kai.huang@...el.com>
To: Haitao Huang <haitao.huang@...ux.intel.com>, "Mehta, Sohil"
<sohil.mehta@...el.com>, "mingo@...hat.com" <mingo@...hat.com>,
"jarkko@...nel.org" <jarkko@...nel.org>, "x86@...nel.org" <x86@...nel.org>,
"dave.hansen@...ux.intel.com" <dave.hansen@...ux.intel.com>,
"cgroups@...r.kernel.org" <cgroups@...r.kernel.org>, "hpa@...or.com"
<hpa@...or.com>, "tim.c.chen@...ux.intel.com" <tim.c.chen@...ux.intel.com>,
"linux-sgx@...r.kernel.org" <linux-sgx@...r.kernel.org>, "mkoutny@...e.com"
<mkoutny@...e.com>, "tglx@...utronix.de" <tglx@...utronix.de>,
"tj@...nel.org" <tj@...nel.org>, "linux-kernel@...r.kernel.org"
<linux-kernel@...r.kernel.org>, "bp@...en8.de" <bp@...en8.de>
CC: "mikko.ylinen@...ux.intel.com" <mikko.ylinen@...ux.intel.com>,
"seanjc@...gle.com" <seanjc@...gle.com>, "anakrish@...rosoft.com"
<anakrish@...rosoft.com>, "Zhang, Bo" <zhanb@...rosoft.com>,
"kristen@...ux.intel.com" <kristen@...ux.intel.com>, "yangjie@...rosoft.com"
<yangjie@...rosoft.com>, "Li, Zhiquan1" <zhiquan1.li@...el.com>,
"chrisyan@...rosoft.com" <chrisyan@...rosoft.com>
Subject: Re: [PATCH v9 10/15] x86/sgx: Add EPC reclamation in cgroup
try_charge()
On 24/02/2024 6:00 am, Haitao Huang wrote:
> On Fri, 23 Feb 2024 04:18:18 -0600, Huang, Kai <kai.huang@...el.com> wrote:
>
>>> >
>>> Right. When code reaches to here, we already passed reclaim per cgroup.
>>
>> Yes if try_charge() failed we must do pre-cgroup reclaim.
>>
>>> The cgroup may not at or reach limit but system has run out of physical
>>> EPC.
>>>
>>
>> But after try_charge() we can still choose to reclaim from the current
>> group,
>> but not necessarily have to be global, right? I am not sure whether I am
>> missing something, but could you elaborate why we should choose to
>> reclaim from
>> the global?
>>
>
> Once try_charge is done and returns zero that means the cgroup usage is
> charged and it's not over usage limit. So you really can't reclaim from
> that cgroup if allocation failed. The only thing you can do is to
> reclaim globally.
Sorry I still cannot establish the logic here.
Let's say the sum of all cgroups are greater than the physical EPC, and
elclave(s) in each cgroup could potentially fault w/o reaching cgroup's
limit.
In this case, when enclave(s) in one cgroup faults, why we cannot
reclaim from the current cgroup, but have to reclaim from global?
Is there any real downside of the former, or you just want to follow the
reclaim logic w/o cgroup at all?
IIUC, there's at least one advantage of reclaim from the current group,
that faults of enclave(s) in one group won't impact other enclaves in
other cgroups. E.g., in this way other enclaves in other groups may
never need to trigger faults.
Or perhaps I am missing anything?
Powered by blists - more mailing lists