Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp415040ybb; Wed, 25 Mar 2020 02:17:27 -0700 (PDT) X-Google-Smtp-Source: ADFU+vsZ9HcKUR3czH05BiBDwoGndNcWrXDi0CCRDFYSLsdOqZfEjHW8EW5JrtBfW+X5VuERFY7X X-Received: by 2002:aca:5508:: with SMTP id j8mr1824544oib.71.1585127846995; Wed, 25 Mar 2020 02:17:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585127846; cv=none; d=google.com; s=arc-20160816; b=RWOA2VgxX/47rnGZjw1c4MDQ3f5WgQkq5osTZmPrSg67EtVBi/bCFwa4w/2C7wKwRG 7+oRvw5QC8IglDrSBppfAVC2IYmdVWpvlbQNj7yuMk/8gZtwcDlMZ3nV2LExhbQ6t9hA 8eX2v1FV3NDytshWjWuSMiYOnUFMe3HzsFRiPa9txQKbsI/5qbje6yduyAQpTQ6fOQ1x 7ep5Vh1mcXlIiVjgzd1Su6bHEUobaw5+5CRA7vZugiQjrZx/bb4h7GPoPd/2LYWHAI06 HpNE1LCGPkw/i4Xwscn15v5BfYORFwdcg66uirZUaTp5503bQC3xbK/frwamWrFesfgJ AB7A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=0fP8SfQZSAtyERg1yN0AyfU/uWwG6IasGOC+cQcTr0k=; b=EWldHPfJ4zZ08TsW2WE+S8I41d81vr8sSmrAGUV8hSAkbKvzEDO67iKKpj0J8vp+0f YC05yo8qOHs1ZhlfE551EGdcGSjzgqFoSFzHZ0mnELFwEKO7cu8IJTC1hE55brKbEtrU VIIpR7bY0yyRbMovZFsjPdMtSRwBEX3yGIpQhB9TiiQfVMxCcZCFDaoM2aS5lMNuDpM7 Ug3as1ifg4k5r/orYeRDADl+QECImo5Natb/AX0RW5R48iAwhFKh/ev1IdihhTHMXcM3 wB/G2d4yZEAkOIB+FTZuqWoluTUINu9cVyJgZOu1H1P7+VCE7IDAC9qoNsy12KH1HqNV 5KKw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=VDt0wkbp; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y3si4374330otq.204.2020.03.25.02.17.13; Wed, 25 Mar 2020 02:17:26 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=VDt0wkbp; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727286AbgCYJPp (ORCPT + 99 others); Wed, 25 Mar 2020 05:15:45 -0400 Received: from mail-wm1-f67.google.com ([209.85.128.67]:33741 "EHLO mail-wm1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726103AbgCYJPp (ORCPT ); Wed, 25 Mar 2020 05:15:45 -0400 Received: by mail-wm1-f67.google.com with SMTP id w25so1617867wmi.0 for ; Wed, 25 Mar 2020 02:15:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=0fP8SfQZSAtyERg1yN0AyfU/uWwG6IasGOC+cQcTr0k=; b=VDt0wkbpFc00q2fb/ca75QtoCPIzB+JkGS5SpH5ocOnGlj4qesJOqx/FDTeiJ9UAyx covDdC3RXIBl9KC6rlt967kBTLvOuRTjS30n3BS/Nx+PRch+4RRsMqvAZCerahTGqw3/ BIeQHDrltoP1c6/y7ruAkz4oH0DFL4mHtUicoUGdzg5cDlZpVg5oqj7vLshVmYuV1uHE NVXYx+fHPeUJWnK4GKr9u5/aHNAOJfvKW3EXZ5qvkgD6ARfTMTpcS4ZSgUDGkSVXW6hJ BnghYdt7QM5TFYT+aWvinnDmPalci2nXVNMu/mxNP3AXRhw5CF9XFUtvzbYGLK3VznHP 5M+g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=0fP8SfQZSAtyERg1yN0AyfU/uWwG6IasGOC+cQcTr0k=; b=ZEM+PKCu+IsnTEFqxuhlNq2+UhDkWGScgvPoxsLIWIvFg9e3+vNHA1bGJ7EX0YqZDN vTFVKa24FD2Eu//JS8F9QKEqnQoItLUHPcFoivALfQfqsJuN5+KMChcYRh4Ont1pWdYD koWlviHJW/F9YAGUazTC3qT2BjN62oynTvqSio8cTIVa9d61sw7pWvjqJXPUX0tVKcup PaGv1xTh18a26oS/igi2xxEXXMJb8mFwe4JMXZCLQpwQduFm+kq1g4dn8eowf8RXnZgt IZY0dETQd0nC3KkOKv/0Hd1ZVuzPmzbiCOZMTbyMQaORuStYc8ByIM45FlhzcvjXCKq/ 1QgA== X-Gm-Message-State: ANhLgQ1ginbUR7Kk1YYbUjqOaWRiW2WmJTX7OoxsRXdUoWNdvLgCgMen wDMkeNQACmIMtMfF+KM11oH4rcDsLZk= X-Received: by 2002:a1c:3d83:: with SMTP id k125mr1295044wma.177.1585127741285; Wed, 25 Mar 2020 02:15:41 -0700 (PDT) Received: from [192.168.86.34] (cpc89974-aztw32-2-0-cust43.18-1.cable.virginm.net. [86.30.250.44]) by smtp.googlemail.com with ESMTPSA id k204sm8448759wma.17.2020.03.25.02.15.40 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 25 Mar 2020 02:15:40 -0700 (PDT) Subject: Re: [PATCH 3/3] nvmem: core: use is_bin_visible for permissions To: Greg KH Cc: linux-kernel@vger.kernel.org, nicholas.johnson-opensource@outlook.com.au References: <20200324171600.15606-1-srinivas.kandagatla@linaro.org> <20200324171600.15606-4-srinivas.kandagatla@linaro.org> <20200324174642.GA2524667@kroah.com> From: Srinivas Kandagatla Message-ID: Date: Wed, 25 Mar 2020 09:15:39 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: <20200324174642.GA2524667@kroah.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 24/03/2020 17:46, Greg KH wrote: > On Tue, Mar 24, 2020 at 05:16:00PM +0000, Srinivas Kandagatla wrote: >> By using is_bin_visible callback to set permissions will remove a large list >> of attribute groups. These group permissions can be dynamically derived in >> the callback. >> >> Suggested-by: Greg KH >> Signed-off-by: Srinivas Kandagatla >> --- >> drivers/nvmem/nvmem-sysfs.c | 74 +++++++++---------------------------- >> 1 file changed, 18 insertions(+), 56 deletions(-) >> >> diff --git a/drivers/nvmem/nvmem-sysfs.c b/drivers/nvmem/nvmem-sysfs.c >> index 8759c4470012..1ff1801048f6 100644 >> --- a/drivers/nvmem/nvmem-sysfs.c >> +++ b/drivers/nvmem/nvmem-sysfs.c >> @@ -103,6 +103,17 @@ static ssize_t bin_attr_nvmem_write(struct file *filp, struct kobject *kobj, >> >> return count; >> } >> +static umode_t nvmem_bin_attr_is_visible(struct kobject *kobj, >> + struct bin_attribute *attr, int i) >> +{ >> + struct device *dev = container_of(kobj, struct device, kobj); >> + struct nvmem_device *nvmem = to_nvmem_device(dev); >> + >> + if (nvmem->root_only) >> + return nvmem->read_only ? 0400 : 0600; >> + >> + return nvmem->read_only ? 0444 : 0644; >> +} > > I don't know why this is so hard for me to read, but how about this > instead: > > static umode_t nvmem_bin_attr_is_visible(struct kobject *kobj, > struct bin_attribute *attr, int i) > { > struct device *dev = container_of(kobj, struct device, kobj); > struct nvmem_device *nvmem = to_nvmem_device(dev); > umode_t mode = 0400; > > if (!nvmem->root_only) > mode |= 0044; > > if (!nvmem->read_only) > mode |= 0200; > > return mode; > } > > Did I get the logic corect? That looks perfect and matches what is in upstream! Thanks for suggesting this cleanup! I will send v2 with this change! --srini > > thanks, > > greg k-h >