On Sun, Aug 18, 2019 at 09:25:57PM +0300, Vladimir Oltean wrote: > @@ -1391,6 +1402,13 @@ static void __spi_pump_messages(struct spi_controller *ctlr, bool in_kthread) > goto out; > } > > + if (!ctlr->ptp_sts_supported) { > + list_for_each_entry(xfer, &mesg->transfers, transfer_list) { > + xfer->ptp_sts_word_pre = 0; > + ptp_read_system_prets(xfer->ptp_sts); > + } > + } > + We can do better than this for controllers which use transfer_one(). > +const void *spi_xfer_ptp_sts_word(struct spi_transfer *xfer, bool pre) > +{ xfer can be const here too. > + * @ptp_sts_supported: If the driver sets this to true, it must provide a > + * time snapshot in @spi_transfer->ptp_sts as close as possible to the > + * moment in time when @spi_transfer->ptp_sts_word_pre and > + * @spi_transfer->ptp_sts_word_post were transmitted. > + * If the driver does not set this, the SPI core takes the snapshot as > + * close to the driver hand-over as possible. A couple of issues here. The big one is that for PIO transfers this is going to either complicate the code or introduce overhead in individual drivers for an extremely niche use case. I guess most drivers won't implement it which makes this a bit moot but then this is a concern that pushes back against the idea of implementing the feature. The other is that it's not 100% clear what you're looking to timestamp here - is it when the data goes on the wire, is it when the data goes on the FIFO (which could be relatively large)? I'm guessing you're looking for the physical transfer here, if that's the case should there be some effort to compensate for the delays in the controller?
Attachment:
signature.asc
Description: PGP signature