Received: by 2002:a5d:9c59:0:0:0:0:0 with SMTP id 25csp2163658iof; Tue, 7 Jun 2022 21:52:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzdij6FofnpI8eV9ZAgUWuBgf2UgcgQSFYjrQbTozrCK7nn7lJvVlUslp5l6JfwMn3iP6Gm X-Received: by 2002:a65:6044:0:b0:3fc:674:8f5a with SMTP id a4-20020a656044000000b003fc06748f5amr28484325pgp.436.1654663963909; Tue, 07 Jun 2022 21:52:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654663963; cv=none; d=google.com; s=arc-20160816; b=eJ4Xj+xigARGw/e82UQ7fmSuoGoD7tahuiAMaCqkJOKqKt43LkckwEyfyyghAmMyBL e6ylJ/iQgUuoCWKJqOW6IDBnR9VbrA++rdABC/1geG/Mdd5TQmNFEeG5jlmHGZIjJ1mS YQ1ZOy9/N1ToajS/dCfI6jqrfn+AKvYIFCu2RteNuPCYiI4kZgfAGUOqr3tQNVVdiMk6 UVTb5zyB2dQhVxjR2pRN5pcFJ8gjpN3UZF7zplK2u/+ZC1FvksWlOJvVBmO4k942w1ml pxdmwt3NYcjWfuaLvTCTUOPWAva6vpEQ8mcjqqWk3mmcTyIzsu8uvFsltHZi3Jtpbwlo rrvQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=ZPDQ3AiTUzJCwH53+VaufRUznlYpHKZyQp45nGTLhtc=; b=I5PhA2OwC7X6QER8yhddnqVF8LUOSBh+QkDm9jdNESCvLng5ipB7klaJ1HqYSUFG35 NenLpUhW1aFgR4GllZszoo4BrcJWWN6sIiCTCpdioD0FzBPjlMhWZeATFaC1qno8A2gG s+QwImSevN+hrCr2XYiPpOXCkLneHFuno3wBxIN3PfC114Gl0j22S7gtCY/4MlvDplKw WjBNr4iqXWk0vEphljnoc21p59sOkv3Lf4Sbc8/3voBTAs8KRYvKuWZ3PtYjhgb5VHVq axrXlNctLd9HWDpETIMmmP8G/EjdM0slTYnvcbj3csruyPGd/VeNa9lXo4rfPTb1rzIf NqNQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=YJOYP5lV; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id f4-20020a170902860400b0016786f2d1d8si8188517plo.475.2022.06.07.21.52.43 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 07 Jun 2022 21:52:43 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=YJOYP5lV; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id C5560422415; Tue, 7 Jun 2022 21:22:15 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1343962AbiFGQgj (ORCPT + 99 others); Tue, 7 Jun 2022 12:36:39 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33008 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232812AbiFGQgi (ORCPT ); Tue, 7 Jun 2022 12:36:38 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9E3DF34B88 for ; Tue, 7 Jun 2022 09:36:37 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 1904F61499 for ; Tue, 7 Jun 2022 16:36:37 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 5726AC385A5; Tue, 7 Jun 2022 16:36:36 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1654619796; bh=8i5haULdeB2Ou8xLNgGyaqjpMUp/nNMdFFzefBtFQus=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=YJOYP5lV5TwG9gnAjthINUaJCRhaAv5ayjybpS0BpNazzoGwVMj1SxQg/skv+eP2j efB3JHODISGBtLWUuzpgVu+c7ki/+9fNOmc/qm31lf8ENLQGu6USScXIR7Zd28pTdR I7xQe05KIYnjlzNRc9/HGJCmoftFlmEgqMYyxEpLsOT44uN6EThAx4V3w78k8oEVLl Mg/nn5b6OJwEzh6oB1f2a94OudqtGDnidgkmdmRttS3p3DWqamPeIm2veizy34Wt+b BYJXF201xvI3qlVaiD4trtkK1XnW2mq9C9RymqaGNWW8XM8nl6LEyESSq45YPdZeDL AsE7PUYfzdm3w== Received: from johan by xi.lan with local (Exim 4.94.2) (envelope-from ) id 1nycBz-0002GQ-7u; Tue, 07 Jun 2022 18:36:31 +0200 Date: Tue, 7 Jun 2022 18:36:31 +0200 From: Johan Hovold To: Jared Kangas Cc: vaibhav.sr@gmail.com, mgreer@animalcreek.com, elder@kernel.org, gregkh@linuxfoundation.org, greybus-dev@lists.linaro.org, linux-kernel@vger.kernel.org, linux-staging@lists.linux.dev Subject: Re: [PATCH] staging: greybus: audio: fix loop cursor use after iteration Message-ID: References: <20220605231806.720085-1-kangas.jd@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20220605231806.720085-1-kangas.jd@gmail.com> X-Spam-Status: No, score=-3.5 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,MAILING_LIST_MULTI, RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Jun 05, 2022 at 04:18:06PM -0700, Jared Kangas wrote: > gbaudio_dapm_free_controls() iterates over widgets using > list_for_each_entry_safe(), which leaves the loop cursor pointing to a > meaningless structure if it completes a traversal of the list. The > cursor was set to NULL at the end of the loop body, but would be > overwritten by the final loop cursor update. > > Because of this behavior, the widget could be non-null after the loop > even if the widget wasn't found, and the cleanup logic would treat the > pointer as a valid widget to free. > > To fix this, introduce a temporary variable to act as the loop cursor > and copy it to a variable that can be accessed after the loop finishes. > > This was detected with the help of Coccinelle. Please add the missing Fixes tag and a CC stable tag here as Dan mentioned. > Signed-off-by: Jared Kangas > --- > drivers/staging/greybus/audio_helper.c | 13 +++++++------ > 1 file changed, 7 insertions(+), 6 deletions(-) > > diff --git a/drivers/staging/greybus/audio_helper.c b/drivers/staging/greybus/audio_helper.c > index 843760675876..07461a5d97c7 100644 > --- a/drivers/staging/greybus/audio_helper.c > +++ b/drivers/staging/greybus/audio_helper.c > @@ -115,7 +115,7 @@ int gbaudio_dapm_free_controls(struct snd_soc_dapm_context *dapm, > int num) > { > int i; > - struct snd_soc_dapm_widget *w, *next_w; > + struct snd_soc_dapm_widget *w, *next_w, *tmp_w; > #ifdef CONFIG_DEBUG_FS > struct dentry *parent = dapm->debugfs_dapm; > struct dentry *debugfs_w = NULL; > @@ -124,13 +124,14 @@ int gbaudio_dapm_free_controls(struct snd_soc_dapm_context *dapm, > mutex_lock(&dapm->card->dapm_mutex); > for (i = 0; i < num; i++) { > /* below logic can be optimized to identify widget pointer */ > - list_for_each_entry_safe(w, next_w, &dapm->card->widgets, > + w = NULL; > + list_for_each_entry_safe(tmp_w, next_w, &dapm->card->widgets, This should be list_for_each_entry() as w is not unlinked in this loop. > list) { > - if (w->dapm != dapm) > - continue; > - if (!strcmp(w->name, widget->name)) > + if (tmp_w->dapm == dapm && > + !strcmp(tmp_w->name, widget->name)) { > + w = tmp_w; > break; > - w = NULL; > + } > } > if (!w) { > dev_err(dapm->dev, "%s: widget not found\n", Looks good otherwise: Reviewed-by: Johan Hovold