Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp577928pxu; Fri, 4 Dec 2020 10:06:54 -0800 (PST) X-Google-Smtp-Source: ABdhPJyFygW8u3xZEU9suqOVE7zIRfE3itB2B462sAzYHwordAJ2UYi0imy71qbtOH7lT+Z1Mc4g X-Received: by 2002:a17:906:f87:: with SMTP id q7mr8535866ejj.530.1607105213776; Fri, 04 Dec 2020 10:06:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607105213; cv=none; d=google.com; s=arc-20160816; b=Xnm1WoMGza1Fg6sXDZkb4+miKBs0iMhlCb0UuLqhvFUDZVioQCrL8zVpQ8tjnmDCIZ RLJZh1l/uy+PMnOne+nLbxUiwY7Y9TK1y+W/cIBGj9njvunZf+ENVH9Nch4vJ2bBNUpp jb3lCW8GjG8xsfEIVre/g04lXhf9OybygF/n6RGk8+4x+9MsLqDQ3dhOwyJlas49gaq+ R4KB1GX4f3J6ALxm7mA3HsThVsrfoSZwK8uoJAmiC6xfdhHxSC644+V2leTjGpjWL3WM OsGwT3FyfbYjYoD+/rpTdp+W4lRnH6mbVk+B7a3WylHqrCJ5PYJfdwDsL5D9f8UebK6v fksg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=e+Njf8NG6+fsYlsC9GMzSFpNhGjLZL8pv+AFfjpqRlM=; b=wmwaMeKDVFzApfb6QsJ51JQ5XSUzTR4+t5t0dVptDEjvzM0xKG+gVtgtlpHKBGA1wk 157V6tfUdU8D7xt52I3aiAzRL5nuh6SwQREZggGsVnBSEo4Gd8WBHiZLuMFLDazy3Rai wOiL4bLZQlxeSa+cP1pRgscoziwC5Ou1SHQg5HgjQs7tVKRZv4N+WkWJW0ByMD0DATMW ekzAdHfOvJYIExlkd6gvYW27gw5dlmIKTNvGqVM/H2zphKnpsDp/qgG99XfwzyWqty67 i+Czk0AgjP+im5yyMw1fGvCNfyWsS97FAif7sOpTEfR6U4TuVO6/qJEeMbP2hXMycW5m Kgig== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=cKXpELug; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h2si3418005edl.367.2020.12.04.10.06.30; Fri, 04 Dec 2020 10:06:53 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=cKXpELug; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728662AbgLDSEE (ORCPT + 99 others); Fri, 4 Dec 2020 13:04:04 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42542 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726775AbgLDSEE (ORCPT ); Fri, 4 Dec 2020 13:04:04 -0500 Received: from mail-pf1-x442.google.com (mail-pf1-x442.google.com [IPv6:2607:f8b0:4864:20::442]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2F8ECC0613D1 for ; Fri, 4 Dec 2020 10:03:24 -0800 (PST) Received: by mail-pf1-x442.google.com with SMTP id d2so380946pfq.5 for ; Fri, 04 Dec 2020 10:03:24 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=e+Njf8NG6+fsYlsC9GMzSFpNhGjLZL8pv+AFfjpqRlM=; b=cKXpELugaWOipTb/KvYJWMqSQbUwnR8wbCWrW8c7uSz2Usy77z7+aCH07etKFMY27n sh3KA2AhWZnqwb5F67/SUCNnUHy+ZUwzFYwwv1YlV4yrJgdec0u9/VjeqTtYiE3qYl0o t8p0TvFx+vq4mN5G2cXbQ9hFKCy2XgRKm3kodIBOOemE+BCCd5pdWhucQfyV4W5hM01q Nt+Ty2vYmlUclZ0N0euG3zaw9ahs4GALX/79GPjkGCbkdRkKLy7urTYxFCVbBv6IpGQW SealJ7WTleTqcIHcmbuvksZj/Np9C5tVB23/Hqt6YoWn2X3bodAQwkTHOKjD57eS/+PS S1fQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=e+Njf8NG6+fsYlsC9GMzSFpNhGjLZL8pv+AFfjpqRlM=; b=sUhzyZchAleNUIE3ayWLc1qDIovWS0f0C85r7TcHpgrq2oGlV0CCPwVvYr9plXvkzh BNDXqXsLr30elrV5CtxKJbkmtOkuiNk1T2dKlY+3gPv7O9aTFPd+DYDaEjSaCSLP8lx+ z4WzlGpBol48HZgat+eZMqEQ4Wul2Yd8oWqn0jYYZ8bq1RK7HP6MUCWTkAll16dErL4U SfWwABAmqnlFIFzxTFSY56eZDk5oBiNX8QoEB1a6o5Gi/c+6XJ96cN+5wIjcGeoLga7z 90pI/08U7F7SKhgoSbQxaAm+MVn5+V/+BwNmH6os6EPG16+49d94xWzcFiMBmsey4JMb g18Q== X-Gm-Message-State: AOAM530bxkBWq9ysqpu6Ad6jPUcvt5eQ+KqLhSZNUoqIKd3yjpoo3i0c 0UWNvA3ydBR5oFRGzoG+MKVAhlhrkXQOeY3Q3Fk= X-Received: by 2002:aa7:9414:0:b029:18c:23f6:bc6d with SMTP id x20-20020aa794140000b029018c23f6bc6dmr4922931pfo.21.1607105003635; Fri, 04 Dec 2020 10:03:23 -0800 (PST) MIME-Version: 1.0 References: <20201204021350.28182-1-wanghai38@huawei.com> In-Reply-To: From: Vaibhav Agarwal Date: Fri, 4 Dec 2020 23:32:47 +0530 Message-ID: Subject: Re: [PATCH] staging: greybus: audio: Add missing unlock in gbaudio_dapm_free_controls() To: Johan Hovold Cc: Wang Hai , Alex Elder , Greg Kroah-Hartman , Dan Carpenter , aibhav.sr@gmail.com, "moderated list:GREYBUS SUBSYSTEM" , devel@driverdev.osuosl.org, open list Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Dec 4, 2020 at 2:10 PM Johan Hovold wrote: > > On Fri, Dec 04, 2020 at 10:13:50AM +0800, Wang Hai wrote: > > Add the missing unlock before return from function > > gbaudio_dapm_free_controls() in the error handling case. > > > > Fixes: 510e340efe0c ("staging: greybus: audio: Add helper APIs for dynamic audio module") > > Reported-by: Hulk Robot > > Signed-off-by: Wang Hai > > --- > > drivers/staging/greybus/audio_helper.c | 1 + > > 1 file changed, 1 insertion(+) > > > > diff --git a/drivers/staging/greybus/audio_helper.c b/drivers/staging/greybus/audio_helper.c > > index 237531ba60f3..293675dbea10 100644 > > --- a/drivers/staging/greybus/audio_helper.c > > +++ b/drivers/staging/greybus/audio_helper.c > > @@ -135,6 +135,7 @@ int gbaudio_dapm_free_controls(struct snd_soc_dapm_context *dapm, > > if (!w) { > > dev_err(dapm->dev, "%s: widget not found\n", > > widget->name); > > + mutex_unlock(&dapm->card->dapm_mutex); > > return -EINVAL; > > } > > widget++; > > This superficially looks correct, but there seems to be another bug in > this function. It can be used free an array of widgets, but if one of > them isn't found we just leak the rest. Perhaps that return should > rather be "widget++; continue;". > > Vaibhav? Thanks Wang for sharing the patch. As already pointed by Johan, this function indeed has another bug as well. Pls feel free to share the patch as suggested above. -- vaibhav > > Johan