Re: [PATCH v2 0/3] x86/intel_rdt: task_work vs task_struct rmid/closid write race
From: Reinette Chatre
Date:  Tue Nov 24 2020 - 16:38:01 EST
Hi Valentin,
On 11/22/2020 6:24 PM, Valentin Schneider wrote:
This is a small cleanup + a fix for a race I stumbled upon while staring at
resctrl stuff.
Briefly tested on a Xeon Gold 5120 (m2.xlarge.x86 on Equinix) by bouncing
a few tasks around control groups.
...
Thank you very much for taking this on. Unfortunately this race is one 
of a few issues with the way in which tasks moving to a new resource 
group is handled.
Other issues are:
1.
Until the queued work is run, the moved task runs with old (and even
invalid in the case when its original resource group has been removed)
closid and rmid.
2.
Work to update the PQR_ASSOC register is queued every time the user 
writes a task id to the "tasks" file, even if the task already belongs 
to the resource group and in addition to any other pending work for that 
task. This could result in multiple pending work items associated with a 
single task even if they are all identical and even though only a single 
update with most recent values is needed. This could result in 
significant system resource waste, especially on tasks sleeping for a 
long time.
Fenghua solved these issues by replacing the callback with a synchronous 
update, similar to how tasks are currently moved when a resource group 
is deleted. We plan to submit this work next week.
This new solution will make patch 1 and 2 of this series unnecessary. As 
I understand it patch 3 would still be a welcome addition but would 
require changes. As you prefer you could either submit patch 3 on its 
own for the code as it is now and we will rework the task related 
changes on top of that, or you could wait for the task related changes 
to land first?
Valentin Schneider (3):
   x86/intel_rdt: Check monitor group vs control group membership earlier
   x86/intel_rdt: Plug task_work vs task_struct {rmid,closid} update race
   x86/intel_rdt: Apply READ_ONCE/WRITE_ONCE to task_struct .rmid &
     .closid
Thank you very much
Reinette