Commit e8140a2d authored by Reinette Chatre's avatar Reinette Chatre Committed by Thomas Gleixner

x86/intel_rdt: Introduce pseudo-locked region

A pseudo-locked region is introduced representing an instance of a
pseudo-locked cache region. Each cache instance (domain) can support one
pseudo-locked region. Similarly a resource group can be used for one
pseudo-locked region.

Include a pointer to a pseudo-locked region from the domain and resource
group structures.
Signed-off-by: default avatarReinette Chatre <reinette.chatre@intel.com>
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Cc: fenghua.yu@intel.com
Cc: tony.luck@intel.com
Cc: vikas.shivappa@linux.intel.com
Cc: gavin.hindman@intel.com
Cc: jithu.joseph@intel.com
Cc: dave.hansen@intel.com
Cc: hpa@zytor.com
Link: https://lkml.kernel.org/r/9f69eb159051067703bcbc714de62e69874d5dee.1529706536.git.reinette.chatre@intel.com
parent bbcee99b
...@@ -122,6 +122,20 @@ struct mongroup { ...@@ -122,6 +122,20 @@ struct mongroup {
u32 rmid; u32 rmid;
}; };
/**
* struct pseudo_lock_region - pseudo-lock region information
* @r: RDT resource to which this pseudo-locked region
* belongs
* @d: RDT domain to which this pseudo-locked region
* belongs
* @cbm: bitmask of the pseudo-locked region
*/
struct pseudo_lock_region {
struct rdt_resource *r;
struct rdt_domain *d;
u32 cbm;
};
/** /**
* struct rdtgroup - store rdtgroup's data in resctrl file system. * struct rdtgroup - store rdtgroup's data in resctrl file system.
* @kn: kernfs node * @kn: kernfs node
...@@ -135,17 +149,19 @@ struct mongroup { ...@@ -135,17 +149,19 @@ struct mongroup {
* monitor only or ctrl_mon group * monitor only or ctrl_mon group
* @mon: mongroup related data * @mon: mongroup related data
* @mode: mode of resource group * @mode: mode of resource group
* @plr: pseudo-locked region
*/ */
struct rdtgroup { struct rdtgroup {
struct kernfs_node *kn; struct kernfs_node *kn;
struct list_head rdtgroup_list; struct list_head rdtgroup_list;
u32 closid; u32 closid;
struct cpumask cpu_mask; struct cpumask cpu_mask;
int flags; int flags;
atomic_t waitcount; atomic_t waitcount;
enum rdt_group_type type; enum rdt_group_type type;
struct mongroup mon; struct mongroup mon;
enum rdtgrp_mode mode; enum rdtgrp_mode mode;
struct pseudo_lock_region *plr;
}; };
/* rdtgroup.flags */ /* rdtgroup.flags */
...@@ -246,22 +262,24 @@ struct mbm_state { ...@@ -246,22 +262,24 @@ struct mbm_state {
* @mbps_val: When mba_sc is enabled, this holds the bandwidth in MBps * @mbps_val: When mba_sc is enabled, this holds the bandwidth in MBps
* @new_ctrl: new ctrl value to be loaded * @new_ctrl: new ctrl value to be loaded
* @have_new_ctrl: did user provide new_ctrl for this domain * @have_new_ctrl: did user provide new_ctrl for this domain
* @plr: pseudo-locked region (if any) associated with domain
*/ */
struct rdt_domain { struct rdt_domain {
struct list_head list; struct list_head list;
int id; int id;
struct cpumask cpu_mask; struct cpumask cpu_mask;
unsigned long *rmid_busy_llc; unsigned long *rmid_busy_llc;
struct mbm_state *mbm_total; struct mbm_state *mbm_total;
struct mbm_state *mbm_local; struct mbm_state *mbm_local;
struct delayed_work mbm_over; struct delayed_work mbm_over;
struct delayed_work cqm_limbo; struct delayed_work cqm_limbo;
int mbm_work_cpu; int mbm_work_cpu;
int cqm_work_cpu; int cqm_work_cpu;
u32 *ctrl_val; u32 *ctrl_val;
u32 *mbps_val; u32 *mbps_val;
u32 new_ctrl; u32 new_ctrl;
bool have_new_ctrl; bool have_new_ctrl;
struct pseudo_lock_region *plr;
}; };
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment