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

greybus: audio: Report jack events conditionally

Now jack & jack-buttons are registered to snd_jack framework based on
the capability shared by module's topology data. Thus, jack events
should be reported to above snd framework only in case corresponding
jack type is registered. This patch adds additional checks to avoid
reporting fake jack events.
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 847175e8
...@@ -21,7 +21,16 @@ ...@@ -21,7 +21,16 @@
static int gbaudio_request_jack(struct gbaudio_module_info *module, static int gbaudio_request_jack(struct gbaudio_module_info *module,
struct gb_audio_jack_event_request *req) struct gb_audio_jack_event_request *req)
{ {
int report, button_status; int report;
struct snd_jack *jack = module->headset_jack.jack;
struct snd_jack *btn_jack = module->button_jack.jack;
if (!jack) {
dev_err_ratelimited(module->dev,
"Invalid jack event received:type: %u, event: %u\n",
req->jack_attribute, req->event);
return -EINVAL;
}
dev_warn_ratelimited(module->dev, dev_warn_ratelimited(module->dev,
"Jack Event received: type: %u, event: %u\n", "Jack Event received: type: %u, event: %u\n",
...@@ -29,19 +38,24 @@ static int gbaudio_request_jack(struct gbaudio_module_info *module, ...@@ -29,19 +38,24 @@ static int gbaudio_request_jack(struct gbaudio_module_info *module,
if (req->event == GB_AUDIO_JACK_EVENT_REMOVAL) { if (req->event == GB_AUDIO_JACK_EVENT_REMOVAL) {
module->jack_type = 0; module->jack_type = 0;
button_status = module->button_status; if (btn_jack && module->button_status) {
module->button_status = 0;
if (button_status)
snd_soc_jack_report(&module->button_jack, 0, snd_soc_jack_report(&module->button_jack, 0,
module->button_mask); module->button_mask);
module->button_status = 0;
}
snd_soc_jack_report(&module->headset_jack, 0, snd_soc_jack_report(&module->headset_jack, 0,
module->jack_mask); module->jack_mask);
return 0; return 0;
} }
/* currently supports Headphone, Headset & Lineout only */ report = req->jack_attribute & module->jack_mask;
report &= ~module->jack_mask; if (!report) {
report |= req->jack_attribute & module->jack_mask; dev_err_ratelimited(module->dev,
"Invalid jack event received:type: %u, event: %u\n",
req->jack_attribute, req->event);
return -EINVAL;
}
if (module->jack_type) if (module->jack_type)
dev_warn_ratelimited(module->dev, dev_warn_ratelimited(module->dev,
"Modifying jack from %d to %d\n", "Modifying jack from %d to %d\n",
...@@ -57,6 +71,14 @@ static int gbaudio_request_button(struct gbaudio_module_info *module, ...@@ -57,6 +71,14 @@ static int gbaudio_request_button(struct gbaudio_module_info *module,
struct gb_audio_button_event_request *req) struct gb_audio_button_event_request *req)
{ {
int soc_button_id, report; int soc_button_id, report;
struct snd_jack *btn_jack = module->button_jack.jack;
if (!btn_jack) {
dev_err_ratelimited(module->dev,
"Invalid button event received:type: %u, event: %u\n",
req->button_id, req->event);
return -EINVAL;
}
dev_warn_ratelimited(module->dev, dev_warn_ratelimited(module->dev,
"Button Event received: id: %u, event: %u\n", "Button Event received: id: %u, event: %u\n",
......
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