Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp572837ybz; Fri, 24 Apr 2020 05:41:12 -0700 (PDT) X-Google-Smtp-Source: APiQypK31oI2qG15agXTQ/fodaPZ9Tt4QAygQvo9zcKHfJniljhLCySsk0gVluKSHgNlmyZXVSef X-Received: by 2002:a17:906:f106:: with SMTP id gv6mr7157161ejb.271.1587732071916; Fri, 24 Apr 2020 05:41:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587732071; cv=none; d=google.com; s=arc-20160816; b=XupNDrYPYZ/Y38ex5HU5rVgdWrMVVP7kwGSoDVYakNJJ/GtZVOkDPjRnTjqaaeAk4o qPEdwd87TYBVQwa+ltCiJrFxOoN9XmGjyjHU4h/OYta1E5c7ijOztYVdV5nmvH49sie0 O1KMJLg9UyUkcMjgpD2nX1+1QcWzWgfLSomP9ickzzZdbPecem/5ivnZObBgdDP34/E9 oACvO8r0Av0uGjuwt834ghcI0HAOd8W28xr+qE9JNgNo3m+9HKTUdS2k+o6fWoSLiDdw otkSufSTiG4w1OX/QHkBXNAhnbxe59JyUdiU9XxKe1qz5ak4ddCmq7D7vQcfFdX8GKHl zOZw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=1Gyjk97qxvl/xf9123F07QGpiGEq3apjVrV8opTv7Wg=; b=hozyOpgSKZyGwiMsFGBW9H7bjLOMkuB2IasO3tmgl0HVX8KQ0oBt/CtHYMq5rKtWgW 0rGg2vVLjt5oXIzWAGVF1qBWIu4sc7sK2JcuCFWhg+sDMY4NHRe6MqBMnVhseg3r8PG0 iC8HtVuQDEcpPaCCXG9VhU6tJ9qdkMvUs/SUbiF5Id7eBB4eQ73HQMtJ8G798M5KDLkN XiLZUGA0jnLz56QwFQ+I5Jbhg7KO4N898hFCf8tq+qGkcGSUOIWitY4QiBnJBYpYiadt iK9J4PEeGM/tIHdnXTLRORFCyZyXyX+D7nCHaY5hBKvOQT0E6wbMkn5NrTmtWblbRHTe 5MFw== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id lw9si2878849ejb.175.2020.04.24.05.40.47; Fri, 24 Apr 2020 05:41:11 -0700 (PDT) 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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726997AbgDXMio (ORCPT + 99 others); Fri, 24 Apr 2020 08:38:44 -0400 Received: from inva020.nxp.com ([92.121.34.13]:59524 "EHLO inva020.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726489AbgDXMin (ORCPT ); Fri, 24 Apr 2020 08:38:43 -0400 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 875331A03CA; Fri, 24 Apr 2020 14:38:41 +0200 (CEST) Received: from invc005.ap-rdc01.nxp.com (invc005.ap-rdc01.nxp.com [165.114.16.14]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 067471A03BE; Fri, 24 Apr 2020 14:38:37 +0200 (CEST) Received: from localhost.localdomain (shlinux2.ap.freescale.net [10.192.224.44]) by invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id 24BD8402C7; Fri, 24 Apr 2020 20:38:31 +0800 (SGT) From: Shengjiu Wang To: timur@kernel.org, nicoleotsuka@gmail.com, Xiubo.Lee@gmail.com, festevam@gmail.com, broonie@kernel.org, alsa-devel@alsa-project.org, lgirdwood@gmail.com, perex@perex.cz, tiwai@suse.com Cc: linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org Subject: [PATCH] ASoC: fsl_easrc: Check NULL pinter before dereference Date: Fri, 24 Apr 2020 20:30:04 +0800 Message-Id: <1587731404-29750-1-git-send-email-shengjiu.wang@nxp.com> X-Mailer: git-send-email 2.7.4 X-Virus-Scanned: ClamAV using ClamSMTP Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The patch 955ac624058f: "ASoC: fsl_easrc: Add EASRC ASoC CPU DAI drivers" from Apr 16, 2020, leads to the following Smatch complaint: sound/soc/fsl/fsl_easrc.c:1529 fsl_easrc_hw_free() warn: variable dereferenced before check 'ctx' (see line 1527) sound/soc/fsl/fsl_easrc.c 1526 struct fsl_asrc_pair *ctx = runtime->private_data; 1527 struct fsl_easrc_ctx_priv *ctx_priv = ctx->private; ^^^^^ Dereference 1528 1529 if (ctx && (ctx_priv->ctx_streams & BIT(substream->stream))) { ^^^ This check is too late, to prevent a NULL dereference. 1530 ctx_priv->ctx_streams &= ~BIT(substream->stream); 1531 fsl_easrc_release_context(ctx); Fixes: 955ac624058f ("ASoC: fsl_easrc: Add EASRC ASoC CPU DAI drivers") Reported-by: Dan Carpenter Signed-off-by: Shengjiu Wang --- sound/soc/fsl/fsl_easrc.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/sound/soc/fsl/fsl_easrc.c b/sound/soc/fsl/fsl_easrc.c index 97658e1f4989..20326bffab64 100644 --- a/sound/soc/fsl/fsl_easrc.c +++ b/sound/soc/fsl/fsl_easrc.c @@ -1524,9 +1524,14 @@ static int fsl_easrc_hw_free(struct snd_pcm_substream *substream, { struct snd_pcm_runtime *runtime = substream->runtime; struct fsl_asrc_pair *ctx = runtime->private_data; - struct fsl_easrc_ctx_priv *ctx_priv = ctx->private; + struct fsl_easrc_ctx_priv *ctx_priv; + + if (!ctx) + return -EINVAL; + + ctx_priv = ctx->private; - if (ctx && (ctx_priv->ctx_streams & BIT(substream->stream))) { + if (ctx_priv->ctx_streams & BIT(substream->stream)) { ctx_priv->ctx_streams &= ~BIT(substream->stream); fsl_easrc_release_context(ctx); } -- 2.21.0