From patchwork Wed Jun 24 18:50:51 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Srinivas Kandagatla X-Patchwork-Id: 6669821 Return-Path: X-Original-To: patchwork-linux-arm-msm@patchwork.kernel.org Delivered-To: patchwork-parsemail@patchwork1.web.kernel.org Received: from mail.kernel.org (mail.kernel.org [198.145.29.136]) by patchwork1.web.kernel.org (Postfix) with ESMTP id 203A49F380 for ; Wed, 24 Jun 2015 18:51:02 +0000 (UTC) Received: from mail.kernel.org (localhost [127.0.0.1]) by mail.kernel.org (Postfix) with ESMTP id 2EA4F205E8 for ; Wed, 24 Jun 2015 18:51:01 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 2FF9A20595 for ; Wed, 24 Jun 2015 18:51:00 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753577AbbFXSu6 (ORCPT ); Wed, 24 Jun 2015 14:50:58 -0400 Received: from mail-wi0-f173.google.com ([209.85.212.173]:34355 "EHLO mail-wi0-f173.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752884AbbFXSu5 (ORCPT ); Wed, 24 Jun 2015 14:50:57 -0400 Received: by wicnd19 with SMTP id nd19so142973815wic.1 for ; Wed, 24 Jun 2015 11:50:55 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:message-id:date:from:user-agent:mime-version:to :cc:subject:references:in-reply-to:content-type :content-transfer-encoding; bh=84Dh9dy5f0ffIyAuxo7LzetIcEBFQLLNcCsPnxV6V9U=; b=AFP0OL1DX9XaQokF78gfAoPRHjrXl1+Wp7quGUdWb+lKCpD9EQ6v7HIonAKyrhmmHE h2eT2l9oOrb9TL7yiBy0u8mAJh3RWPHlHgrEe5knTExhg+MJRNFEVndgioOx3xlKbAlZ MTOOHa1r+UrOdUo58ep+wTCRaxsztmc/wAbZtrJwYFfrEaiY3PMPudjwWij1m2iy59Tc hibEs2m5K0VSVLTjwOYJYwdFGZuYVVdkCIjlxtuNl/hoQ8b10NAJl9YCo9k4gk9Ppf4v bpEgYztfE77QopnYRBPI8WrytSnSYaoTCJNWSPNyZSuKCXsm/QsPbO487L1ey+S9OnqS TdyQ== X-Gm-Message-State: ALoCoQloaCyOetC0O3js12JRKW4r1VDW+58fgZq4RazSdef/q3CN7glaC3NhF7QXo3we0aKhbOfj X-Received: by 10.180.84.170 with SMTP id a10mr7663334wiz.52.1435171855746; Wed, 24 Jun 2015 11:50:55 -0700 (PDT) Received: from [192.168.1.8] (host-78-147-7-145.as13285.net. [78.147.7.145]) by mx.google.com with ESMTPSA id ju2sm3838340wid.12.2015.06.24.11.50.52 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 24 Jun 2015 11:50:54 -0700 (PDT) Message-ID: <558AFC0B.1050400@linaro.org> Date: Wed, 24 Jun 2015 19:50:51 +0100 From: Srinivas Kandagatla User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.4.0 MIME-Version: 1.0 To: Stefan Wahren , linux-arm-kernel@lists.infradead.org CC: wxt@rock-chips.com, linux-api@vger.kernel.org, Rob Herring , Kumar Gala , sboyd@codeaurora.org, arnd@arndb.de, s.hauer@pengutronix.de, Greg Kroah-Hartman , linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, mporter@konsulko.com, Maxime Ripard , pantelis.antoniou@konsulko.com, devicetree@vger.kernel.org, Mark Brown Subject: Re: [PATCH v6 0/9] Add simple NVMEM Framework via regmap. References: <1435014459-26138-1-git-send-email-srinivas.kandagatla@linaro.org> <235181230.251177.1435088854197.JavaMail.open-xchange@oxbsltgw00.schlund.de> <558A7C92.2040102@linaro.org> <558AA2E2.1010606@i2se.com> <558AAA8D.8030209@linaro.org> <1641569650.41238.1435168054323.JavaMail.open-xchange@oxbsltgw35.schlund.de> In-Reply-To: <1641569650.41238.1435168054323.JavaMail.open-xchange@oxbsltgw35.schlund.de> Sender: linux-arm-msm-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-arm-msm@vger.kernel.org X-Spam-Status: No, score=-8.3 required=5.0 tests=BAYES_00, RCVD_IN_DNSWL_HI, RP_MATCHES_RCVD, UNPARSEABLE_RELAY autolearn=unavailable version=3.3.1 X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on mail.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP On 24/06/15 18:47, Stefan Wahren wrote: > Hi Srinivas, > >> Srinivas Kandagatla hat am 24. Juni 2015 um >> 15:03 geschrieben: >> >> >> >> >> On 24/06/15 13:30, Stefan Wahren wrote: >>>>> If the question is just about hexdump, then hexdump itself can read >>>>> file from given offset and size. >>> yes, this is my question at first. Let me show the difference between >>> the current implementation and my expectations as a user. >>> >>> $ hexdump /sys/class/nvmem/mxs-ocotp/nvmem >>> >>> Current implementation: dump the complete register range defined in DT >>> >> Its dumping the range which is specified in the provider regmap. If the >> requirement is to dump only particular range, this has to be made >> explicit while creating regmap, which is to specify the base address to >> start from "First data register" and max_register to be "Last data >> register "- "First data register" > > i know about max_register, but i can't find the base address in regmap_config. > Base is not in the regmap config, its the value which you pass to the For example, if I had to do similar change to qfprom driver It would look like: ><-----------------------cut--------------------------------->< return PTR_ERR(regmap); ><-----------------------cut--------------------------------->< --srini > Do you mean struct regmap_access_table *rd_table ? > >> >>> User expectation: dump only the data from OCOTP block >>> >>> Let me explain it for i.MX28 OCOTP >>> >>> 0x8002c000 // Start of OCOTP register block (defined in DT) >>> >>> 0x8002c020 // First data register >>> >>> 0x8002c290 // Last data register >>> >>> 0x8002dfff // End of OCOTP register block (defined in DT) >>> >>> My knowledge about regmap is limited, but how can i achieve that hexdump >>> give me only the data registers? From my understanding this should be >>> handled in regmap and not in the read function. >> >> Setup the base and regmap_config correctly in the provider driver before >> calling regmap_init_mmio(). >> >> Let me know if you need more details. > > Yes, please. > > Stefan > >> >> --srini >> >>> >>> Are my expectations about the raw access wrong? >>> >>> >> >> _______________________________________________ >> linux-arm-kernel mailing list >> linux-arm-kernel@lists.infradead.org >> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel > -- > To unsubscribe from this list: send the line "unsubscribe linux-arm-msm" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html > --- To unsubscribe from this list: send the line "unsubscribe linux-arm-msm" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html diff --git a/drivers/nvmem/qfprom.c b/drivers/nvmem/qfprom.c index 7f7a82f..26ced95 100644 --- a/drivers/nvmem/qfprom.c +++ b/drivers/nvmem/qfprom.c @@ -52,9 +52,9 @@ static int qfprom_probe(struct platform_device *pdev) if (IS_ERR(base)) return PTR_ERR(base); - qfprom_regmap_config.max_register = resource_size(res) - 1; + qfprom_regmap_config.max_register = my_data_size; - regmap = devm_regmap_init_mmio(dev, base, &qfprom_regmap_config); + regmap = devm_regmap_init_mmio(dev, base + data_offset, &qfprom_regmap_config); if (IS_ERR(regmap)) { dev_err(dev, "regmap init failed\n");