[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1389048315.32504.57.camel@ppwaskie-mobl.amr.corp.intel.com>
Date: Mon, 6 Jan 2014 22:45:24 +0000
From: "Waskiewicz Jr, Peter P" <peter.p.waskiewicz.jr@...el.com>
To: Peter Zijlstra <peterz@...radead.org>
CC: Tejun Heo <tj@...nel.org>, Thomas Gleixner <tglx@...utronix.de>,
"Ingo Molnar" <mingo@...hat.com>, "H. Peter Anvin" <hpa@...or.com>,
Li Zefan <lizefan@...wei.com>,
"containers@...ts.linux-foundation.org"
<containers@...ts.linux-foundation.org>,
"cgroups@...r.kernel.org" <cgroups@...r.kernel.org>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>
Subject: Re: [PATCH 0/4] x86: Add Cache QoS Monitoring (CQM) support
On Mon, 2014-01-06 at 23:12 +0100, Peter Zijlstra wrote:
> On Mon, Jan 06, 2014 at 09:48:29PM +0000, Waskiewicz Jr, Peter P wrote:
> > The cacheline is tagged internally with the RMID as part of the waymask
> > for the thread in the core.
> >
> > > Without a wipe you keep having stale entries of the former user and no
> > > clear indication on when your numbers are any good.
> >
> > That can happen, yes. If you have leftover cache data from a process
> > that died that hasn't been evicted yet and it's assigned to the RMID
> > you're using, you will see its included cache occupancy to the overall
> > numbers.
> >
> > > Also, is there any sane way of shooting down the entire L3?
> >
> > That is a question I'd punt to hpa, but I'll ask him. Looking around
> > though, a WBINVD would certainly nuke things, but would hurt
> > performance. We could get creative with INVPCID as a process dies. Let
> > me ask him though and see if there's a good way to tidy up.
>
> You seem to be assuming a RMID is for the entire task lifetime.
No, the RMID can be changed if the user wants to reassign the process to
a different group/RMID. If I'm coming across otherwise, then my
apologies.
> Since its a very limited resource that seems like a weird assumption to
> me; there's plenty scenarios in which you'd want to re-use RMIDs that
> belong to a still running context.
I think I see what you're really asking, let me rephrase to see if I'm
now understanding you: What happens to a running process' cache
assigned to one RMID when it's reassigned to a different RMID? Does the
RMID get updated internally or does it appear as still belonging to the
old RMID?
If that's your question, then the CPU will update the cache entry with
the correct RMID. It knows to do this because the when the process is
scheduled, the OS will write the IA32_PQR_ASSOC MSR with the RMID map to
start monitoring. That's when the RMID will be updated in the cache.
However, any cacheline for a process that is moved to a different RMID,
but doesn't have an opportunity to be scheduled, will still show up on
the old RMID until it gets to run with the new RMID.
Let me know if that better explains what I think you're asking.
-PJ
--
PJ Waskiewicz Open Source Technology Center
peter.p.waskiewicz.jr@...el.com Intel Corp.
Powered by blists - more mailing lists