mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 b158935f70
			
		
	
	
		b158935f70
		
	
	
	
	
		
			
			The loops which SPI controller drivers use to process the list of transfers in a spi_message are typically very similar and have some error prone areas such as the handling of /CS. Help simplify drivers by factoring this code out into the core - if drivers provide a transfer_one() function instead of a transfer_one_message() function the core will handle processing at the message level. /CS can be controlled by either setting cs_gpio or providing a set_cs function. If this is not possible for hardware reasons then both can be omitted and the driver should continue to implement manual /CS handling. This is a first step in refactoring and it is expected that there will be further enhancements, for example factoring out of the mapping of transfers for DMA and the initiation and completion of interrupt driven transfers. Signed-off-by: Mark Brown <broonie@linaro.org>
		
			
				
	
	
		
			157 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			157 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #undef TRACE_SYSTEM
 | |
| #define TRACE_SYSTEM spi
 | |
| 
 | |
| #if !defined(_TRACE_SPI_H) || defined(TRACE_HEADER_MULTI_READ)
 | |
| #define _TRACE_SPI_H
 | |
| 
 | |
| #include <linux/ktime.h>
 | |
| #include <linux/tracepoint.h>
 | |
| 
 | |
| DECLARE_EVENT_CLASS(spi_master,
 | |
| 
 | |
| 	TP_PROTO(struct spi_master *master),
 | |
| 
 | |
| 	TP_ARGS(master),
 | |
| 
 | |
| 	TP_STRUCT__entry(
 | |
| 		__field(        int,           bus_num             )
 | |
| 	),
 | |
| 
 | |
| 	TP_fast_assign(
 | |
| 		__entry->bus_num = master->bus_num;
 | |
| 	),
 | |
| 
 | |
| 	TP_printk("spi%d", (int)__entry->bus_num)
 | |
| 
 | |
| );
 | |
| 
 | |
| DEFINE_EVENT(spi_master, spi_master_idle,
 | |
| 
 | |
| 	TP_PROTO(struct spi_master *master),
 | |
| 
 | |
| 	TP_ARGS(master)
 | |
| 
 | |
| );
 | |
| 
 | |
| DEFINE_EVENT(spi_master, spi_master_busy,
 | |
| 
 | |
| 	TP_PROTO(struct spi_master *master),
 | |
| 
 | |
| 	TP_ARGS(master)
 | |
| 
 | |
| );
 | |
| 
 | |
| DECLARE_EVENT_CLASS(spi_message,
 | |
| 
 | |
| 	TP_PROTO(struct spi_message *msg),
 | |
| 
 | |
| 	TP_ARGS(msg),
 | |
| 
 | |
| 	TP_STRUCT__entry(
 | |
| 		__field(        int,            bus_num         )
 | |
| 		__field(        int,            chip_select     )
 | |
| 		__field(        struct spi_message *,   msg     )
 | |
| 	),
 | |
| 
 | |
| 	TP_fast_assign(
 | |
| 		__entry->bus_num = msg->spi->master->bus_num;
 | |
| 		__entry->chip_select = msg->spi->chip_select;
 | |
| 		__entry->msg = msg;
 | |
| 	),
 | |
| 
 | |
|         TP_printk("spi%d.%d %p", (int)__entry->bus_num,
 | |
| 		  (int)__entry->chip_select,
 | |
| 		  (struct spi_message *)__entry->msg)
 | |
| );
 | |
| 
 | |
| DEFINE_EVENT(spi_message, spi_message_submit,
 | |
| 
 | |
| 	TP_PROTO(struct spi_message *msg),
 | |
| 
 | |
| 	TP_ARGS(msg)
 | |
| 
 | |
| );
 | |
| 
 | |
| DEFINE_EVENT(spi_message, spi_message_start,
 | |
| 
 | |
| 	TP_PROTO(struct spi_message *msg),
 | |
| 
 | |
| 	TP_ARGS(msg)
 | |
| 
 | |
| );
 | |
| 
 | |
| TRACE_EVENT(spi_message_done,
 | |
| 
 | |
| 	TP_PROTO(struct spi_message *msg),
 | |
| 
 | |
| 	TP_ARGS(msg),
 | |
| 
 | |
| 	TP_STRUCT__entry(
 | |
| 		__field(        int,            bus_num         )
 | |
| 		__field(        int,            chip_select     )
 | |
| 		__field(        struct spi_message *,   msg     )
 | |
| 		__field(        unsigned,       frame           )
 | |
| 		__field(        unsigned,       actual          )
 | |
| 	),
 | |
| 
 | |
| 	TP_fast_assign(
 | |
| 		__entry->bus_num = msg->spi->master->bus_num;
 | |
| 		__entry->chip_select = msg->spi->chip_select;
 | |
| 		__entry->msg = msg;
 | |
| 		__entry->frame = msg->frame_length;
 | |
| 		__entry->actual = msg->actual_length;
 | |
| 	),
 | |
| 
 | |
|         TP_printk("spi%d.%d %p len=%u/%u", (int)__entry->bus_num,
 | |
| 		  (int)__entry->chip_select,
 | |
| 		  (struct spi_message *)__entry->msg,
 | |
|                   (unsigned)__entry->actual, (unsigned)__entry->frame)
 | |
| );
 | |
| 
 | |
| DECLARE_EVENT_CLASS(spi_transfer,
 | |
| 
 | |
| 	TP_PROTO(struct spi_message *msg, struct spi_transfer *xfer),
 | |
| 
 | |
| 	TP_ARGS(msg, xfer),
 | |
| 
 | |
| 	TP_STRUCT__entry(
 | |
| 		__field(        int,            bus_num         )
 | |
| 		__field(        int,            chip_select     )
 | |
| 		__field(        struct spi_transfer *,   xfer   )
 | |
| 		__field(        int,            len             )
 | |
| 	),
 | |
| 
 | |
| 	TP_fast_assign(
 | |
| 		__entry->bus_num = msg->spi->master->bus_num;
 | |
| 		__entry->chip_select = msg->spi->chip_select;
 | |
| 		__entry->xfer = xfer;
 | |
| 		__entry->len = xfer->len;
 | |
| 	),
 | |
| 
 | |
|         TP_printk("spi%d.%d %p len=%d", (int)__entry->bus_num,
 | |
| 		  (int)__entry->chip_select,
 | |
| 		  (struct spi_message *)__entry->xfer,
 | |
| 		  (int)__entry->len)
 | |
| );
 | |
| 
 | |
| DEFINE_EVENT(spi_transfer, spi_transfer_start,
 | |
| 
 | |
| 	TP_PROTO(struct spi_message *msg, struct spi_transfer *xfer),
 | |
| 
 | |
| 	TP_ARGS(msg, xfer)
 | |
| 
 | |
| );
 | |
| 
 | |
| DEFINE_EVENT(spi_transfer, spi_transfer_stop,
 | |
| 
 | |
| 	TP_PROTO(struct spi_message *msg, struct spi_transfer *xfer),
 | |
| 
 | |
| 	TP_ARGS(msg, xfer)
 | |
| 
 | |
| );
 | |
| 
 | |
| #endif /* _TRACE_POWER_H */
 | |
| 
 | |
| /* This part must be outside protection */
 | |
| #include <trace/define_trace.h>
 |