Skip to content

Commit 753694a

Browse files
xiaochenshenKAGA-KOKO
authored andcommitted
x86/intel_rdt: Fix data type in parsing callbacks
Each resource is associated with a parsing callback to parse the data provided from user space when writing schemata file. The 'data' parameter in the callbacks is defined as a void pointer which is error prone due to lack of type check. parse_bw() processes the 'data' parameter as a string while its caller actually passes the parameter as a pointer to struct rdt_cbm_parse_data. Thus, parse_bw() takes wrong data and causes failure of parsing MBA throttle value. To fix the issue, the 'data' parameter in all parsing callbacks is defined and handled as a pointer to struct rdt_parse_data (renamed from struct rdt_cbm_parse_data). Fixes: 7604df6 ("x86/intel_rdt: Support flexible data to parsing callbacks") Fixes: 9ab9aa1 ("x86/intel_rdt: Ensure requested schemata respects mode") Signed-off-by: Xiaochen Shen <xiaochen.shen@intel.com> Signed-off-by: Reinette Chatre <reinette.chatre@intel.com> Signed-off-by: Fenghua Yu <fenghua.yu@intel.com> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Cc: "H Peter Anvin" <hpa@zytor.com> Cc: "Tony Luck" <tony.luck@intel.com> Cc: "Chen Yu" <yu.c.chen@intel.com> Link: https://lkml.kernel.org/r/1537048707-76280-2-git-send-email-fenghua.yu@intel.com
1 parent 6a1cac5 commit 753694a

File tree

2 files changed

+20
-17
lines changed

2 files changed

+20
-17
lines changed

arch/x86/kernel/cpu/intel_rdt.h

Lines changed: 12 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -382,6 +382,11 @@ static inline bool is_mbm_event(int e)
382382
e <= QOS_L3_MBM_LOCAL_EVENT_ID);
383383
}
384384

385+
struct rdt_parse_data {
386+
struct rdtgroup *rdtgrp;
387+
char *buf;
388+
};
389+
385390
/**
386391
* struct rdt_resource - attributes of an RDT resource
387392
* @rid: The index of the resource
@@ -423,16 +428,19 @@ struct rdt_resource {
423428
struct rdt_cache cache;
424429
struct rdt_membw membw;
425430
const char *format_str;
426-
int (*parse_ctrlval) (void *data, struct rdt_resource *r,
427-
struct rdt_domain *d);
431+
int (*parse_ctrlval)(struct rdt_parse_data *data,
432+
struct rdt_resource *r,
433+
struct rdt_domain *d);
428434
struct list_head evt_list;
429435
int num_rmid;
430436
unsigned int mon_scale;
431437
unsigned long fflags;
432438
};
433439

434-
int parse_cbm(void *_data, struct rdt_resource *r, struct rdt_domain *d);
435-
int parse_bw(void *_buf, struct rdt_resource *r, struct rdt_domain *d);
440+
int parse_cbm(struct rdt_parse_data *data, struct rdt_resource *r,
441+
struct rdt_domain *d);
442+
int parse_bw(struct rdt_parse_data *data, struct rdt_resource *r,
443+
struct rdt_domain *d);
436444

437445
extern struct mutex rdtgroup_mutex;
438446

arch/x86/kernel/cpu/intel_rdt_ctrlmondata.c

Lines changed: 8 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -64,19 +64,19 @@ static bool bw_validate(char *buf, unsigned long *data, struct rdt_resource *r)
6464
return true;
6565
}
6666

67-
int parse_bw(void *_buf, struct rdt_resource *r, struct rdt_domain *d)
67+
int parse_bw(struct rdt_parse_data *data, struct rdt_resource *r,
68+
struct rdt_domain *d)
6869
{
69-
unsigned long data;
70-
char *buf = _buf;
70+
unsigned long bw_val;
7171

7272
if (d->have_new_ctrl) {
7373
rdt_last_cmd_printf("duplicate domain %d\n", d->id);
7474
return -EINVAL;
7575
}
7676

77-
if (!bw_validate(buf, &data, r))
77+
if (!bw_validate(data->buf, &bw_val, r))
7878
return -EINVAL;
79-
d->new_ctrl = data;
79+
d->new_ctrl = bw_val;
8080
d->have_new_ctrl = true;
8181

8282
return 0;
@@ -123,18 +123,13 @@ static bool cbm_validate(char *buf, u32 *data, struct rdt_resource *r)
123123
return true;
124124
}
125125

126-
struct rdt_cbm_parse_data {
127-
struct rdtgroup *rdtgrp;
128-
char *buf;
129-
};
130-
131126
/*
132127
* Read one cache bit mask (hex). Check that it is valid for the current
133128
* resource type.
134129
*/
135-
int parse_cbm(void *_data, struct rdt_resource *r, struct rdt_domain *d)
130+
int parse_cbm(struct rdt_parse_data *data, struct rdt_resource *r,
131+
struct rdt_domain *d)
136132
{
137-
struct rdt_cbm_parse_data *data = _data;
138133
struct rdtgroup *rdtgrp = data->rdtgrp;
139134
u32 cbm_val;
140135

@@ -195,7 +190,7 @@ int parse_cbm(void *_data, struct rdt_resource *r, struct rdt_domain *d)
195190
static int parse_line(char *line, struct rdt_resource *r,
196191
struct rdtgroup *rdtgrp)
197192
{
198-
struct rdt_cbm_parse_data data;
193+
struct rdt_parse_data data;
199194
char *dom = NULL, *id;
200195
struct rdt_domain *d;
201196
unsigned long dom_id;

0 commit comments

Comments
 (0)