ALSA: hda: Fix possible null-ptr-deref when assigning a stream
While AudioDSP drivers assign streams exclusively of HOST or LINK type, nothing blocks a user to attempt to assign a COUPLED stream. As supplied substream instance may be a stub, what is the case when code-loading, such scenario ends with null-ptr-deref. Signed-off-by: Cezary Rojewski <cezary.rojewski@intel.com> Link: https://lore.kernel.org/r/20231006102857.749143-2-cezary.rojewski@intel.com Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
fdfc374af5
commit
f93dc90c2e
@ -362,8 +362,10 @@ struct hdac_stream *snd_hdac_stream_assign(struct hdac_bus *bus,
|
|||||||
struct hdac_stream *res = NULL;
|
struct hdac_stream *res = NULL;
|
||||||
|
|
||||||
/* make a non-zero unique key for the substream */
|
/* make a non-zero unique key for the substream */
|
||||||
int key = (substream->pcm->device << 16) | (substream->number << 2) |
|
int key = (substream->number << 2) | (substream->stream + 1);
|
||||||
(substream->stream + 1);
|
|
||||||
|
if (substream->pcm)
|
||||||
|
key |= (substream->pcm->device << 16);
|
||||||
|
|
||||||
spin_lock_irq(&bus->reg_lock);
|
spin_lock_irq(&bus->reg_lock);
|
||||||
list_for_each_entry(azx_dev, &bus->stream_list, list) {
|
list_for_each_entry(azx_dev, &bus->stream_list, list) {
|
||||||
|
Loading…
Reference in New Issue
Block a user