* it is not set for this transfer.
         * Set transfer tx_nbits and rx_nbits as single transfer default
         * (SPI_NBITS_SINGLE) if it is not set for this transfer.
+        * Ensure transfer word_delay is at least as long as that required by
+        * device itself.
         */
        message->frame_length = 0;
        list_for_each_entry(xfer, &message->transfers, transfer_list) {
                                !(spi->mode & SPI_RX_QUAD))
                                return -EINVAL;
                }
+
+               if (xfer->word_delay_usecs < spi->word_delay_usecs)
+                       xfer->word_delay_usecs = spi->word_delay_usecs;
        }
 
        message->status = -EINPROGRESS;
 
  *     the spi_master.
  * @cs_gpiod: gpio descriptor of the chipselect line (optional, NULL when
  *     not using a GPIO line)
+ * @word_delay_usecs: microsecond delay to be inserted between consecutive
+ *     words of a transfer
  *
  * @statistics: statistics for the spi_device
  *
        const char              *driver_override;
        int                     cs_gpio;        /* LEGACY: chip select gpio */
        struct gpio_desc        *cs_gpiod;      /* chip select gpio desc */
+       uint8_t                 word_delay_usecs; /* inter-word delay */
 
        /* the statistics */
        struct spi_statistics   statistics;
  * @delay_usecs: microseconds to delay after this transfer before
  *     (optionally) changing the chipselect status, then starting
  *     the next transfer or completing this @spi_message.
+ * @word_delay_usecs: microseconds to inter word delay after each word size
+ *     (set by bits_per_word) transmission.
  * @word_delay: clock cycles to inter word delay after each word size
  *     (set by bits_per_word) transmission.
  * @transfer_list: transfers are sequenced through @spi_message.transfers
 #define        SPI_NBITS_DUAL          0x02 /* 2bits transfer */
 #define        SPI_NBITS_QUAD          0x04 /* 4bits transfer */
        u8              bits_per_word;
+       u8              word_delay_usecs;
        u16             delay_usecs;
        u32             speed_hz;
        u16             word_delay;