From mboxrd@z Thu Jan 1 00:00:00 1970 From: Lee Jones Subject: Re: [PATCH v3 35/36] platform/x86: intel_pmc_ipc: Convert to MFD Date: Mon, 20 Jan 2020 11:11:59 +0000 Message-ID: <20200120111159.GC15507@dell> References: <20200113135623.56286-1-mika.westerberg@linux.intel.com> <20200113135623.56286-36-mika.westerberg@linux.intel.com> <20200116132108.GH325@dell> <20200116143730.GE2838@lahna.fi.intel.com> <20200117113202.GH15507@dell> <20200120092650.GI2665@lahna.fi.intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit Return-path: Content-Disposition: inline In-Reply-To: <20200120092650.GI2665@lahna.fi.intel.com> Sender: linux-kernel-owner@vger.kernel.org To: Mika Westerberg Cc: Andy Shevchenko , Darren Hart , Thomas Gleixner , Ingo Molnar , Borislav Petkov , "H . Peter Anvin" , x86@kernel.org, Zha Qipeng , "David E . Box" , Guenter Roeck , Heikki Krogerus , Greg Kroah-Hartman , Wim Van Sebroeck , platform-driver-x86@vger.kernel.org, linux-kernel@vger.kernel.org List-Id: platform-driver-x86.vger.kernel.org Adding Mark (the Regmap Maintainer) to the conversation. On Mon, 20 Jan 2020, Mika Westerberg wrote: > On Fri, Jan 17, 2020 at 11:32:02AM +0000, Lee Jones wrote: > > [...] > > > > > > Looks like Regmap could save you the trouble here. > > > > > > Agreed. > > > > Great. > > I started to implement regmap for this driver but I run into some > problems. The registers we read/write are all 64-bit and accessed trough > readq/writeq accessors. However, the regmap API takes unsigned int: > > int regmap_write(struct regmap *map, unsigned int reg, unsigned int val); > int regmap_read(struct regmap *map, unsigned int reg, unsigned int *val); > > I'm not sure how we can take advantage of this API with the 64-bit > registers. There are "raw" versions of the functions that take void > pointer like: > > int regmap_raw_read(struct regmap *map, unsigned int reg, > void *val, size_t val_len); > > but looking at the implementation if the register gets cached it > internally does reads in unsigned int sized chunks (if I understand it > right). > > Any ideas how this can be done? Mark, Does Regmap support 64bit accesses? -- Lee Jones [李琼斯] Linaro Services Technical Lead Linaro.org │ Open source software for ARM SoCs Follow Linaro: Facebook | Twitter | Blog