From mboxrd@z Thu Jan 1 00:00:00 1970 From: Sergei Shtylyov Subject: Re: [PATCH v8 1/2] spi: Add Renesas R-Car Gen3 RPC-IF SPI controller driver Date: Fri, 8 Mar 2019 20:32:31 +0300 Message-ID: References: <1548658158-5460-1-git-send-email-masonccyang@mxic.com.tw> <1548658158-5460-2-git-send-email-masonccyang@mxic.com.tw> <0c54ee2c-016a-bc8e-33ae-fbd04191cc49@cogentembedded.com> Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Cc: Mason Yang , Mark Brown , Marek Vasut , Linux Kernel Mailing List , linux-spi , Boris Brezillon , Linux-Renesas , Geert Uytterhoeven , juliensu@mxic.com.tw, Simon Horman , zhengxunli@mxic.com.tw To: Geert Uytterhoeven Return-path: In-Reply-To: Content-Language: en-MW Sender: linux-kernel-owner@vger.kernel.org List-Id: linux-spi.vger.kernel.org Hello! On 03/08/2019 12:14 PM, Geert Uytterhoeven wrote: >>> Add a driver for Renesas R-Car Gen3 RPC-IF SPI controller. >>> >>> Signed-off-by: Mason Yang >>> Signed-off-by: Sergei Shtylyov >> [...] >>> diff --git a/drivers/spi/spi-renesas-rpc.c b/drivers/spi/spi-renesas-rpc.c >>> new file mode 100644 >>> index 0000000..ea12017 >>> --- /dev/null >>> +++ b/drivers/spi/spi-renesas-rpc.c >>> @@ -0,0 +1,804 @@ >> [...] >>> +static void rpc_spi_hw_init(struct rpc_spi *rpc) >>> +{ >>> + // >>> + // NOTE: The 0x260 are undocumented bits, but they must be set. >>> + // RPC_PHYCNT_STRTIM is strobe timing adjustment bit, >>> + // 0x0 : the delay is biggest, >>> + // 0x1 : the delay is 2nd biggest, >>> + // On H3 ES1.x, the value should be 0, while on others, >>> + // the value should be 6. >>> + // >>> + regmap_write(rpc->regmap, RPC_PHYCNT, RPC_PHYCNT_CAL | >>> + RPC_PHYCNT_STRTIM(6) | 0x260); >>> + >>> + // >>> + // NOTE: The 0x1511144 are undocumented bits, but they must be set >>> + // for RPC_PHYOFFSET1. >>> + // The 0x31 are undocumented bits, but they must be set >>> + // for RPC_PHYOFFSET2. >>> + // >>> + regmap_write(rpc->regmap, RPC_PHYOFFSET1, RPC_PHYOFFSET1_DDRTMG(3) | >>> + 0x1511144); >>> + regmap_write(rpc->regmap, RPC_PHYOFFSET2, 0x31 | >>> + RPC_PHYOFFSET2_OCTTMG(4)); >>> + regmap_write(rpc->regmap, RPC_SSLDR, RPC_SSLDR_SPNDL(7) | >>> + RPC_SSLDR_SLNDL(7) | RPC_SSLDR_SCKDL(7)); >>> + regmap_write(rpc->regmap, RPC_CMNCR, RPC_CMNCR_MD | RPC_CMNCR_SFDE | >>> + RPC_CMNCR_MOIIO_HIZ | RPC_CMNCR_IOFV_HIZ | >>> + RPC_CMNCR_BSZ(0)); >>> +} >> >> We clearly need runtime PM get/put() calls around this code. Otherwise, >> we're dependant on U-Boot leaving the clocks enabled... > > Even that would be futile, as the common clock framework disables all > unused clocks at late boot time. This code is executed during the probing time and it indeed works. The clocks seem to be disabled somewhat later... > Gr{oetje,eeting}s, > > Geert MBR, Sergei