Hi, On Wed, Mar 08, 2023 at 03:57:38PM -0800, Wesley Cheng wrote: > diff --git a/sound/usb/qcom/qc_audio_offload.c b/sound/usb/qcom/qc_audio_offload.c > new file mode 100644 > index 000000000000..2663906644f2 > --- /dev/null > +++ b/sound/usb/qcom/qc_audio_offload.c > ... > +static int enable_audio_stream(struct snd_usb_substream *subs, > + snd_pcm_format_t pcm_format, > + unsigned int channels, unsigned int cur_rate, > + int datainterval) > +{ > + struct snd_usb_audio *chip = subs->stream->chip; > + struct snd_pcm_hw_params params; > + const struct audioformat *fmt; > + int ret; > + bool fixed_rate; > + > + _snd_pcm_hw_params_any(¶ms); > + _snd_pcm_hw_param_set(¶ms, SNDRV_PCM_HW_PARAM_FORMAT, > + (__force int) pcm_format, 0); > + _snd_pcm_hw_param_set(¶ms, SNDRV_PCM_HW_PARAM_CHANNELS, > + channels, 0); > + _snd_pcm_hw_param_set(¶ms, SNDRV_PCM_HW_PARAM_RATE, > + cur_rate, 0); I think the above code is equivalent to below code. ``` // 1. Initialize the hardware parameter so that it expresses // the maximum flags of mask parameters and the maximum range of integer // parameters. _snd_pcm_hw_params_any(¶ms); // 2. Then shrink the mask parameters and integer parameters. struct snd_mask *mask; struct snd_interval *interval; mask = hw_param_mask(params, SNDRV_PCM_HW_PARAM_FORMAT); snd_mask_leave(mask, pcm_format); interval = hw_param_interval(params, SNDRV_PCM_HW_PARAM_CHANNELS); snd_interval_setinteger(&interval); interval.min = interval.max = channels; interval = hw_param_interval(params, SNDRV_PCM_HW_PARAM_RATE); snd_interval_setinteger(&interval); interval.min = interval.max = cur_rate; ``` In '[PATCH v3 10/28] sound: usb: Export USB SND APIs for modules', some codes moved from ALSA Open Sound System compatibility layer to ALSA core to export some kernel APIs. The '_snd_pcm_hw_param_set()' is one of them. If they were needed just for the above operations, it would be exaggerating just for the driver. Of course, we can assume that the similar kernel API would be required for the other drivers (OSS PCM, USB gadget, and so on.). However, at present, it is preferable to focus just on your driver. (I note that typical sound PCM driver has code to shrink hardware parameters in PCM rule. It consists of a set of test and refine API.) Regards Takashi Sakamoto