diff mbox

PATCH: ALSA: hda: fix possible null dereference

Message ID 20150824101740.GA13757@mo-online.de (mailing list archive)
State New, archived
Headers show

Commit Message

Markus Osterhoff Aug. 24, 2015, 10:17 a.m. UTC
Dear Takashi,

maybe I am mistaken or have not made my patch clear, please let me
apologise.

* Takashi Iwai <tiwai@suse.de> [150824 08:30]:
> On Sun, 23 Aug 2015 20:37:05 +0200,
> Markus Osterhoff wrote:
> > With commits bbbc7e85 and 751e2216, a for-loop was restated using
> > list_for_each_entry(...); originally, a local pcm* was extracted from an array
> > and checked against NULL, if not-NULL then passed along to
> > snd_pcm_add_chmap_ctls(...).
> > 
> > For a history of the function in question, have a look at lines 2430ff for
> > 	git diff v4.0 v4.1 sound/pci/hda/hda_codec.c
> > 
> > The two commits that touched this function are
> > Commit bbbc7e8502c9 ("ALSA: hda - Allocate hda_pcm objects dynamically")
> > Commit 751e2216899c ("ALSA: hda: fix possible null dereference")
> > 
> > where the latter only fixes the order of two fixes, but not the pcm / pcm->pcm confusion.

> Thanks for the patch.  But this was already fixed by commit
> 751e2216899c in 4.1-rc1.
So I re-checked and diff'ed against the current v4.2-rc8 and found that
the if-statement reads, /sound/pci/hda/hda_codec.c, line 3172:
	if (!pcm || pcm->own_chmap ||
while I propose
	if (!pcm->pcm || pcm->own_chmap ||

With the mentioned 751e2216899c I do get a NULL dereference (for
whatever reason), because pcm->pcm can indeed by NULL inside the loop. Please
reconsider the patch:

> Takashi
Thanks for your time, Markus


Signed-off-by: Markus Osterhoff <linux-kernel@k-raum.org>
---
 sound/pci/hda/hda_codec.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

Comments

Takashi Iwai Aug. 24, 2015, 10:25 a.m. UTC | #1
On Mon, 24 Aug 2015 12:17:40 +0200,
Markus Osterhoff wrote:
> 
> Dear Takashi,
> 
> maybe I am mistaken or have not made my patch clear, please let me
> apologise.
> 
> * Takashi Iwai <tiwai@suse.de> [150824 08:30]:
> > On Sun, 23 Aug 2015 20:37:05 +0200,
> > Markus Osterhoff wrote:
> > > With commits bbbc7e85 and 751e2216, a for-loop was restated using
> > > list_for_each_entry(...); originally, a local pcm* was extracted from an array
> > > and checked against NULL, if not-NULL then passed along to
> > > snd_pcm_add_chmap_ctls(...).
> > > 
> > > For a history of the function in question, have a look at lines 2430ff for
> > > 	git diff v4.0 v4.1 sound/pci/hda/hda_codec.c
> > > 
> > > The two commits that touched this function are
> > > Commit bbbc7e8502c9 ("ALSA: hda - Allocate hda_pcm objects dynamically")
> > > Commit 751e2216899c ("ALSA: hda: fix possible null dereference")
> > > 
> > > where the latter only fixes the order of two fixes, but not the pcm / pcm->pcm confusion.
> 
> > Thanks for the patch.  But this was already fixed by commit
> > 751e2216899c in 4.1-rc1.
> So I re-checked and diff'ed against the current v4.2-rc8 and found that
> the if-statement reads, /sound/pci/hda/hda_codec.c, line 3172:
> 	if (!pcm || pcm->own_chmap ||
> while I propose
> 	if (!pcm->pcm || pcm->own_chmap ||

Then your previous patch did exactly opposite :)

> With the mentioned 751e2216899c I do get a NULL dereference (for
> whatever reason), because pcm->pcm can indeed by NULL inside the loop. Please
> reconsider the patch:

Actually you're trying to shoot two things in a shot, and it's
confusing.  What we need is to *add* the NULL check of pcm->pcm.  It's
basically different from replacing pcm NULL check itself.
The pcm NULL check is superfluous, indeed, and can be removed.  But
it can be done in a different patch, or mention properly in the
changelog.

Could you revisit your patch with the proper description?


thanks,

Takashi

> 
> > Takashi
> Thanks for your time, Markus
> 
> 
> Signed-off-by: Markus Osterhoff <linux-kernel@k-raum.org>
> ---
>  sound/pci/hda/hda_codec.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/sound/pci/hda/hda_codec.c b/sound/pci/hda/hda_codec.c
> index 5de3c5d..47206b9 100644
> --- a/sound/pci/hda/hda_codec.c
> +++ b/sound/pci/hda/hda_codec.c
> @@ -3172,7 +3172,7 @@ static int add_std_chmaps(struct hda_codec *codec)
>                         struct snd_pcm_chmap *chmap;
>                         const struct snd_pcm_chmap_elem *elem;
>  
> -                       if (!pcm || pcm->own_chmap ||
> +                       if (!pcm->pcm || pcm->own_chmap ||
>                             !hinfo->substreams)
>                                 continue;
>                         elem = hinfo->chmap ? hinfo->chmap : snd_pcm_std_chmaps;
>
diff mbox

Patch

diff --git a/sound/pci/hda/hda_codec.c b/sound/pci/hda/hda_codec.c
index 5de3c5d..47206b9 100644
--- a/sound/pci/hda/hda_codec.c
+++ b/sound/pci/hda/hda_codec.c
@@ -3172,7 +3172,7 @@  static int add_std_chmaps(struct hda_codec *codec)
                        struct snd_pcm_chmap *chmap;
                        const struct snd_pcm_chmap_elem *elem;
 
-                       if (!pcm || pcm->own_chmap ||
+                       if (!pcm->pcm || pcm->own_chmap ||
                            !hinfo->substreams)
                                continue;
                        elem = hinfo->chmap ? hinfo->chmap : snd_pcm_std_chmaps;