[alsa-devel] [PATCH 10/24] ALSA: ctl: unify calls of D0-wait function for ELEM_READ request
Takashi Sakamoto
o-takashi at sakamocchi.jp
Sat Nov 25 10:19:52 CET 2017
When handling I/O request for ELEM_READ, 'snd_power_wait()' function is
used before a call of 'snd_ctl_elem_read()' function. This is perhaps due
to performing I/O operation to actual devices. The same thing is done by
helper functions for native/compat ABI, and they can be unified.
This commit moves these duplicated codes into the callee function.
Signed-off-by: Takashi Sakamoto <o-takashi at sakamocchi.jp>
---
sound/core/control.c | 30 +++++++++++++++++++-----------
sound/core/control_compat.c | 3 ---
2 files changed, 19 insertions(+), 14 deletions(-)
diff --git a/sound/core/control.c b/sound/core/control.c
index 91966b190b8b..2b5921e9f111 100644
--- a/sound/core/control.c
+++ b/sound/core/control.c
@@ -897,18 +897,32 @@ static int snd_ctl_elem_read(struct snd_card *card,
struct snd_kcontrol *kctl;
struct snd_kcontrol_volatile *vd;
unsigned int index_offset;
+ int err;
+
+ err = snd_power_wait(card, SNDRV_CTL_POWER_D0);
+ if (err < 0)
+ return err;
+
+ down_read(&card->controls_rwsem);
kctl = snd_ctl_find_id(card, &control->id);
- if (kctl == NULL)
- return -ENOENT;
+ if (kctl == NULL) {
+ err = -ENOENT;
+ goto end;
+ }
index_offset = snd_ctl_get_ioff(kctl, &control->id);
vd = &kctl->vd[index_offset];
- if (!(vd->access & SNDRV_CTL_ELEM_ACCESS_READ) && kctl->get == NULL)
- return -EPERM;
+ if (!(vd->access & SNDRV_CTL_ELEM_ACCESS_READ) && kctl->get == NULL) {
+ err = -EPERM;
+ goto end;
+ }
snd_ctl_build_ioff(&control->id, kctl, index_offset);
- return kctl->get(kctl, control);
+ err = kctl->get(kctl, control);
+end:
+ up_read(&card->controls_rwsem);
+ return err;
}
static int snd_ctl_elem_read_user(struct snd_card *card,
@@ -921,13 +935,7 @@ static int snd_ctl_elem_read_user(struct snd_card *card,
if (IS_ERR(control))
return PTR_ERR(control);
- result = snd_power_wait(card, SNDRV_CTL_POWER_D0);
- if (result < 0)
- goto error;
-
- down_read(&card->controls_rwsem);
result = snd_ctl_elem_read(card, control);
- up_read(&card->controls_rwsem);
if (result < 0)
goto error;
diff --git a/sound/core/control_compat.c b/sound/core/control_compat.c
index e6169b2bc6b3..b887cda28d30 100644
--- a/sound/core/control_compat.c
+++ b/sound/core/control_compat.c
@@ -688,9 +688,6 @@ static int ctl_elem_read_user(struct snd_card *card,
if (err < 0)
goto error;
- err = snd_power_wait(card, SNDRV_CTL_POWER_D0);
- if (err < 0)
- goto error;
err = snd_ctl_elem_read(card, data);
if (err < 0)
goto error;
--
2.14.1
More information about the Alsa-devel
mailing list