Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp166248rdb; Tue, 5 Dec 2023 01:43:59 -0800 (PST) X-Google-Smtp-Source: AGHT+IHWEwu94iTeqKlh4+R/HuePNOPWr+OBKY6pJufnX0gCCkCNwe0I+ZAgpUmo8iKkorPzONLf X-Received: by 2002:a05:6a21:184:b0:18b:b04e:6c30 with SMTP id le4-20020a056a21018400b0018bb04e6c30mr3577965pzb.20.1701769439344; Tue, 05 Dec 2023 01:43:59 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701769439; cv=none; d=google.com; s=arc-20160816; b=hKqAvM4P7B+6CW6n4XAowe11lbnjcSLw54vNIkLXtquo4WqR/7zM3C0kBOjq27F+dA DtMQ9ejEHRalI5DddeVLjgTuZiFc+il5sK1Nk4wHD1kw8/rMN25sR3vCfF5wEGYVzIem jibbze7WstRlh+Uh8hPyuZ2OtIGwbBu+ddFfIQVrgJFv1DPePExgFbPMEa36vCgh2E0b DrDHtXReHsSe4G9RAbG/kAswKdbk4SXtstybpzBJ/98y9kakCuB+oIG8vqRaRZCH7/IF NnNXAZ4sNLhXNme07bZRWbk1alADPYDigwUfOVJXf+hwnQ05Rq9t41gBJTxdqZaqN8RL OKQA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :content-language:references:cc:to:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=cFS01VD4h5dZj4eDK9RGOzOt5GyS1miUs2op5CacH1c=; fh=ZKxlDNMeKur+ZwY1oGBsi1ycwpPpfbNeyW5EjnLXn90=; b=GNRPC7nc3rVNjDpR8SLEDJS4nx+hmwntd0lnvGliSzClw9IohKqN+wRgnwESxk1GyG pwx7t7ckNwyx7WP8FMNCODzXrO7EuWLxrdfDVhRyVIZCn45WW7NQA5OOEGc89fgL9ocw tQlcHrKKYra3iM0FHDh04ZTekRC64gTUVu1WC6kgb2pK4hU59m230RdzYbvupkTEKJD2 9Va+4A+FgfeLcai31mOeRoUPwfYUHFZIcbI6CLobWMZ5FTSSVlQcU/0CXsqB+rS1F8H7 OmmDdKbTn9lZ7bhwUGlMFJTLhk5u1Ojv+KS209KQ95BEQgjuSXHhUqPMg0rOo+Xd0SDs H/Ew== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=G9fbCebf; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from snail.vger.email (snail.vger.email. [23.128.96.37]) by mx.google.com with ESMTPS id w15-20020a63d74f000000b005bdbd683601si9584078pgi.57.2023.12.05.01.43.58 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 05 Dec 2023 01:43:59 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) client-ip=23.128.96.37; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=G9fbCebf; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by snail.vger.email (Postfix) with ESMTP id 22786806A432; Tue, 5 Dec 2023 01:43:58 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at snail.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231778AbjLEJnn (ORCPT + 99 others); Tue, 5 Dec 2023 04:43:43 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59788 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235401AbjLEJnj (ORCPT ); Tue, 5 Dec 2023 04:43:39 -0500 Received: from mgamail.intel.com (mgamail.intel.com [192.198.163.11]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 37B9D1B1; Tue, 5 Dec 2023 01:43:41 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1701769421; x=1733305421; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=7Xx8hTm4tgt1WkYv+D9huMLfFJ1VJtxyGkuW4UZy5kA=; b=G9fbCebfZ6qHXY1OS1tiZ0HYFozV14HDo98wrHpr3+mSmIl7a9p2qY8g jJbqvJRRhQVONlmFYUUbzp9LWREqoBcp/r4DaKcP3YBcIIXO/VLWkVaj+ vvxlILUZb86scri2wI7wwTQzIIdHn4dNRTvzJNo4psF9uTpnOj9rpp87h 9s+vei3x3wSjDNmK/a0X2dBASbFvB462AA6bAPXJ3o2wolyyTiSQn4Wli mZC90EAPf8jrjoFWef7UDDWmieewTTHboBt038ZkEHt+bQTpVW5aNtap2 awmLLXYNZojmzKmfDa4SkX3QpTYw/W0D8YWrRimeqf3x3Z6Mrr6oqUSK8 g==; X-IronPort-AV: E=McAfee;i="6600,9927,10914"; a="711883" X-IronPort-AV: E=Sophos;i="6.04,251,1695711600"; d="scan'208";a="711883" Received: from fmviesa001.fm.intel.com ([10.60.135.141]) by fmvoesa105.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 05 Dec 2023 01:43:41 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.04,251,1695711600"; d="scan'208";a="17345940" Received: from nathanby-mobl2.ger.corp.intel.com (HELO [10.252.61.50]) ([10.252.61.50]) by smtpauth.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 05 Dec 2023 01:43:37 -0800 Message-ID: <74ba8770-6174-4820-8dc4-e97e5814e665@linux.intel.com> Date: Tue, 5 Dec 2023 11:44:16 +0200 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH] ASoC: SOF: Fix null pointer dereference in sof_pci_probe To: Kunwu Chan , pierre-louis.bossart@linux.intel.com, lgirdwood@gmail.com, yung-chuan.liao@linux.intel.com, ranjani.sridharan@linux.intel.com, daniel.baluta@nxp.com, kai.vehmanen@linux.intel.com, broonie@kernel.org, perex@perex.cz, tiwai@suse.com, chao.song@intel.com Cc: kunwu.chan@hotmail.com, sound-open-firmware@alsa-project.org, linux-sound@vger.kernel.org, linux-kernel@vger.kernel.org References: <20231123155424.1275919-1-chentao@kylinos.cn> <1701766721668457.408.seg@mailgw> <55c00bb3-b795-4698-ba3f-56d10df1882a@kylinos.cn> Content-Language: en-US From: =?UTF-8?Q?P=C3=A9ter_Ujfalusi?= In-Reply-To: <55c00bb3-b795-4698-ba3f-56d10df1882a@kylinos.cn> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_EF,SPF_HELO_NONE,SPF_NONE, T_SCC_BODY_TEXT_LINE autolearn=ham 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 X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (snail.vger.email [0.0.0.0]); Tue, 05 Dec 2023 01:43:58 -0800 (PST) On 05/12/2023 11:10, Kunwu Chan wrote: > It's my bad, i'll follow your suggestion in v2 patch: > 1. remove 'Fixes: 46207ca24545' label > > 2. rename subject to 'ASoC: SOF: Add null pointer check to sof_pci_probe' > > 3. when sof_pdata->fw_filename_prefix is NULL,don't use it to dev_dbg. > Or just use a > if (sof_pdata->fw_filename_prefix) >         dev_dbg(dev, >                 "Platform uses community key, changed fw path to %s\n", >                 sof_pdata->fw_filename_prefix); > else >     dev_dbg(dev, >                 "Platform uses community key, changed fw path to %s/%s\n", >                  sof_pdata->desc->default_fw_path[sof_pdata->ipc_type], >                  "community"); > > Is it okay to modify it like this? The code has been rewritten and all of these issues have been eliminated, fixed in core SOF. > > > Thanks, > Kunwu > > On 2023/12/4 19:34, Péter Ujfalusi wrote: >> >> >> On 23/11/2023 17:54, Kunwu Chan wrote: >>> devm_kasprintf() returns a pointer to dynamically allocated memory >>> which can be NULL upon failure. >>> >>> Fixes: 46207ca24545 ("ASoC: SOF: pci: change the default firmware >>> path when the community key is used") >>> Fixes: 25bbc0c59ee1 ("ASoC: SOF: Add path definition for external >>> firmware libraries") >>> Signed-off-by: Kunwu Chan >> >> This patch cannot fix both commits as at 46207ca24545 the lib path was >> not present. >> Please don't bundle unrelated fixes, it makes maintainers life harder. >> >> As a note: if the allocation fails it is not going to cause null >> dereference as the code checks !sof_pdata->*_prefix to see if it is >> provided (override) or not (use default). >> At most it will cause the kernel to 'ignore' the path override, but if >> this allocation fails this is least of our problem ;) >> >>> --- >>>   sound/soc/sof/sof-pci-dev.c | 8 ++++++++ >>>   1 file changed, 8 insertions(+) >>> >>> diff --git a/sound/soc/sof/sof-pci-dev.c b/sound/soc/sof/sof-pci-dev.c >>> index 64b326e3ef85..75a9bfa5bfbe 100644 >>> --- a/sound/soc/sof/sof-pci-dev.c >>> +++ b/sound/soc/sof/sof-pci-dev.c >>> @@ -282,6 +282,10 @@ int sof_pci_probe(struct pci_dev *pci, const >>> struct pci_device_id *pci_id) >>>               devm_kasprintf(dev, GFP_KERNEL, "%s/%s", >>>                          >>> sof_pdata->desc->default_fw_path[sof_pdata->ipc_type], >>>                          "community"); >>> +        if (!sof_pdata->fw_filename_prefix) { >>> +            ret = -ENOMEM;    >>> +            goto out; >>> +        } >>>             dev_dbg(dev, >>>               "Platform uses community key, changed fw path to %s\n", >>> @@ -303,6 +307,10 @@ int sof_pci_probe(struct pci_dev *pci, const >>> struct pci_device_id *pci_id) >>>                   devm_kasprintf(dev, GFP_KERNEL, "%s/%s", >>>                       >>> sof_pdata->desc->default_lib_path[sof_pdata->ipc_type], >>>                       "community"); >>> +            if (!sof_pdata->fw_lib_prefix) { >>> +                ret = -ENOMEM; >>> +                goto out; >>> +            } >>>                 dev_dbg(dev, >>>                   "Platform uses community key, changed fw_lib path >>> to %s\n", >> -- Péter