On Fri, 2015-12-11 at 23:45 +0100, Marcus Weseloh wrote: [...] > > diff --git a/Documentation/devicetree/bindings/spi/spi-sun4i.txt b/Documentation/devicetree/bindings/spi/spi-sun4i.txt > index de827f5..d6c55fc 100644 > --- a/Documentation/devicetree/bindings/spi/spi-sun4i.txt > +++ b/Documentation/devicetree/bindings/spi/spi-sun4i.txt > @@ -10,6 +10,10 @@ Required properties: > - "mod": the parent module clock > - clock-names: Must contain the clock names described just above > > +Optional properties for slave devices: > +- sun4i,spi-word-wait-ns: hardware based delay in nanoseconds between > + transmission of words Should be 'allwinner,spi-word-wait-ns' Vendor prefix do come from: Documentation/devicetree/bindings/vendor-prefixes.txt > + > Example: > > spi1: spi@01c06000 { > @@ -21,4 +25,11 @@ spi1: spi@01c06000 { > status = "disabled"; > #address-cells = <1>; > #size-cells = <0>; > + > + spi1_0 { > + compatible = "example,dummy"; > + reg = <0>; > + spi-max-frequency = <1000000>; > + sun4i,spi-word-wait-ns = <12000>; > + }; > }; > diff --git a/drivers/spi/spi-sun4i.c b/drivers/spi/spi-sun4i.c > index f60a6d6..8cfd96c 100644 > --- a/drivers/spi/spi-sun4i.c > +++ b/drivers/spi/spi-sun4i.c > @@ -19,6 +19,7 @@ > #include > #include > #include > +#include > > #include > > @@ -173,6 +174,9 @@ static int sun4i_spi_transfer_one(struct spi_master *master, > unsigned int tx_len = 0; > int ret = 0; > u32 reg; > + u32 wait_ns = 0; > + int wait_clk = 0; > + int clk_ns = 0; > > /* We don't support transfer larger than the FIFO */ > if (tfr->len > SUN4I_FIFO_DEPTH) > @@ -261,6 +265,25 @@ static int sun4i_spi_transfer_one(struct spi_master *master, > > sun4i_spi_write(sspi, SUN4I_CLK_CTL_REG, reg); > > + /* Setup wait time beteen words */ typo > + of_property_read_u32(spi->dev.of_node, "sun4i,spi-word-wait-ns", > + &wait_ns); > + if (wait_ns) { > + /* The wait time is set in SPI_CLK cycles. The SPI hardware > + * needs 3 additional cycles to setup the wait counter, so > + * the minimum delay time is 4 cycles. > + */ > + clk_ns = DIV_ROUND_UP(1000000000, tfr->speed_hz); > + wait_clk = DIV_ROUND_UP(wait_ns, clk_ns) - 3; > + if (wait_clk < 1) { > + wait_clk = 1; > + dev_info(&spi->dev, > + "using minimum of 4 word wait cycles (%uns)", > + 4 * clk_ns); > + } > + } > + sun4i_spi_write(sspi, SUN4I_WAIT_REG, (u16)wait_clk); > + > /* Setup the transfer now... */ > if (sspi->tx_buf) > tx_len = tfr->len; > -- > 1.9.1 > -- To unsubscribe from this list: send the line "unsubscribe linux-spi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html