Commit 15c726ea authored by Vaibhav Agarwal's avatar Vaibhav Agarwal Committed by Greg Kroah-Hartman

greybus: audio: Add check for invalid index while mapping control

While mapping control id to define DAPM routes, invalid control index
may cause kernel oops. Add extra check to validate index while mapping
names to control_id.
Signed-off-by: default avatarVaibhav Agarwal <vaibhav.agarwal@linaro.org>
Reviewed-by: default avatarMark Greer <mgreer@animalcreek.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@google.com>
parent 0900845a
...@@ -132,6 +132,7 @@ struct gbaudio_control { ...@@ -132,6 +132,7 @@ struct gbaudio_control {
char *name; char *name;
char *wname; char *wname;
const char * const *texts; const char * const *texts;
int items;
struct list_head list; struct list_head list;
}; };
......
...@@ -64,6 +64,8 @@ static const char *gbaudio_map_controlid(struct gbaudio_module_info *module, ...@@ -64,6 +64,8 @@ static const char *gbaudio_map_controlid(struct gbaudio_module_info *module,
if (control->id == control_id) { if (control->id == control_id) {
if (index == GBAUDIO_INVALID_ID) if (index == GBAUDIO_INVALID_ID)
return control->name; return control->name;
if (index >= control->items)
return NULL;
return control->texts[index]; return control->texts[index];
} }
} }
...@@ -71,6 +73,8 @@ static const char *gbaudio_map_controlid(struct gbaudio_module_info *module, ...@@ -71,6 +73,8 @@ static const char *gbaudio_map_controlid(struct gbaudio_module_info *module,
if (control->id == control_id) { if (control->id == control_id) {
if (index == GBAUDIO_INVALID_ID) if (index == GBAUDIO_INVALID_ID)
return control->name; return control->name;
if (index >= control->items)
return NULL;
return control->texts[index]; return control->texts[index];
} }
} }
...@@ -1038,6 +1042,7 @@ static int gbaudio_tplg_create_widget(struct gbaudio_module_info *module, ...@@ -1038,6 +1042,7 @@ static int gbaudio_tplg_create_widget(struct gbaudio_module_info *module,
csize += gbenum->names_length; csize += gbenum->names_length;
control->texts = (const char * const *) control->texts = (const char * const *)
gb_generate_enum_strings(module, gbenum); gb_generate_enum_strings(module, gbenum);
control->items = gbenum->items;
} else } else
csize = sizeof(struct gb_audio_control); csize = sizeof(struct gb_audio_control);
*w_size += csize; *w_size += csize;
...@@ -1184,6 +1189,7 @@ static int gbaudio_tplg_process_kcontrols(struct gbaudio_module_info *module, ...@@ -1184,6 +1189,7 @@ static int gbaudio_tplg_process_kcontrols(struct gbaudio_module_info *module,
csize += gbenum->names_length; csize += gbenum->names_length;
control->texts = (const char * const *) control->texts = (const char * const *)
gb_generate_enum_strings(module, gbenum); gb_generate_enum_strings(module, gbenum);
control->items = gbenum->items;
} else } else
csize = sizeof(struct gb_audio_control); csize = sizeof(struct gb_audio_control);
......
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