Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp900933iob; Wed, 4 May 2022 10:14:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwFHejW6X7SDrR9EB+OslRWIZsUVU+2O6WDmlUZMpJFtDHR4rpod7V9er2hhAGiOwtP5Ba4 X-Received: by 2002:a05:6402:1d48:b0:427:e039:9262 with SMTP id dz8-20020a0564021d4800b00427e0399262mr10654454edb.148.1651684451779; Wed, 04 May 2022 10:14:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651684451; cv=none; d=google.com; s=arc-20160816; b=eHVdPiDD/JMzsDWLRMzk43wXy7pFzGzg18ys9TRbApZ2ZHHQtW/hG6r2hVznZRhfLo o7pNN7cLxIm7pr126JpyxlhVzhZZ1i27FiU4UpjEpBRlAXUnLVz3YoVKTPRY5y9BfRdO mtKuabkACjM/GdMo5HYBRRNUEJWlAGR4UrxBb27lMhl4kJbr+eYwTWdON7FZ2RE8Okxq 6vU8+vQ1Myoa82ZxUAE8qyRjtgEL++WW9LMG2Tvcl2aI4i+gKEyI6VpHl37Vx0EbB8v9 iT3vUPbHtaAbuy5ukrZu+3d/6paTNnbtZ2XrI0UIaD+yYrhqm5aPz1cH6qfMj7uiB27V N+eQ== 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 :content-language:references:cc:to:subject:from:user-agent :mime-version:date:message-id; bh=yamqAwvHF4xhtMQN+0thj1DzomUivnA243PQvTX0V1I=; b=J53flOOr4lbFoMEJ7UvBz3cn8ERv7+UZoUuAKLJGDU43sCEIpvHJ0bw0KUSeM89/Gr 00rD50hPLYjuZ2W5OHHUVfq2DYXQW7S+msbdu9xMXoEK0UIrmRuhadL+HE8QxvphKe/o 0BrGKGzn9EKLahq+rNvwasxxItwV73D4dl0MLaJQjqmmgi4wv6dSXWqZkM2ELyR/4TwD wKN88ew+ETKAy9DuxwqN1bvZoeXWNMLxxAt/VaTl1aeiDrONGV/FN4ft2TnnMVyQhY6z WT4mbqSQzz1Sd5kdVBxFTkJ4nWXs69me9CHiVL1XsfmyKXgGtvzlUYcU6DZkXQPVYDUl 3bFQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id z15-20020a05640240cf00b00427cb81f020si7323833edb.250.2022.05.04.10.13.46; Wed, 04 May 2022 10:14:11 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1347103AbiEDJ0x (ORCPT + 99 others); Wed, 4 May 2022 05:26:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33220 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239093AbiEDJ0v (ORCPT ); Wed, 4 May 2022 05:26:51 -0400 Received: from metis.ext.pengutronix.de (metis.ext.pengutronix.de [IPv6:2001:67c:670:201:290:27ff:fe1d:cc33]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6D44920BF4 for ; Wed, 4 May 2022 02:23:16 -0700 (PDT) Received: from ptz.office.stw.pengutronix.de ([2a0a:edc0:0:900:1d::77] helo=[127.0.0.1]) by metis.ext.pengutronix.de with esmtp (Exim 4.92) (envelope-from ) id 1nmBDx-0006Us-V7; Wed, 04 May 2022 11:23:10 +0200 Message-ID: <79c7891a-9a68-a111-094d-be9804071a9e@pengutronix.de> Date: Wed, 4 May 2022 11:23:06 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.7.0 From: Ahmad Fatoum Subject: Re: [PATCH V2] nvmem: add driver handling U-Boot environment variables To: =?UTF-8?B?UmFmYcWCIE1pxYJlY2tp?= , Srinivas Kandagatla , Miquel Raynal , Richard Weinberger , Vignesh Raghavendra Cc: Tom Rini , linux-mtd@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, u-boot@lists.denx.de, devicetree@vger.kernel.org, =?UTF-8?B?UmFmYcWCIE1pxYJlY2tp?= , Pengutronix Kernel Team References: <20220503165658.13932-1-zajec5@gmail.com> Content-Language: en-US In-Reply-To: <20220503165658.13932-1-zajec5@gmail.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-SA-Exim-Connect-IP: 2a0a:edc0:0:900:1d::77 X-SA-Exim-Mail-From: a.fatoum@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org X-Spam-Status: No, score=-6.7 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_PASS,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 Hello Rafał, On 03.05.22 18:56, Rafał Miłecki wrote: > From: Rafał Miłecki > > U-Boot stores its setup as environment variables. It's a list of > key-value pairs stored on flash device with a custom header. > > This commit adds an NVMEM driver that: > 1. Provides NVMEM access to environment vars binary data > 2. Extracts variables as NVMEM cells > > It can be used for: > 1. Accessing env variables from user-space Is this already possible? The only interface I know of is the /nvmem file in sysfs, but that one is not per cell, but per device. > + label = of_get_property(np->parent, "label", NULL); > + if (!label) > + label = np->parent->name; > + > + priv->mtd = get_mtd_device_nm(label); > + if (IS_ERR(priv->mtd)) { > + dev_err(dev, "Failed to find \"%s\" MTD device: %ld\n", label, PTR_ERR(priv->mtd)); > + return PTR_ERR(priv->mtd); > + } I am trying to make sense of this using the binding, but I can't. Do you have an example device tree fragment? Cheers, Ahmad -- Pengutronix e.K. | | Steuerwalder Str. 21 | http://www.pengutronix.de/ | 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 |