From: Fenghua Yu <fenghua...@intel.com> The header mainly provides functions to call from the user interface file intel_rdt_rdtgroup.c.
Signed-off-by: Fenghua Yu <fenghua...@intel.com> Reviewed-by: Tony Luck <tony.l...@intel.com> --- arch/x86/include/asm/intel_rdt.h | 77 +++++++++++++++++++++++++++++++++++++--- 1 file changed, 72 insertions(+), 5 deletions(-) diff --git a/arch/x86/include/asm/intel_rdt.h b/arch/x86/include/asm/intel_rdt.h index 4e05c6e..a4f794b 100644 --- a/arch/x86/include/asm/intel_rdt.h +++ b/arch/x86/include/asm/intel_rdt.h @@ -3,27 +3,94 @@ #ifdef CONFIG_INTEL_RDT +#include <linux/seq_file.h> #include <linux/jump_label.h> -#define MAX_CBM_LENGTH 32 #define IA32_L3_CBM_BASE 0xc90 -#define CBM_FROM_INDEX(x) (IA32_L3_CBM_BASE + x) -#define MSR_IA32_PQOS_CFG 0xc81 +#define L3_CBM_FROM_INDEX(x) (IA32_L3_CBM_BASE + x) + +#define MSR_IA32_L3_QOS_CFG 0xc81 + +enum resource_type { + RESOURCE_L3 = 0, + RESOURCE_NUM = 1, +}; + +#define MAX_CACHE_LEAVES 4 +#define MAX_CACHE_DOMAINS 64 + +DECLARE_PER_CPU_READ_MOSTLY(int, cpu_l3_domain); +DECLARE_PER_CPU_READ_MOSTLY(struct rdtgroup *, cpu_rdtgroup); extern struct static_key rdt_enable_key; void __intel_rdt_sched_in(void *dummy); +extern bool cdp_enabled; + +struct rdt_opts { + bool cdp_enabled; + bool verbose; + bool simulate_cat_l3; +}; + +struct cache_domain { + cpumask_t shared_cpu_map[MAX_CACHE_DOMAINS]; + unsigned int max_cache_domains_num; + unsigned int level; + unsigned int shared_cache_id[MAX_CACHE_DOMAINS]; +}; + +extern struct rdt_opts rdt_opts; + struct clos_cbm_table { unsigned long cbm; unsigned int clos_refcnt; }; struct clos_config { - unsigned long *closmap; + unsigned long **closmap; u32 max_closid; - u32 closids_used; }; +struct shared_domain { + struct cpumask cpumask; + int l3_domain; +}; + +#define for_each_cache_domain(domain, start_domain, max_domain) \ + for (domain = start_domain; domain < max_domain; domain++) + +extern struct clos_config cconfig; +extern struct shared_domain *shared_domain; +extern int shared_domain_num; + +extern struct rdtgroup *root_rdtgrp; + +extern struct clos_cbm_table **l3_cctable; + +extern unsigned int min_bitmask_len; +extern void msr_cpu_update(void *arg); +extern inline void closid_get(u32 closid, int domain); +extern void closid_put(u32 closid, int domain); +extern void closid_free(u32 closid, int domain, int level); +extern int closid_alloc(u32 *closid, int domain); +extern bool cat_l3_enabled; +extern unsigned int get_domain_num(int level); +extern struct shared_domain *shared_domain; +extern int shared_domain_num; +extern inline int get_dcbm_table_index(int x); +extern inline int get_icbm_table_index(int x); + +extern int get_cache_leaf(int level, int cpu); + +extern void cbm_update_l3_msr(void *pindex); +extern int level_to_leaf(int level); + +extern void init_msrs(bool cdpenabled); +extern bool cat_enabled(int level); +extern u64 max_cbm(int level); +extern u32 max_cbm_len(int level); + /* * intel_rdt_sched_in() - Writes the task's CLOSid to IA32_PQR_MSR * -- 2.5.0