Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932119AbWI2KzA (ORCPT ); Fri, 29 Sep 2006 06:55:00 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S932156AbWI2KzA (ORCPT ); Fri, 29 Sep 2006 06:55:00 -0400 Received: from ns.suse.de ([195.135.220.2]:39117 "EHLO mx1.suse.de") by vger.kernel.org with ESMTP id S932119AbWI2Ky7 (ORCPT ); Fri, 29 Sep 2006 06:54:59 -0400 Date: Fri, 29 Sep 2006 12:54:57 +0200 Message-ID: From: Takashi Iwai To: Florin Malita Cc: perex@suse.cz, linux-kernel@vger.kernel.org Subject: Re: [PATCH] Dereference after free in snd_hwdep_release() In-Reply-To: <451C5EAE.3050309@gmail.com> References: <451C5EAE.3050309@gmail.com> User-Agent: Wanderlust/2.12.0 (Your Wildest Dreams) SEMI/1.14.6 (Maruoka) FLIM/1.14.7 (=?ISO-8859-4?Q?Sanj=F2?=) APEL/10.6 MULE XEmacs/21.5 (beta25) (eggplant) (+CVS-20060326) (i386-suse-linux) MIME-Version: 1.0 (generated by SEMI 1.14.6 - "Maruoka") Content-Type: text/plain; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1197 Lines: 45 At Thu, 28 Sep 2006 19:45:50 -0400, Florin Malita wrote: > > snd_card_file_remove() may free hw->card so we can't dereference > hw->card->module after that. > > Coverity ID 1420. > > Signed-off-by: Florin Malita Thanks! Applied to ALSA tree now. Takashi > --- > > diff --git a/sound/core/hwdep.c b/sound/core/hwdep.c > index 9aa9d94..46b4768 100644 > --- a/sound/core/hwdep.c > +++ b/sound/core/hwdep.c > @@ -158,6 +158,7 @@ static int snd_hwdep_release(struct inod > { > int err = -ENXIO; > struct snd_hwdep *hw = file->private_data; > + struct module *mod = hw->card->module; > mutex_lock(&hw->open_mutex); > if (hw->ops.release) { > err = hw->ops.release(hw, file); > @@ -167,7 +168,7 @@ static int snd_hwdep_release(struct inod > hw->used--; > snd_card_file_remove(hw->card, file); > mutex_unlock(&hw->open_mutex); > - module_put(hw->card->module); > + module_put(mod); > return err; > } > > > - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/