Message ID | 20170608051603.16070-3-jiada_wang@mentor.com (mailing list archive) |
---|---|
State | Accepted |
Headers | show |
On Thu, Jun 08, 2017 at 02:16:01PM +0900, Jiada Wang wrote: > ECSPI contorller for iMX53 and iMX6 has few hardware issues > comparing to iMX51. > The change add possibility to detect which controller is used > to apply possible workaround and limitations. > > Signed-off-by: Jiada Wang <jiada_wang@mentor.com> > --- > .../devicetree/bindings/spi/fsl-imx-cspi.txt | 1 + > drivers/spi/spi-imx.c | 26 ++++++++++++++++++++-- > 2 files changed, 25 insertions(+), 2 deletions(-) > > diff --git a/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt b/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt > index 31b5b21..5bf1396 100644 > --- a/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt > +++ b/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt > @@ -9,6 +9,7 @@ Required properties: > - "fsl,imx31-cspi" for SPI compatible with the one integrated on i.MX31 > - "fsl,imx35-cspi" for SPI compatible with the one integrated on i.MX35 > - "fsl,imx51-ecspi" for SPI compatible with the one integrated on i.MX51 > + - "fsl,imx53-ecspi" for SPI compatible with the one integrated on i.MX53 and later Soc > - reg : Offset and length of the register set for the device > - interrupts : Should contain CSPI/eCSPI interrupt > - cs-gpios : Specifies the gpio pins to be used for chipselects. > diff --git a/drivers/spi/spi-imx.c b/drivers/spi/spi-imx.c > index 4469121..8e6f339 100644 > --- a/drivers/spi/spi-imx.c > +++ b/drivers/spi/spi-imx.c > @@ -63,7 +63,8 @@ enum spi_imx_devtype { > IMX27_CSPI, > IMX31_CSPI, > IMX35_CSPI, /* CSPI on all i.mx except above */ > - IMX51_ECSPI, /* ECSPI on i.mx51 and later */ > + IMX51_ECSPI, /* ECSPI on i.mx51 */ > + IMX53_ECSPI, /* ECSPI on i.mx53 and later */ Looks like i.MX51 and i.MX53 are the same. While the DT should have different compatibles (with fallbacks), the driver should map them to the same type until there's some difference found. Rob -- To unsubscribe from this list: send the line "unsubscribe linux-spi" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Hello Rob On 06/13/2017 12:53 AM, Rob Herring wrote: > On Thu, Jun 08, 2017 at 02:16:01PM +0900, Jiada Wang wrote: >> ECSPI contorller for iMX53 and iMX6 has few hardware issues >> comparing to iMX51. >> The change add possibility to detect which controller is used >> to apply possible workaround and limitations. >> >> Signed-off-by: Jiada Wang <jiada_wang@mentor.com> >> --- >> .../devicetree/bindings/spi/fsl-imx-cspi.txt | 1 + >> drivers/spi/spi-imx.c | 26 ++++++++++++++++++++-- >> 2 files changed, 25 insertions(+), 2 deletions(-) >> >> diff --git a/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt b/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt >> index 31b5b21..5bf1396 100644 >> --- a/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt >> +++ b/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt >> @@ -9,6 +9,7 @@ Required properties: >> - "fsl,imx31-cspi" for SPI compatible with the one integrated on i.MX31 >> - "fsl,imx35-cspi" for SPI compatible with the one integrated on i.MX35 >> - "fsl,imx51-ecspi" for SPI compatible with the one integrated on i.MX51 >> + - "fsl,imx53-ecspi" for SPI compatible with the one integrated on i.MX53 and later Soc >> - reg : Offset and length of the register set for the device >> - interrupts : Should contain CSPI/eCSPI interrupt >> - cs-gpios : Specifies the gpio pins to be used for chipselects. >> diff --git a/drivers/spi/spi-imx.c b/drivers/spi/spi-imx.c >> index 4469121..8e6f339 100644 >> --- a/drivers/spi/spi-imx.c >> +++ b/drivers/spi/spi-imx.c >> @@ -63,7 +63,8 @@ enum spi_imx_devtype { >> IMX27_CSPI, >> IMX31_CSPI, >> IMX35_CSPI, /* CSPI on all i.mx except above */ >> - IMX51_ECSPI, /* ECSPI on i.mx51 and later */ >> + IMX51_ECSPI, /* ECSPI on i.mx51 */ >> + IMX53_ECSPI, /* ECSPI on i.mx53 and later */ > > Looks like i.MX51 and i.MX53 are the same. While the DT should have > different compatibles (with fallbacks), the driver should map them to > the same type until there's some difference found. > the difference between i.MX51 and i.MX53 is introduced in the 4th patch "spi: imx: Add support for SPI Slave mode" in this patch set do you think, I need to merge the two patches into one? Thanks, Jiada > Rob > -- To unsubscribe from this list: send the line "unsubscribe linux-spi" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Tue, Jun 13, 2017 at 12:28 AM, Jiada Wang <jiada_wang@mentor.com> wrote: > Hello Rob > > > On 06/13/2017 12:53 AM, Rob Herring wrote: >> >> On Thu, Jun 08, 2017 at 02:16:01PM +0900, Jiada Wang wrote: >>> >>> ECSPI contorller for iMX53 and iMX6 has few hardware issues >>> comparing to iMX51. >>> The change add possibility to detect which controller is used >>> to apply possible workaround and limitations. >>> >>> Signed-off-by: Jiada Wang <jiada_wang@mentor.com> >>> --- >>> .../devicetree/bindings/spi/fsl-imx-cspi.txt | 1 + >>> drivers/spi/spi-imx.c | 26 >>> ++++++++++++++++++++-- >>> 2 files changed, 25 insertions(+), 2 deletions(-) >>> >>> diff --git a/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt >>> b/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt >>> index 31b5b21..5bf1396 100644 >>> --- a/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt >>> +++ b/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt >>> @@ -9,6 +9,7 @@ Required properties: >>> - "fsl,imx31-cspi" for SPI compatible with the one integrated on >>> i.MX31 >>> - "fsl,imx35-cspi" for SPI compatible with the one integrated on >>> i.MX35 >>> - "fsl,imx51-ecspi" for SPI compatible with the one integrated on >>> i.MX51 >>> + - "fsl,imx53-ecspi" for SPI compatible with the one integrated on >>> i.MX53 and later Soc >>> - reg : Offset and length of the register set for the device >>> - interrupts : Should contain CSPI/eCSPI interrupt >>> - cs-gpios : Specifies the gpio pins to be used for chipselects. >>> diff --git a/drivers/spi/spi-imx.c b/drivers/spi/spi-imx.c >>> index 4469121..8e6f339 100644 >>> --- a/drivers/spi/spi-imx.c >>> +++ b/drivers/spi/spi-imx.c >>> @@ -63,7 +63,8 @@ enum spi_imx_devtype { >>> IMX27_CSPI, >>> IMX31_CSPI, >>> IMX35_CSPI, /* CSPI on all i.mx except above */ >>> - IMX51_ECSPI, /* ECSPI on i.mx51 and later */ >>> + IMX51_ECSPI, /* ECSPI on i.mx51 */ >>> + IMX53_ECSPI, /* ECSPI on i.mx53 and later */ >> >> >> Looks like i.MX51 and i.MX53 are the same. While the DT should have >> different compatibles (with fallbacks), the driver should map them to >> the same type until there's some difference found. >> > the difference between i.MX51 and i.MX53 is introduced in the > 4th patch "spi: imx: Add support for SPI Slave mode" in this patch set Okay, I missed that. > do you think, I need to merge the two patches into one? No, not necessary. Acked-by: Rob Herring <robh@kernel.org> Rob -- To unsubscribe from this list: send the line "unsubscribe linux-spi" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Hello Mark and Sascha Could you please review my v4 patch set for i.MX SPI slave support Thanks, Jiada On 06/13/2017 07:29 AM, Rob Herring wrote: > On Tue, Jun 13, 2017 at 12:28 AM, Jiada Wang<jiada_wang@mentor.com> wrote: >> Hello Rob >> >> >> On 06/13/2017 12:53 AM, Rob Herring wrote: >>> On Thu, Jun 08, 2017 at 02:16:01PM +0900, Jiada Wang wrote: >>>> ECSPI contorller for iMX53 and iMX6 has few hardware issues >>>> comparing to iMX51. >>>> The change add possibility to detect which controller is used >>>> to apply possible workaround and limitations. >>>> >>>> Signed-off-by: Jiada Wang<jiada_wang@mentor.com> >>>> --- >>>> .../devicetree/bindings/spi/fsl-imx-cspi.txt | 1 + >>>> drivers/spi/spi-imx.c | 26 >>>> ++++++++++++++++++++-- >>>> 2 files changed, 25 insertions(+), 2 deletions(-) >>>> >>>> diff --git a/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt >>>> b/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt >>>> index 31b5b21..5bf1396 100644 >>>> --- a/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt >>>> +++ b/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt >>>> @@ -9,6 +9,7 @@ Required properties: >>>> - "fsl,imx31-cspi" for SPI compatible with the one integrated on >>>> i.MX31 >>>> - "fsl,imx35-cspi" for SPI compatible with the one integrated on >>>> i.MX35 >>>> - "fsl,imx51-ecspi" for SPI compatible with the one integrated on >>>> i.MX51 >>>> + - "fsl,imx53-ecspi" for SPI compatible with the one integrated on >>>> i.MX53 and later Soc >>>> - reg : Offset and length of the register set for the device >>>> - interrupts : Should contain CSPI/eCSPI interrupt >>>> - cs-gpios : Specifies the gpio pins to be used for chipselects. >>>> diff --git a/drivers/spi/spi-imx.c b/drivers/spi/spi-imx.c >>>> index 4469121..8e6f339 100644 >>>> --- a/drivers/spi/spi-imx.c >>>> +++ b/drivers/spi/spi-imx.c >>>> @@ -63,7 +63,8 @@ enum spi_imx_devtype { >>>> IMX27_CSPI, >>>> IMX31_CSPI, >>>> IMX35_CSPI, /* CSPI on all i.mx except above */ >>>> - IMX51_ECSPI, /* ECSPI on i.mx51 and later */ >>>> + IMX51_ECSPI, /* ECSPI on i.mx51 */ >>>> + IMX53_ECSPI, /* ECSPI on i.mx53 and later */ >>> >>> Looks like i.MX51 and i.MX53 are the same. While the DT should have >>> different compatibles (with fallbacks), the driver should map them to >>> the same type until there's some difference found. >>> >> the difference between i.MX51 and i.MX53 is introduced in the >> 4th patch "spi: imx: Add support for SPI Slave mode" in this patch set > Okay, I missed that. > >> do you think, I need to merge the two patches into one? > No, not necessary. > > Acked-by: Rob Herring<robh@kernel.org> > > Rob -- To unsubscribe from this list: send the line "unsubscribe linux-spi" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Mon, Jun 26, 2017 at 06:25:52PM -0700, Jiada Wang wrote: > Hello Mark and Sascha > > Could you please review my v4 patch set for i.MX SPI slave support Please don't send content free pings and please allow a reasonable time for review. People get busy, go on holiday, attend conferences and so on so unless there is some reason for urgency (like critical bug fixes) please allow at least a couple of weeks for review. If there have been review comments then people may be waiting for those to be addressed. Sending content free pings just adds to the mail volume (if they are seen at all) and if something has gone wrong you'll have to resend the patches anyway.
diff --git a/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt b/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt index 31b5b21..5bf1396 100644 --- a/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt +++ b/Documentation/devicetree/bindings/spi/fsl-imx-cspi.txt @@ -9,6 +9,7 @@ Required properties: - "fsl,imx31-cspi" for SPI compatible with the one integrated on i.MX31 - "fsl,imx35-cspi" for SPI compatible with the one integrated on i.MX35 - "fsl,imx51-ecspi" for SPI compatible with the one integrated on i.MX51 + - "fsl,imx53-ecspi" for SPI compatible with the one integrated on i.MX53 and later Soc - reg : Offset and length of the register set for the device - interrupts : Should contain CSPI/eCSPI interrupt - cs-gpios : Specifies the gpio pins to be used for chipselects. diff --git a/drivers/spi/spi-imx.c b/drivers/spi/spi-imx.c index 4469121..8e6f339 100644 --- a/drivers/spi/spi-imx.c +++ b/drivers/spi/spi-imx.c @@ -63,7 +63,8 @@ enum spi_imx_devtype { IMX27_CSPI, IMX31_CSPI, IMX35_CSPI, /* CSPI on all i.mx except above */ - IMX51_ECSPI, /* ECSPI on i.mx51 and later */ + IMX51_ECSPI, /* ECSPI on i.mx51 */ + IMX53_ECSPI, /* ECSPI on i.mx53 and later */ }; struct spi_imx_data; @@ -127,6 +128,11 @@ static inline int is_imx51_ecspi(struct spi_imx_data *d) return d->devtype_data->devtype == IMX51_ECSPI; } +static inline int is_imx53_ecspi(struct spi_imx_data *d) +{ + return d->devtype_data->devtype == IMX53_ECSPI; +} + #define MXC_SPI_BUF_RX(type) \ static void spi_imx_buf_rx_##type(struct spi_imx_data *spi_imx) \ { \ @@ -752,6 +758,17 @@ static struct spi_imx_devtype_data imx51_ecspi_devtype_data = { .devtype = IMX51_ECSPI, }; +static struct spi_imx_devtype_data imx53_ecspi_devtype_data = { + .intctrl = mx51_ecspi_intctrl, + .config = mx51_ecspi_config, + .trigger = mx51_ecspi_trigger, + .rx_available = mx51_ecspi_rx_available, + .reset = mx51_ecspi_reset, + .fifo_size = 64, + .has_dmamode = true, + .devtype = IMX53_ECSPI, +}; + static const struct platform_device_id spi_imx_devtype[] = { { .name = "imx1-cspi", @@ -772,6 +789,9 @@ static const struct platform_device_id spi_imx_devtype[] = { .name = "imx51-ecspi", .driver_data = (kernel_ulong_t) &imx51_ecspi_devtype_data, }, { + .name = "imx53-ecspi", + .driver_data = (kernel_ulong_t) &imx53_ecspi_devtype_data, + }, { /* sentinel */ } }; @@ -783,6 +803,7 @@ static const struct of_device_id spi_imx_dt_ids[] = { { .compatible = "fsl,imx31-cspi", .data = &imx31_cspi_devtype_data, }, { .compatible = "fsl,imx35-cspi", .data = &imx35_cspi_devtype_data, }, { .compatible = "fsl,imx51-ecspi", .data = &imx51_ecspi_devtype_data, }, + { .compatible = "fsl,imx53-ecspi", .data = &imx53_ecspi_devtype_data, }, { /* sentinel */ } }; MODULE_DEVICE_TABLE(of, spi_imx_dt_ids); @@ -1218,7 +1239,8 @@ static int spi_imx_probe(struct platform_device *pdev) spi_imx->bitbang.master->prepare_message = spi_imx_prepare_message; spi_imx->bitbang.master->unprepare_message = spi_imx_unprepare_message; spi_imx->bitbang.master->mode_bits = SPI_CPOL | SPI_CPHA | SPI_CS_HIGH; - if (is_imx35_cspi(spi_imx) || is_imx51_ecspi(spi_imx)) + if (is_imx35_cspi(spi_imx) || is_imx51_ecspi(spi_imx) || + is_imx53_ecspi(spi_imx)) spi_imx->bitbang.master->mode_bits |= SPI_LOOP | SPI_READY; spi_imx->spi_drctl = spi_drctl;
ECSPI contorller for iMX53 and iMX6 has few hardware issues comparing to iMX51. The change add possibility to detect which controller is used to apply possible workaround and limitations. Signed-off-by: Jiada Wang <jiada_wang@mentor.com> --- .../devicetree/bindings/spi/fsl-imx-cspi.txt | 1 + drivers/spi/spi-imx.c | 26 ++++++++++++++++++++-- 2 files changed, 25 insertions(+), 2 deletions(-)