Received: by 2002:a05:6520:1682:b0:147:d1a0:b502 with SMTP id ck2csp5595572lkb; Mon, 11 Oct 2021 09:37:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwZ9b+TMzOKOEV7OTUaBdUHzO/wLF0a/NNvmuLfsi9pYiN7LPUYh+XquulZ9VBMXlPIc2K+ X-Received: by 2002:a63:7b42:: with SMTP id k2mr10908002pgn.14.1633970269492; Mon, 11 Oct 2021 09:37:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1633970269; cv=none; d=google.com; s=arc-20160816; b=f2N7swfkYwJeSNVF0YbPu+LhgqjT6gXVJi86kXQ0Q9kNF97BdiELrF/idcIffapLNf Lw6OKhHGKKn+TW8HcntB33i4RfDczEAc0g2VmqzfcX8Toi+Dwh6RXKl9jkg+hHIuMET+ 9D1UJ+MiTBBbqIoPSaqWqr479i9tZSkcSxy+ua0jvawqO1MdmBAFIP+wHEy3tMYhDT7J 1P/QwX6dvPPm6p+zdsyPQbBdRm3qHU4cnPwJ9usGJP6xrNg28yVTpGIKfXSBODRHMtl+ kULZU9p83MHcTJDSsEjuUJezTyjYWlp66CyElMPv5u/z/DKqRGk0XLjmaCoLPBSyFwPF /7vw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=oXfj/LdcIWi8QBGVWoLeHpPANC5aeTpAQshDalhDSsU=; b=zLS9yaWUr9ZCG3NxpWXTrsQo1ftbm54ZyWQMf0lv0HGrNB/OaWmRn9HutolDEOV7LT qFvzPIXd9XeMSVMehx5fQ+PbhywD5+i+OC6Wwpo329a9T459Z8QLtJSdrl8/yaFjqMdm mEt7cJyysIfy0XviOohC3yK/4dQ4tAKnvchxLCYzvltfRTLkgD3PYYesgdEv4R1VTxnU FVowFjwiiUm1C1EvOZK4/O6vj88oh1xg+ABZ0qxWOgqeApHN6cZaC77NHDtu7FnrEOlY 8pBEm+k+RBhXOBWgs3QjcJN7Y+eXo14aq8VXoY1tTGSEBsIpnYbBwkbEMFwjIwPJq63x QYIw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@metafoo.de header.s=default2002 header.b=ABxJPME4; 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=NONE dis=NONE) header.from=metafoo.de Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f9si13587pjs.10.2021.10.11.09.37.36; Mon, 11 Oct 2021 09:37:49 -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; dkim=pass header.i=@metafoo.de header.s=default2002 header.b=ABxJPME4; 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=NONE dis=NONE) header.from=metafoo.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S244619AbhJKORc (ORCPT + 99 others); Mon, 11 Oct 2021 10:17:32 -0400 Received: from www381.your-server.de ([78.46.137.84]:55546 "EHLO www381.your-server.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238262AbhJKOPA (ORCPT ); Mon, 11 Oct 2021 10:15:00 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=metafoo.de; s=default2002; h=Content-Transfer-Encoding:Content-Type:In-Reply-To: MIME-Version:Date:Message-ID:From:References:Cc:To:Subject:Sender:Reply-To: Content-ID:Content-Description:Resent-Date:Resent-From:Resent-Sender: Resent-To:Resent-Cc:Resent-Message-ID; bh=oXfj/LdcIWi8QBGVWoLeHpPANC5aeTpAQshDalhDSsU=; b=ABxJPME4LUvQro8a+7cOvSj2Xq 5u7fd18VGVpoabqCh5wyIG9c72ARX2XLGj16aYcTMxEjRTX5/R7OdMVwi4u+r2LkDhJw2dwiiUEjE K40PyOLzNLDwNRn//96QNZFKeOCHnI1EgFz0a7WcITS4ij+Tja2Vs1+40EArHVS5nFIldUQG6fk+v V4dBk+Gup5aOQnHMD6SqON4DN5EDLSamO2S873iBC5YPhczFN9qqLOx9yZqEsXuS5VOYwXEtlK6GU e6lFPNm2NPjQ07o56AyGJEXwQAx/dcRSN1KxYP1+jsOlJtn127RwlEzt5uwR55LweVPMnASfTpgtp 9JKsNF7Q==; Received: from sslproxy06.your-server.de ([78.46.172.3]) by www381.your-server.de with esmtpsa (TLSv1.3:TLS_AES_256_GCM_SHA384:256) (Exim 4.92.3) (envelope-from ) id 1mZw2y-0001XY-JN; Mon, 11 Oct 2021 16:12:56 +0200 Received: from [82.135.83.71] (helo=[192.168.178.20]) by sslproxy06.your-server.de with esmtpsa (TLSv1.3:TLS_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1mZw2y-000IkW-DK; Mon, 11 Oct 2021 16:12:56 +0200 Subject: Re: [PATCH] iio: core: do not create debugfs when has no dev name To: Yang Yingliang , linux-kernel@vger.kernel.org, linux-iio@vger.kernel.org Cc: ars@metafoo.de, jic23@kernel.org, alexandru.ardelean@analog.com, andy.shevchenko@gmail.com References: <20211011135654.282958-1-yangyingliang@huawei.com> From: Lars-Peter Clausen Message-ID: <2430dc94-ecf8-c246-beaf-52cc0905e3d4@metafoo.de> Date: Mon, 11 Oct 2021 16:12:55 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.14.0 MIME-Version: 1.0 In-Reply-To: <20211011135654.282958-1-yangyingliang@huawei.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US X-Authenticated-Sender: lars@metafoo.de X-Virus-Scanned: Clear (ClamAV 0.103.3/26319/Mon Oct 11 10:18:47 2021) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/11/21 3:56 PM, Yang Yingliang wrote: > I got a null-ptr-deref report when doing fault injection test: > > BUG: kernel NULL pointer dereference, address: 0000000000000000 > PGD 0 P4D 0 > Oops: 0000 [#1] SMP KASAN PTI > RIP: 0010:strlen+0x0/0x20 > Call Trace: > start_creating+0x199/0x2f0 > debugfs_create_dir+0x25/0x430 > __iio_device_register+0x4da/0x1b40 [industrialio] > __devm_iio_device_register+0x22/0x80 [industrialio] > max1027_probe+0x639/0x860 [max1027] > spi_probe+0x183/0x210 > really_probe+0x285/0xc30 > > If dev_set_name() fails, the dev_name() is null, add check for > device name before creating debugfs. If dev_set_name() fails, shouldn't we better return an error in iio_device_alloc()? Otherwise the device has no name and will show up as in sysfs. > > Reported-by: Hulk Robot > Fixes: e553f182d55b ("staging: iio: core: Introduce debugfs support...") > Signed-off-by: Yang Yingliang > --- > drivers/iio/industrialio-core.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/drivers/iio/industrialio-core.c b/drivers/iio/industrialio-core.c > index 2dc837db50f7..8974490ad536 100644 > --- a/drivers/iio/industrialio-core.c > +++ b/drivers/iio/industrialio-core.c > @@ -466,7 +466,7 @@ static void iio_device_register_debugfs(struct iio_dev *indio_dev) > if (indio_dev->info->debugfs_reg_access == NULL) > return; > > - if (!iio_debugfs_dentry) > + if (!iio_debugfs_dentry || !dev_name(&indio_dev->dev)) > return; > > iio_dev_opaque = to_iio_dev_opaque(indio_dev);