Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp389045imm; Sat, 1 Sep 2018 06:12:38 -0700 (PDT) X-Google-Smtp-Source: ANB0VdaECF6D4qlwDTbsi8HJi6LjrYMnZAfoijVSxSJfCP722PjIw7vyZhaCtTjwvq+dm1uSy0wn X-Received: by 2002:a62:9bc9:: with SMTP id e70-v6mr20240544pfk.95.1535807557941; Sat, 01 Sep 2018 06:12:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1535807557; cv=none; d=google.com; s=arc-20160816; b=K+VSNVDLJK+sQdxB15u2pgExO0PGvJXItmIPROJ7VRyuCqbcBSfl0/EnAFU2e3YM+k ey3fz30RTUbQgTfX+/jdv365KxwrWzOFm5WxoVdHeJSgswDm9ChnWCdSUc0kj7yPSbnv XCZAK/YrbI8pfekbNEW8EX9Knqm0gRL6OD55RRNpcabrIU/pO37FYHB9KXxkRKS0dmoV f6qwWnQUhlnXPCyr7mow84ZKYJ6pW9BEI50aqKxnBLg2V9hA5USNSHI/WE9Ca1XwY9iK KAmojyq2XbJbDlYsS8GH40LoQjD+bMMdiCQDpeoMxA4inlMl8QPV8Ir5t7J+W4gqTCP0 1YtQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature :arc-authentication-results; bh=6OBmkEzLXWZdBpezwe8RFhhwWFRCQX9SHKDEgZ+9NRI=; b=piMBKlK1NzGbl1abDflqp/kaLHvD6q/dpTASb1sO4DJW7CgnJq5DNlqlbv6sgZyWbO ss0gNXZPk0cXf17qGqY/XRrTWcALAElvRd1gyF0ftGszLZBEaLOBP3kCjQfJHnxxDhzL aJNF2VXyCVqRzpklZEgC8C30IGbnlurHtgBuuiUHfPg0nPNmp1onpb44S1DEMDxeLQMP XJ8tbna2GtMWQGDLhBIzV36DGsWZZLiX4gXL5zkFviAGZmrUCjtAwIbjOqw6AjN7k0d3 zmM25dQxljIw3leGLy56IWSZ8GkDCS75eNGm+WrLTMGkYZOzBQKoa7+d/BPvvIdNL1R6 JGDg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bgdev-pl.20150623.gappssmtp.com header.s=20150623 header.b=ulzWIWQu; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v190-v6si11685876pgd.128.2018.09.01.06.12.23; Sat, 01 Sep 2018 06:12:37 -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=@bgdev-pl.20150623.gappssmtp.com header.s=20150623 header.b=ulzWIWQu; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727526AbeIARXJ (ORCPT + 99 others); Sat, 1 Sep 2018 13:23:09 -0400 Received: from mail-it0-f65.google.com ([209.85.214.65]:38161 "EHLO mail-it0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727318AbeIARXI (ORCPT ); Sat, 1 Sep 2018 13:23:08 -0400 Received: by mail-it0-f65.google.com with SMTP id p129-v6so10514732ite.3 for ; Sat, 01 Sep 2018 06:11:06 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bgdev-pl.20150623.gappssmtp.com; s=20150623; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc; bh=6OBmkEzLXWZdBpezwe8RFhhwWFRCQX9SHKDEgZ+9NRI=; b=ulzWIWQuDhn/rtCywEf/jryrYuwjOnxXau5JUehFwvxSyihjLtSyM+U0WsoSnFfVrA 3uR4ia9l27WZeynbRQcGL5eXDMarDGJtGs2FJzESq5JLAu4lpfyDieQsVVad9HnKf+1R 3gezPG1t0Nzw6F8f3zQeL3jVWT31/875tRtu/GM/oBLmN+hrOs5OWlIT6i6gJgsjOlXF x5Gyujj9mMCMUPQsyT+jgwM+4oaluISyXaMdieO5kCFJ2ukClTRFsqffbKdux8Pv+8AN acJV0nplEIu/MMZDi3v3p+RPZ08nTylwAhqMGBkvDD3htg6byTUsXNXSKubE3qPTbCCq KL+g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc; bh=6OBmkEzLXWZdBpezwe8RFhhwWFRCQX9SHKDEgZ+9NRI=; b=rgQpmqj0uZAAEq0C0LdRJx647NP8QbmSD6WMBwTPtwlUPpVNei53qTl2HLpKBjpq4L tSSXLFw0F2LjtaWvIV2TwZecVZmeTfO2Cis+r90r7ZcY5IN1lV7TweKG2msGBTjCBkGF Dy2Z8xrqTSDTa5FIgMAXgUKI26zBZupvRNrKwSidGLXLZaWKqvletdahcq+yNu+m0Zg7 xirPW9uPTI9uBUchfapq8X6uDwb6fy9aFBhUa50FBHXWKREy+Hqx9OaOYkgQZMNbt5pL Ao9P7/UgmEf2lnfIAyXVPd460jFYU1T6fecAbpGqQSeBKqr/GqZ/yRxPbgjYqA8cRFxw WslA== X-Gm-Message-State: APzg51Ck/p2PeJnQkrqwE2C1lmCBz1+8f2kttQC3xyxrpJZfyNE6zV1m DVWn9i9W/OqXpr6DUfplkCaMCQVadm259VDpIi9YiA== X-Received: by 2002:a02:943:: with SMTP id f64-v6mr15187000jad.31.1535807466228; Sat, 01 Sep 2018 06:11:06 -0700 (PDT) MIME-Version: 1.0 Received: by 2002:a6b:a043:0:0:0:0:0 with HTTP; Sat, 1 Sep 2018 06:11:05 -0700 (PDT) In-Reply-To: <20180831203028.GC62862@ban.mtv.corp.google.com> References: <20180810080526.27207-1-brgl@bgdev.pl> <20180810080526.27207-3-brgl@bgdev.pl> <20180831203028.GC62862@ban.mtv.corp.google.com> From: Bartosz Golaszewski Date: Sat, 1 Sep 2018 15:11:05 +0200 Message-ID: Subject: Re: [PATCH v2 02/29] Documentation: nvmem: document lookup entries To: Brian Norris Cc: Jonathan Corbet , Sekhar Nori , Kevin Hilman , Russell King , Arnd Bergmann , Greg Kroah-Hartman , David Woodhouse , Boris Brezillon , Marek Vasut , Richard Weinberger , Grygorii Strashko , "David S . Miller" , Srinivas Kandagatla , Naren , Mauro Carvalho Chehab , Andrew Morton , Lukas Wunner , Dan Carpenter , Florian Fainelli , Ivan Khoronzhuk , Sven Van Asbroeck , Paolo Abeni , Alban Bedel , Rob Herring , David Lechner , Andrew Lunn , linux-doc , Linux Kernel Mailing List , Linux ARM , linux-i2c , "open list:MEMORY TECHNOLOGY..." , Linux-OMAP , netdev , Bartosz Golaszewski , briannorris@chromium.org Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 2018-08-31 22:30 GMT+02:00 Brian Norris : > On Fri, Aug 10, 2018 at 10:04:59AM +0200, Bartosz Golaszewski wrote: >> From: Bartosz Golaszewski >> >> Describe the usage of nvmem cell lookup tables. >> >> Signed-off-by: Bartosz Golaszewski >> --- >> Documentation/nvmem/nvmem.txt | 28 ++++++++++++++++++++++++++++ >> 1 file changed, 28 insertions(+) >> >> diff --git a/Documentation/nvmem/nvmem.txt b/Documentation/nvmem/nvmem.txt >> index 8d8d8f58f96f..9d5e3ca2b4f3 100644 >> --- a/Documentation/nvmem/nvmem.txt >> +++ b/Documentation/nvmem/nvmem.txt >> @@ -58,6 +58,34 @@ static int qfprom_probe(struct platform_device *pdev) >> It is mandatory that the NVMEM provider has a regmap associated with its >> struct device. Failure to do would return error code from nvmem_register(). >> >> +Additionally it is possible to create nvmem cell lookup entries and register >> +them with the nvmem framework from machine code as shown in the example below: > > Maybe it's partially a lacking in the existing documentation, but what > does the "name" and the "nvmem_name" mean here? AFAICT, "nvmem_name" is > akin to a provider identifier; and "name" is a key to match with the > consumer. It feels like this should be in either the header / kerneldoc > or this file. Or maybe both. > > Does this mean there can only be a single "mac-address" cell in the > system? I have systems where there are multiple MACs provided in flash > storage, and we need to map them to ethernet0 and ethernet1. Is that > supported here? > This is a shortcoming of the nvmem subsystem we discussed under another patch in this series with Boris and Srinivas. I will try to post a series addressing this next week. Basically there's a global list of nvmem cells referenced only by name and unless you're using DT you can only have a single cell with given name. I will address it by introducing the standard dev_id/con_id resource association. Bart > Brian > >> +static struct nvmem_cell_lookup foobar_lookup = { >> + .info = { >> + .name = "mac-address", >> + .offset = 0xd000, >> + .bytes = ERH_ALEN, >> + }, >> + .nvmem_name = "foobar", >> +}; >> + >> +static void foobar_register(void) >> +{ >> + ... >> + nvmem_add_lookup_table(&foobar_lookup, 1); >> + ... >> +} >> + >> +A lookup entry table can be later removed if needed: >> + >> +static void foobar_fini(void) >> +{ >> + ... >> + nvmem_del_lookup_table(&foobar_lookup, 1); >> + ... >> +} >> + >> NVMEM Consumers >> +++++++++++++++ >> >> -- >> 2.18.0 >>