From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-wm0-f41.google.com ([74.125.82.41]:33503 "EHLO mail-wm0-f41.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750734AbbKYJ4N (ORCPT ); Wed, 25 Nov 2015 04:56:13 -0500 Subject: Re: [PATCH] TTY: n_gsm, fix false positive WARN_ON To: xinhui , Greg Kroah-Hartman References: <1448384067-27300-1-git-send-email-jslaby@suse.cz> <56555613.1040502@linux.vnet.ibm.com> Cc: dvyukov@google.com, linux-kernel@vger.kernel.org, Alan Cox , stable From: Jiri Slaby Message-ID: <565585B9.4040706@suse.cz> Date: Wed, 25 Nov 2015 10:56:09 +0100 MIME-Version: 1.0 In-Reply-To: <56555613.1040502@linux.vnet.ibm.com> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Sender: stable-owner@vger.kernel.org List-ID: Hi, On 11/25/2015, 07:32 AM, xinhui wrote: > This warning should blame on commit 5a640967 ("tty/n_gsm.c: fix a > memory leak in gsmld_open()"). Oh, yes, I messed up the "Fixes" line then. It should write: Fixes: 5a640967 ("tty/n_gsm.c: fix a memory leak in gsmld_open()") > I have one confusion. As there is field gsm->num to store the index of > gsm_mux[]. so in gsm_cleanup_mux(), why we still use for-loop to find > this mux? > > In error handle path, for example, the call trace in this patch, as we > failed to activate it and the > gsm->num is invalid(and the value is 0). we can just modify the codes > like below: > > if(gsm_mux[gsm->num] == gsm) > ....other work > else > return; > > I think it would work, and the logic is correct. Or I just miss > something important? Yup, it looks like a cleanup. Could you prepare a separate patch for that? Something like this: /* open failed before registering => nothing to do */ if (gsm_mux[gsm->num] != gsm) return; spin_lock(&gsm_mux_lock); gsm_mux[gsm->num] = NULL; spin_unlock(&gsm_mux_lock); thanks, -- js suse labs