ALSA: pcm: return error immediately for parameters handling
When refining mask/interval parameters, helper functions can return error code. This error is not handled immediately. This seems to return parameters to userspace applications in its meddle of processing. However, in general, when receiving error from system calls, the application might not handle argument buffer. It's reasonable to judge the above design as superfluity. This commit handles the error immediately. Signed-off-by: Takashi Sakamoto <o-takashi@sakamocchi.jp> Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
6baca010c7
commit
f74ae15fe3
|
@ -276,14 +276,14 @@ static int constrain_mask_params(struct snd_pcm_substream *substream,
|
||||||
old_mask = *m;
|
old_mask = *m;
|
||||||
|
|
||||||
changed = snd_mask_refine(m, constrs_mask(constrs, k));
|
changed = snd_mask_refine(m, constrs_mask(constrs, k));
|
||||||
|
if (changed < 0)
|
||||||
|
return changed;
|
||||||
|
|
||||||
trace_hw_mask_param(substream, k, 0, &old_mask, m);
|
trace_hw_mask_param(substream, k, 0, &old_mask, m);
|
||||||
|
|
||||||
/* Set corresponding flag so that the caller gets it. */
|
/* Set corresponding flag so that the caller gets it. */
|
||||||
if (changed)
|
if (changed)
|
||||||
params->cmask |= 1 << k;
|
params->cmask |= 1 << k;
|
||||||
if (changed < 0)
|
|
||||||
return changed;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -312,14 +312,14 @@ static int constrain_interval_params(struct snd_pcm_substream *substream,
|
||||||
old_interval = *i;
|
old_interval = *i;
|
||||||
|
|
||||||
changed = snd_interval_refine(i, constrs_interval(constrs, k));
|
changed = snd_interval_refine(i, constrs_interval(constrs, k));
|
||||||
|
if (changed < 0)
|
||||||
|
return changed;
|
||||||
|
|
||||||
trace_hw_interval_param(substream, k, 0, &old_interval, i);
|
trace_hw_interval_param(substream, k, 0, &old_interval, i);
|
||||||
|
|
||||||
/* Set corresponding flag so that the caller gets it. */
|
/* Set corresponding flag so that the caller gets it. */
|
||||||
if (changed)
|
if (changed)
|
||||||
params->cmask |= 1 << k;
|
params->cmask |= 1 << k;
|
||||||
if (changed < 0)
|
|
||||||
return changed;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -406,6 +406,8 @@ retry:
|
||||||
}
|
}
|
||||||
|
|
||||||
changed = r->func(params, r);
|
changed = r->func(params, r);
|
||||||
|
if (changed < 0)
|
||||||
|
return changed;
|
||||||
|
|
||||||
if (hw_is_mask(r->var)) {
|
if (hw_is_mask(r->var)) {
|
||||||
trace_hw_mask_param(substream, r->var, k + 1,
|
trace_hw_mask_param(substream, r->var, k + 1,
|
||||||
|
@ -428,8 +430,7 @@ retry:
|
||||||
vstamps[r->var] = stamp;
|
vstamps[r->var] = stamp;
|
||||||
again = true;
|
again = true;
|
||||||
}
|
}
|
||||||
if (changed < 0)
|
|
||||||
return changed;
|
|
||||||
stamp++;
|
stamp++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -527,13 +528,16 @@ static int snd_pcm_hw_refine_user(struct snd_pcm_substream *substream,
|
||||||
return PTR_ERR(params);
|
return PTR_ERR(params);
|
||||||
|
|
||||||
err = snd_pcm_hw_refine(substream, params);
|
err = snd_pcm_hw_refine(substream, params);
|
||||||
if (err >= 0)
|
if (err < 0)
|
||||||
err = fixup_unreferenced_params(substream, params);
|
goto end;
|
||||||
if (copy_to_user(_params, params, sizeof(*params))) {
|
|
||||||
if (!err)
|
|
||||||
err = -EFAULT;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
err = fixup_unreferenced_params(substream, params);
|
||||||
|
if (err < 0)
|
||||||
|
goto end;
|
||||||
|
|
||||||
|
if (copy_to_user(_params, params, sizeof(*params)))
|
||||||
|
err = -EFAULT;
|
||||||
|
end:
|
||||||
kfree(params);
|
kfree(params);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
@ -749,11 +753,12 @@ static int snd_pcm_hw_params_user(struct snd_pcm_substream *substream,
|
||||||
return PTR_ERR(params);
|
return PTR_ERR(params);
|
||||||
|
|
||||||
err = snd_pcm_hw_params(substream, params);
|
err = snd_pcm_hw_params(substream, params);
|
||||||
if (copy_to_user(_params, params, sizeof(*params))) {
|
if (err < 0)
|
||||||
if (!err)
|
goto end;
|
||||||
err = -EFAULT;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
if (copy_to_user(_params, params, sizeof(*params)))
|
||||||
|
err = -EFAULT;
|
||||||
|
end:
|
||||||
kfree(params);
|
kfree(params);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
@ -3699,14 +3704,17 @@ static int snd_pcm_hw_refine_old_user(struct snd_pcm_substream *substream,
|
||||||
}
|
}
|
||||||
snd_pcm_hw_convert_from_old_params(params, oparams);
|
snd_pcm_hw_convert_from_old_params(params, oparams);
|
||||||
err = snd_pcm_hw_refine(substream, params);
|
err = snd_pcm_hw_refine(substream, params);
|
||||||
if (err >= 0)
|
if (err < 0)
|
||||||
err = fixup_unreferenced_params(substream, params);
|
goto out_old;
|
||||||
snd_pcm_hw_convert_to_old_params(oparams, params);
|
|
||||||
if (copy_to_user(_oparams, oparams, sizeof(*oparams))) {
|
|
||||||
if (!err)
|
|
||||||
err = -EFAULT;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
err = fixup_unreferenced_params(substream, params);
|
||||||
|
if (err < 0)
|
||||||
|
goto out_old;
|
||||||
|
|
||||||
|
snd_pcm_hw_convert_to_old_params(oparams, params);
|
||||||
|
if (copy_to_user(_oparams, oparams, sizeof(*oparams)))
|
||||||
|
err = -EFAULT;
|
||||||
|
out_old:
|
||||||
kfree(oparams);
|
kfree(oparams);
|
||||||
out:
|
out:
|
||||||
kfree(params);
|
kfree(params);
|
||||||
|
@ -3729,14 +3737,16 @@ static int snd_pcm_hw_params_old_user(struct snd_pcm_substream *substream,
|
||||||
err = PTR_ERR(oparams);
|
err = PTR_ERR(oparams);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
snd_pcm_hw_convert_from_old_params(params, oparams);
|
snd_pcm_hw_convert_from_old_params(params, oparams);
|
||||||
err = snd_pcm_hw_params(substream, params);
|
err = snd_pcm_hw_params(substream, params);
|
||||||
snd_pcm_hw_convert_to_old_params(oparams, params);
|
if (err < 0)
|
||||||
if (copy_to_user(_oparams, oparams, sizeof(*oparams))) {
|
goto out_old;
|
||||||
if (!err)
|
|
||||||
err = -EFAULT;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
snd_pcm_hw_convert_to_old_params(oparams, params);
|
||||||
|
if (copy_to_user(_oparams, oparams, sizeof(*oparams)))
|
||||||
|
err = -EFAULT;
|
||||||
|
out_old:
|
||||||
kfree(oparams);
|
kfree(oparams);
|
||||||
out:
|
out:
|
||||||
kfree(params);
|
kfree(params);
|
||||||
|
|
Loading…
Reference in New Issue