[PATCH] SPI: DUAL and QUAD support
yuhang wang
wangyuhang2014 at gmail.com
Thu Aug 8 22:09:47 EDT 2013
Hi, Pekon
2013/8/7 Gupta, Pekon <pekon at ti.com>:
>>
>> Hello,
>> > diff --git a/include/linux/spi/spi.h b/include/linux/spi/spi.h
>> > index 38c2b92..222e49e 100644
>> > --- a/include/linux/spi/spi.h
>> > +++ b/include/linux/spi/spi.h
>> > @@ -437,6 +441,8 @@ extern struct spi_master
>> > *spi_busnum_to_master(u16 busnum);
>> > * @rx_buf: data to be read (dma-safe memory), or NULL
>> > * @tx_dma: DMA address of tx_buf, if @spi_message.is_dma_mapped
>> > * @rx_dma: DMA address of rx_buf, if @spi_message.is_dma_mapped
>> > + * @tx_nbits: number of bits used for writting
>> > + * @rx_nbits: number of bits used for reading
>> > * @len: size of rx and tx buffers (in bytes)
>> > * @speed_hz: Select a speed other than the device default for this
>> > * transfer. If 0 the default (from @spi_device) is used.
>> > @@ -491,6 +497,11 @@ extern struct spi_master
>> > *spi_busnum_to_master(u16 busnum);
>> > * by the results of previous messages and where the whole transaction
>> > * ends when the chipselect goes intactive.
>> > *
>> > + * When SPI can transfer in 1x,2x or 4x. It can get this tranfer information
>> > + * from device through @tx_nbits and @rx_nbits. In Bi-direction, these
>> > + * two should both be set. User can set transfer mode with
>> > SPI_NBITS_SINGLE(1x)
>> > + * SPI_NBITS_DUAL(2x) and SPI_NBITS_QUAD(4x) to support these three
>> > transfer.
>> > + *
>> > * The code that submits an spi_message (and its spi_transfers)
>> > * to the lower layers is responsible for managing its memory.
>> > * Zero-initialize every field you don't set up explicitly, to
>> > @@ -511,6 +522,11 @@ struct spi_transfer {
>> > dma_addr_t rx_dma;
>> >
>> > unsigned cs_change:1;
>> > + u8 tx_nbits;
>> > + u8 rx_nbits;
>> > +#define SPI_NBITS_SINGLE 0x0; /* 1bit transfer */
>> > +#define SPI_NBITS_DUAL 0x01; /* 2bits transfer */
>> > +#define SPI_NBITS_QUAD 0x02; /* 4bits transfer */
>>
>> [Pekon]: I don't think it's a good place for #defines. Plz keep it out of struct
>> body.
> One more feedback, Its better you define SPI_NBITS_xx matching
> the actual number of wires used. This would leave places for some
> micro-wire and 3-wire SPI, and would be more readable.
> +#define SPI_NBITS_SINGLE_HALF_DUPLEX 0x0; /* 1bit transfer microwire*/
> +#define SPI_NBITS_SINGLE_FULL_DUPLEX 0x01; /* 1bit transfer normal SPI*/
> +#define SPI_NBITS_DUAL 2; /* 2bits transfer */
> +#define SPI_NBITS_QUAD 4; /* 4bits transfer */
>
Totally three points.
1. There are still other positions which have macro defined in struct
in spi.h. That means the macro is belonged to the member above. So to
make it consistent, define it in @spi_transfer seems OK.
2. I don't think that SPI_NBITS_SINGLE_HALF_DUPLEX is necessary.
tx_nbits and rx_nbits in @spi_transfer should be passed to spi master
driver and the master driver will set the certain mode depend on the
info in @spi_transfer. So there is no need to let the master driver
know SPI_NBITS_SINGLE_HALF_DUPLEX, also master can get the 3-wire SPI
info from spi_device->mode.
3. I agree to match the actual number of wires used. To make it 0x01,
0x02 and 0x04. Thanks.
Best regards.
More information about the linux-mtd
mailing list