Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3505898pxf; Mon, 22 Mar 2021 08:00:38 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyc7aJh6/YYkLKgmCf+Wtmsq8u1lXk0xwYXij3fNyZk8FXIaF69XdP/fn3UHdcagTlRzL6I X-Received: by 2002:a17:906:37db:: with SMTP id o27mr215391ejc.60.1616425238155; Mon, 22 Mar 2021 08:00:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616425238; cv=none; d=google.com; s=arc-20160816; b=o3FKpcgr3lOSOaRxmFXpIfkHj4ASwdOdY4Xh/RwaGa9xSUvRTlUNkwny68Fq3knB5l OI8CRXzpMMcFg7PVbXycz5caq/ZfH+4KfSda4nnNQMcqNfm33zTIHAOAagQ+g31IViMp m6QCGx34Rw/tabkaxGorHQknxbhEwz8o3A4AYl9wAD1/urrphpRMqimk9+y8TMY7+CeL hxatU2LPsN+6xW8EioxmDKUO6UxDphxo+ftuoBCiKoDILtTi754tR3OpFHBHWVERgH+a F+pXwXz7N2sGm5AHpxyED3xnkPV4j+tijfP8q+Kh7fXeYCErfzBNn1HunKpwvvqMOy49 yE5g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:user-agent:references:in-reply-to :subject:cc:to:from:date:content-transfer-encoding:mime-version :dkim-signature; bh=X2+WabiOKhG6YXHDZiRtWr20I9Z8MpQUgxE2F5z65rE=; b=LtaojF7fMeTvP9Z1/vYjtvlxuJGaOtEBrwrQ60HWZFXPpr6LIyCQhO2Iunb6B4CUnZ rmLW+A0j0IKvOm9U1kp/6c4X72U/W+zBEoWItVTgYtfy7pVRAOfKl8v0nJwobURzYvmh HR3Ey0gy+MzFLculJ1xmgn5HrhR21Zfte1qoui/vGVSja1A7tZfEQ+We2RLjY8MY444B raOpRNEm7hyovS1MwPlKlGR9bl42AEhPC0PXmZJkl2QM8se45eRbVXd/q5qCXPhnYA4s B/MA9FQBOiwuradB+chsHs38uruZQAME2utCN+Yw8ar7xdwnJ2dkpmtlA+lrcRpNHXIZ RBkg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@walle.cc header.s=mail2016061301 header.b=h2lQkhN8; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id e7si11411932edk.222.2021.03.22.08.00.14; Mon, 22 Mar 2021 08:00:38 -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=@walle.cc header.s=mail2016061301 header.b=h2lQkhN8; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231243AbhCVO5v (ORCPT + 99 others); Mon, 22 Mar 2021 10:57:51 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55502 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231435AbhCVO5U (ORCPT ); Mon, 22 Mar 2021 10:57:20 -0400 Received: from ssl.serverraum.org (ssl.serverraum.org [IPv6:2a01:4f8:151:8464::1:2]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B4AC1C061763 for ; Mon, 22 Mar 2021 07:57:19 -0700 (PDT) Received: from ssl.serverraum.org (web.serverraum.org [172.16.0.2]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ssl.serverraum.org (Postfix) with ESMTPSA id 2A8A422235; Mon, 22 Mar 2021 15:57:17 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=walle.cc; s=mail2016061301; t=1616425037; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=X2+WabiOKhG6YXHDZiRtWr20I9Z8MpQUgxE2F5z65rE=; b=h2lQkhN8QBVibNYmbDjS/7j0Gzi2IWLyq/3oLvkYuyZq3Hh5MxquOmMwHdkerN6GKrN7FR 6GrFfIYQyO08Dt2Jf1Jjgxco76kFM6dqZilSwXRiTgaWNhakPMBDlru5T/h3v2CnQYt3JP /rxtU+pZr70FdvHQyRvAPxAPBNQuof0= MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Mon, 22 Mar 2021 15:57:16 +0100 From: Michael Walle To: Pratyush Yadav Cc: linux-kernel@vger.kernel.org, linux-mtd@lists.infradead.org, Tudor Ambarus , Miquel Raynal , Richard Weinberger , Vignesh Raghavendra Subject: Re: [PATCH 2/2] mtd: spi-nor: add initial sysfs support In-Reply-To: <20210322144344.4hys4zs57hnsjyjy@ti.com> References: <20210318092406.5340-1-michael@walle.cc> <20210318092406.5340-3-michael@walle.cc> <20210322144344.4hys4zs57hnsjyjy@ti.com> User-Agent: Roundcube Webmail/1.4.11 Message-ID: <716b7d6c86a12d30021fbf6b77b8545f@walle.cc> X-Sender: michael@walle.cc Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Pratyush, Am 2021-03-22 15:43, schrieb Pratyush Yadav: > I have not worked with sysfs much so only giving this patch a quick > overview. > > On 18/03/21 10:24AM, Michael Walle wrote: >> Add support to show the name and JEDEC identifier as well as to dump >> the >> SFDP table. Not all flashes list their SFDP table contents in their >> datasheet. So having that is useful. It might also be helpful in bug >> reports from users. >> >> The idea behind the sysfs module is also to have raw access to the SPI >> NOR flash device registers, which can also be useful for debugging. > > Your current patch does not add this feature. Why do you think it is > important enough to mention it? It was part of my first (not submitted) version. I.e. you could also read the status register(s). Comes in handy for debugging the locking code, for example. I can also remove that paragraph ;) >> Signed-off-by: Michael Walle >> --- >> drivers/mtd/spi-nor/Makefile | 2 +- >> drivers/mtd/spi-nor/core.c | 5 +++ >> drivers/mtd/spi-nor/core.h | 3 ++ >> drivers/mtd/spi-nor/sysfs.c | 86 >> ++++++++++++++++++++++++++++++++++++ >> 4 files changed, 95 insertions(+), 1 deletion(-) >> create mode 100644 drivers/mtd/spi-nor/sysfs.c >> >> diff --git a/drivers/mtd/spi-nor/Makefile >> b/drivers/mtd/spi-nor/Makefile >> index 653923896205..aff308f75987 100644 >> --- a/drivers/mtd/spi-nor/Makefile >> +++ b/drivers/mtd/spi-nor/Makefile >> @@ -1,6 +1,6 @@ >> # SPDX-License-Identifier: GPL-2.0 >> >> -spi-nor-objs := core.o sfdp.o >> +spi-nor-objs := core.o sfdp.o sysfs.o >> spi-nor-objs += atmel.o >> spi-nor-objs += catalyst.o >> spi-nor-objs += eon.o >> diff --git a/drivers/mtd/spi-nor/core.c b/drivers/mtd/spi-nor/core.c >> index 4a315cb1c4db..2eaf4ba8c0f3 100644 >> --- a/drivers/mtd/spi-nor/core.c >> +++ b/drivers/mtd/spi-nor/core.c >> @@ -3707,6 +3707,10 @@ static int spi_nor_probe(struct spi_mem >> *spimem) >> if (ret) >> return ret; >> >> + ret = spi_nor_sysfs_create(nor); >> + if (ret) >> + return ret; >> + >> return mtd_device_register(&nor->mtd, data ? data->parts : NULL, >> data ? data->nr_parts : 0); >> } >> @@ -3716,6 +3720,7 @@ static int spi_nor_remove(struct spi_mem >> *spimem) >> struct spi_nor *nor = spi_mem_get_drvdata(spimem); >> >> spi_nor_restore(nor); >> + spi_nor_sysfs_remove(nor); >> >> /* Clean up MTD stuff. */ >> return mtd_device_unregister(&nor->mtd); >> diff --git a/drivers/mtd/spi-nor/core.h b/drivers/mtd/spi-nor/core.h >> index 668f22011b1d..dd592f7b62d1 100644 >> --- a/drivers/mtd/spi-nor/core.h >> +++ b/drivers/mtd/spi-nor/core.h >> @@ -488,4 +488,7 @@ static struct spi_nor __maybe_unused >> *mtd_to_spi_nor(struct mtd_info *mtd) >> return mtd->priv; >> } >> >> +int spi_nor_sysfs_create(struct spi_nor *nor); >> +void spi_nor_sysfs_remove(struct spi_nor *nor); >> + >> #endif /* __LINUX_MTD_SPI_NOR_INTERNAL_H */ >> diff --git a/drivers/mtd/spi-nor/sysfs.c b/drivers/mtd/spi-nor/sysfs.c >> new file mode 100644 >> index 000000000000..0de031e246c5 >> --- /dev/null >> +++ b/drivers/mtd/spi-nor/sysfs.c >> @@ -0,0 +1,86 @@ >> +// SPDX-License-Identifier: GPL-2.0 >> + >> +#include >> +#include >> +#include >> +#include >> + >> +#include "core.h" >> + >> +static ssize_t name_show(struct device *dev, >> + struct device_attribute *attr, char *buf) >> +{ >> + struct spi_device *spi = to_spi_device(dev); >> + struct spi_mem *spimem = spi_get_drvdata(spi); >> + struct spi_nor *nor = spi_mem_get_drvdata(spimem); >> + >> + return sprintf(buf, "%s\n", nor->info->name); >> +} >> +static DEVICE_ATTR_RO(name); >> + >> +static ssize_t jedec_id_show(struct device *dev, >> + struct device_attribute *attr, char *buf) >> +{ >> + struct spi_device *spi = to_spi_device(dev); >> + struct spi_mem *spimem = spi_get_drvdata(spi); >> + struct spi_nor *nor = spi_mem_get_drvdata(spimem); >> + >> + return sprintf(buf, "%*phN\n", nor->info->id_len, nor->info->id); >> +} >> +static DEVICE_ATTR_RO(jedec_id); >> + >> +static struct attribute *spi_nor_sysfs_entries[] = { >> + &dev_attr_name.attr, >> + &dev_attr_jedec_id.attr, >> + NULL >> +}; >> + >> +static ssize_t sfdp_read(struct file *filp, struct kobject *kobj, >> + struct bin_attribute *bin_attr, char *buf, >> + loff_t off, size_t count) >> +{ >> + struct spi_device *spi = to_spi_device(kobj_to_dev(kobj)); >> + struct spi_mem *spimem = spi_get_drvdata(spi); >> + struct spi_nor *nor = spi_mem_get_drvdata(spimem); >> + struct sfdp *sfdp = nor->sfdp; >> + size_t sfdp_size = sfdp->num_dwords * sizeof(*sfdp->dwords); > > Is a NULL check needed here? If the flash does not have a SFDP table > nor->sfdp will be NULL. That can't happen because.. >> + >> + return memory_read_from_buffer(buf, count, &off, nor->sfdp->dwords, >> + sfdp_size); >> +} >> +static BIN_ATTR_RO(sfdp, PAGE_SIZE); >> + >> +static struct bin_attribute *spi_nor_sysfs_bin_entries[] = { >> + &bin_attr_sfdp, >> + NULL >> +}; >> + >> +static umode_t spi_nor_sysfs_is_bin_visible(struct kobject *kobj, >> + struct bin_attribute *attr, int n) >> +{ >> + struct spi_device *spi = to_spi_device(kobj_to_dev(kobj)); >> + struct spi_mem *spimem = spi_get_drvdata(spi); >> + struct spi_nor *nor = spi_mem_get_drvdata(spimem); >> + >> + if (attr == &bin_attr_sfdp && nor->sfdp) >> + return 0444; .. it is not visible. Maybe I should use if (attr == &bin_attr_sfdp && !nor->sfdp) return 0; return 0444; >> + >> + return 0; >> +} >> + >> +static struct attribute_group spi_nor_sysfs_attr_group = { >> + .name = NULL, >> + .is_bin_visible = spi_nor_sysfs_is_bin_visible, >> + .attrs = spi_nor_sysfs_entries, >> + .bin_attrs = spi_nor_sysfs_bin_entries, >> +}; >> + >> +int spi_nor_sysfs_create(struct spi_nor *nor) >> +{ >> + return sysfs_create_group(&nor->dev->kobj, >> &spi_nor_sysfs_attr_group); >> +} >> + >> +void spi_nor_sysfs_remove(struct spi_nor *nor) >> +{ >> + sysfs_remove_group(&nor->dev->kobj, &spi_nor_sysfs_attr_group); >> +} >> -- >> 2.20.1 >> > > Rest of it looks good to me. Thanks for reviewing! -michael