RE: [RFC PATCH 1/2] spi: Add multiple CS support for a single SPI device

From: Mahapatra, Amit Kumar
Date: Thu Jun 23 2022 - 07:39:33 EST


Hello Mark,

> -----Original Message-----
> From: linux-arm-kernel <linux-arm-kernel-bounces@xxxxxxxxxxxxxxxxxxx> On
> Behalf Of Mark Brown
> Sent: Thursday, June 9, 2022 5:24 PM
> To: Amit Kumar Mahapatra <amit.kumar-mahapatra@xxxxxxxxxx>
> Cc: p.yadav@xxxxxx; miquel.raynal@xxxxxxxxxxx; richard@xxxxxx;
> vigneshr@xxxxxx; git@xxxxxxxxxx; michal.simek@xxxxxxxxxx; linux-
> spi@xxxxxxxxxxxxxxx; linux-arm-kernel@xxxxxxxxxxxxxxxxxxx; linux-
> kernel@xxxxxxxxxxxxxxx; michael@xxxxxxxx; linux-mtd@xxxxxxxxxxxxxxxxxxx
> Subject: Re: [RFC PATCH 1/2] spi: Add multiple CS support for a single SPI
> device
>
> On Mon, Jun 06, 2022 at 04:56:06PM +0530, Amit Kumar Mahapatra wrote:
>
> > ---
> > drivers/spi/spi-zynqmp-gqspi.c | 30 ++++++++++++++++++++++++++----
> > drivers/spi/spi.c | 10 +++++++---
> > include/linux/spi/spi.h | 10 +++++++++-
> > 3 files changed, 42 insertions(+), 8 deletions(-)
>
> Please split the core and driver support into separate patches, they are
> separate things.

Ok, I will split the patches.
>
> > --- a/drivers/spi/spi.c
> > +++ b/drivers/spi/spi.c
> > @@ -2082,6 +2082,8 @@ static int of_spi_parse_dt(struct spi_controller
> > *ctlr, struct spi_device *spi, {
> > u32 value;
> > int rc;
> > + u32 cs[SPI_CS_CNT_MAX];
> > + u8 idx;
> >
> > /* Mode (clock phase/polarity/etc.) */
> > if (of_property_read_bool(nc, "spi-cpha"))
>
> This is changing the DT binding but doesn't have any updates to the binding
> document. The binding code also doesn't validate that we don't have too
> many chip selects.

The following updates are done in the binding documents for adding multiple
CS support:
In jedec,spi-nor.yaml file " maxItems " of the "reg" DT property has been
updated to accommodate two CS per SPI device.
https://github.com/torvalds/linux/blob/de5c208d533a46a074eb46ea17f672cc005a7269/Documentation/devicetree/bindings/mtd/jedec%2Cspi-nor.yaml#L49

An example of a flash node with two CS has been added in spi-controller.yaml
https://github.com/torvalds/linux/blob/de5c208d533a46a074eb46ea17f672cc005a7269/Documentation/devicetree/bindings/spi/spi-controller.yaml#L141
>
> > + /* Bit mask of the chipselect(s) that the driver
> > + * need to use form the chipselect array.
> > + */
> > + u8 cs_index_mask : 2;
>
> Why make this a bitfield?

https://github.com/torvalds/linux/blob/de5c208d533a46a074eb46ea17f672cc005a7269/Documentation/devicetree/bindings/mtd/jedec%2Cspi-nor.yaml#L49

As per the DT bindings we are supporting max 2 chip selects per SPI device
that is the reason I had taken it as an bitfield of 2. But now I think that in
future when the number of chip selects per device would increase i.e.,
more than 2, then we have to again increase the bitfield allocation for
accommodating the increase in the number of chip selects per SPI device,
So I think it's better to drop the bitfield for now and use cs_index_mask
as an u8
>
> I'm also not seeing anything here that checks that the driver supports
> multiple chip selects - it seems like something that's going to cause issues
> and we should probably have something to handle that situation.

In my approach the chip select member (chip_select) of the spi_device structure
is changed to an array (chip_select[2]). This array is used to store the CS values
coming from the "reg" DT property.
In case of multiple chip selects spi->chip_slect[0] will hold CS0 value &
spi->chip_select[1] wil hold CS1 value.
In case of single chip select the spi->chip_select[0] will hold the chip select value.

As per the current implementation all the drivers fetch their chip select value form
spi->chip_select, but now the driver code needs to be modified to fetch the value
from spi->chip_select[0] instead and by this approach we do not need to check if the
driver supports single or multiple CS.

Hope I addressed all your concerns and please let us know what you think.

Regards,
Amit