18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 28c2ecf20Sopenharmony_ci#undef TRACE_SYSTEM 38c2ecf20Sopenharmony_ci#define TRACE_SYSTEM spi 48c2ecf20Sopenharmony_ci 58c2ecf20Sopenharmony_ci#if !defined(_TRACE_SPI_H) || defined(TRACE_HEADER_MULTI_READ) 68c2ecf20Sopenharmony_ci#define _TRACE_SPI_H 78c2ecf20Sopenharmony_ci 88c2ecf20Sopenharmony_ci#include <linux/ktime.h> 98c2ecf20Sopenharmony_ci#include <linux/tracepoint.h> 108c2ecf20Sopenharmony_ci 118c2ecf20Sopenharmony_ciDECLARE_EVENT_CLASS(spi_controller, 128c2ecf20Sopenharmony_ci 138c2ecf20Sopenharmony_ci TP_PROTO(struct spi_controller *controller), 148c2ecf20Sopenharmony_ci 158c2ecf20Sopenharmony_ci TP_ARGS(controller), 168c2ecf20Sopenharmony_ci 178c2ecf20Sopenharmony_ci TP_STRUCT__entry( 188c2ecf20Sopenharmony_ci __field( int, bus_num ) 198c2ecf20Sopenharmony_ci ), 208c2ecf20Sopenharmony_ci 218c2ecf20Sopenharmony_ci TP_fast_assign( 228c2ecf20Sopenharmony_ci __entry->bus_num = controller->bus_num; 238c2ecf20Sopenharmony_ci ), 248c2ecf20Sopenharmony_ci 258c2ecf20Sopenharmony_ci TP_printk("spi%d", (int)__entry->bus_num) 268c2ecf20Sopenharmony_ci 278c2ecf20Sopenharmony_ci); 288c2ecf20Sopenharmony_ci 298c2ecf20Sopenharmony_ciDEFINE_EVENT(spi_controller, spi_controller_idle, 308c2ecf20Sopenharmony_ci 318c2ecf20Sopenharmony_ci TP_PROTO(struct spi_controller *controller), 328c2ecf20Sopenharmony_ci 338c2ecf20Sopenharmony_ci TP_ARGS(controller) 348c2ecf20Sopenharmony_ci 358c2ecf20Sopenharmony_ci); 368c2ecf20Sopenharmony_ci 378c2ecf20Sopenharmony_ciDEFINE_EVENT(spi_controller, spi_controller_busy, 388c2ecf20Sopenharmony_ci 398c2ecf20Sopenharmony_ci TP_PROTO(struct spi_controller *controller), 408c2ecf20Sopenharmony_ci 418c2ecf20Sopenharmony_ci TP_ARGS(controller) 428c2ecf20Sopenharmony_ci 438c2ecf20Sopenharmony_ci); 448c2ecf20Sopenharmony_ci 458c2ecf20Sopenharmony_ciDECLARE_EVENT_CLASS(spi_message, 468c2ecf20Sopenharmony_ci 478c2ecf20Sopenharmony_ci TP_PROTO(struct spi_message *msg), 488c2ecf20Sopenharmony_ci 498c2ecf20Sopenharmony_ci TP_ARGS(msg), 508c2ecf20Sopenharmony_ci 518c2ecf20Sopenharmony_ci TP_STRUCT__entry( 528c2ecf20Sopenharmony_ci __field( int, bus_num ) 538c2ecf20Sopenharmony_ci __field( int, chip_select ) 548c2ecf20Sopenharmony_ci __field( struct spi_message *, msg ) 558c2ecf20Sopenharmony_ci ), 568c2ecf20Sopenharmony_ci 578c2ecf20Sopenharmony_ci TP_fast_assign( 588c2ecf20Sopenharmony_ci __entry->bus_num = msg->spi->controller->bus_num; 598c2ecf20Sopenharmony_ci __entry->chip_select = msg->spi->chip_select; 608c2ecf20Sopenharmony_ci __entry->msg = msg; 618c2ecf20Sopenharmony_ci ), 628c2ecf20Sopenharmony_ci 638c2ecf20Sopenharmony_ci TP_printk("spi%d.%d %p", (int)__entry->bus_num, 648c2ecf20Sopenharmony_ci (int)__entry->chip_select, 658c2ecf20Sopenharmony_ci (struct spi_message *)__entry->msg) 668c2ecf20Sopenharmony_ci); 678c2ecf20Sopenharmony_ci 688c2ecf20Sopenharmony_ciDEFINE_EVENT(spi_message, spi_message_submit, 698c2ecf20Sopenharmony_ci 708c2ecf20Sopenharmony_ci TP_PROTO(struct spi_message *msg), 718c2ecf20Sopenharmony_ci 728c2ecf20Sopenharmony_ci TP_ARGS(msg) 738c2ecf20Sopenharmony_ci 748c2ecf20Sopenharmony_ci); 758c2ecf20Sopenharmony_ci 768c2ecf20Sopenharmony_ciDEFINE_EVENT(spi_message, spi_message_start, 778c2ecf20Sopenharmony_ci 788c2ecf20Sopenharmony_ci TP_PROTO(struct spi_message *msg), 798c2ecf20Sopenharmony_ci 808c2ecf20Sopenharmony_ci TP_ARGS(msg) 818c2ecf20Sopenharmony_ci 828c2ecf20Sopenharmony_ci); 838c2ecf20Sopenharmony_ci 848c2ecf20Sopenharmony_ciTRACE_EVENT(spi_message_done, 858c2ecf20Sopenharmony_ci 868c2ecf20Sopenharmony_ci TP_PROTO(struct spi_message *msg), 878c2ecf20Sopenharmony_ci 888c2ecf20Sopenharmony_ci TP_ARGS(msg), 898c2ecf20Sopenharmony_ci 908c2ecf20Sopenharmony_ci TP_STRUCT__entry( 918c2ecf20Sopenharmony_ci __field( int, bus_num ) 928c2ecf20Sopenharmony_ci __field( int, chip_select ) 938c2ecf20Sopenharmony_ci __field( struct spi_message *, msg ) 948c2ecf20Sopenharmony_ci __field( unsigned, frame ) 958c2ecf20Sopenharmony_ci __field( unsigned, actual ) 968c2ecf20Sopenharmony_ci ), 978c2ecf20Sopenharmony_ci 988c2ecf20Sopenharmony_ci TP_fast_assign( 998c2ecf20Sopenharmony_ci __entry->bus_num = msg->spi->controller->bus_num; 1008c2ecf20Sopenharmony_ci __entry->chip_select = msg->spi->chip_select; 1018c2ecf20Sopenharmony_ci __entry->msg = msg; 1028c2ecf20Sopenharmony_ci __entry->frame = msg->frame_length; 1038c2ecf20Sopenharmony_ci __entry->actual = msg->actual_length; 1048c2ecf20Sopenharmony_ci ), 1058c2ecf20Sopenharmony_ci 1068c2ecf20Sopenharmony_ci TP_printk("spi%d.%d %p len=%u/%u", (int)__entry->bus_num, 1078c2ecf20Sopenharmony_ci (int)__entry->chip_select, 1088c2ecf20Sopenharmony_ci (struct spi_message *)__entry->msg, 1098c2ecf20Sopenharmony_ci (unsigned)__entry->actual, (unsigned)__entry->frame) 1108c2ecf20Sopenharmony_ci); 1118c2ecf20Sopenharmony_ci 1128c2ecf20Sopenharmony_ci/* 1138c2ecf20Sopenharmony_ci * consider a buffer valid if non-NULL and if it doesn't match the dummy buffer 1148c2ecf20Sopenharmony_ci * that only exist to work with controllers that have SPI_CONTROLLER_MUST_TX or 1158c2ecf20Sopenharmony_ci * SPI_CONTROLLER_MUST_RX. 1168c2ecf20Sopenharmony_ci */ 1178c2ecf20Sopenharmony_ci#define spi_valid_txbuf(msg, xfer) \ 1188c2ecf20Sopenharmony_ci (xfer->tx_buf && xfer->tx_buf != msg->spi->controller->dummy_tx) 1198c2ecf20Sopenharmony_ci#define spi_valid_rxbuf(msg, xfer) \ 1208c2ecf20Sopenharmony_ci (xfer->rx_buf && xfer->rx_buf != msg->spi->controller->dummy_rx) 1218c2ecf20Sopenharmony_ci 1228c2ecf20Sopenharmony_ciDECLARE_EVENT_CLASS(spi_transfer, 1238c2ecf20Sopenharmony_ci 1248c2ecf20Sopenharmony_ci TP_PROTO(struct spi_message *msg, struct spi_transfer *xfer), 1258c2ecf20Sopenharmony_ci 1268c2ecf20Sopenharmony_ci TP_ARGS(msg, xfer), 1278c2ecf20Sopenharmony_ci 1288c2ecf20Sopenharmony_ci TP_STRUCT__entry( 1298c2ecf20Sopenharmony_ci __field( int, bus_num ) 1308c2ecf20Sopenharmony_ci __field( int, chip_select ) 1318c2ecf20Sopenharmony_ci __field( struct spi_transfer *, xfer ) 1328c2ecf20Sopenharmony_ci __field( int, len ) 1338c2ecf20Sopenharmony_ci __dynamic_array(u8, rx_buf, 1348c2ecf20Sopenharmony_ci spi_valid_rxbuf(msg, xfer) ? 1358c2ecf20Sopenharmony_ci (xfer->len < 64 ? xfer->len : 64) : 0) 1368c2ecf20Sopenharmony_ci __dynamic_array(u8, tx_buf, 1378c2ecf20Sopenharmony_ci spi_valid_txbuf(msg, xfer) ? 1388c2ecf20Sopenharmony_ci (xfer->len < 64 ? xfer->len : 64) : 0) 1398c2ecf20Sopenharmony_ci ), 1408c2ecf20Sopenharmony_ci 1418c2ecf20Sopenharmony_ci TP_fast_assign( 1428c2ecf20Sopenharmony_ci __entry->bus_num = msg->spi->controller->bus_num; 1438c2ecf20Sopenharmony_ci __entry->chip_select = msg->spi->chip_select; 1448c2ecf20Sopenharmony_ci __entry->xfer = xfer; 1458c2ecf20Sopenharmony_ci __entry->len = xfer->len; 1468c2ecf20Sopenharmony_ci 1478c2ecf20Sopenharmony_ci if (spi_valid_txbuf(msg, xfer)) 1488c2ecf20Sopenharmony_ci memcpy(__get_dynamic_array(tx_buf), 1498c2ecf20Sopenharmony_ci xfer->tx_buf, __get_dynamic_array_len(tx_buf)); 1508c2ecf20Sopenharmony_ci 1518c2ecf20Sopenharmony_ci if (spi_valid_rxbuf(msg, xfer)) 1528c2ecf20Sopenharmony_ci memcpy(__get_dynamic_array(rx_buf), 1538c2ecf20Sopenharmony_ci xfer->rx_buf, __get_dynamic_array_len(rx_buf)); 1548c2ecf20Sopenharmony_ci ), 1558c2ecf20Sopenharmony_ci 1568c2ecf20Sopenharmony_ci TP_printk("spi%d.%d %p len=%d tx=[%*phD] rx=[%*phD]", 1578c2ecf20Sopenharmony_ci __entry->bus_num, __entry->chip_select, 1588c2ecf20Sopenharmony_ci __entry->xfer, __entry->len, 1598c2ecf20Sopenharmony_ci __get_dynamic_array_len(tx_buf), __get_dynamic_array(tx_buf), 1608c2ecf20Sopenharmony_ci __get_dynamic_array_len(rx_buf), __get_dynamic_array(rx_buf)) 1618c2ecf20Sopenharmony_ci); 1628c2ecf20Sopenharmony_ci 1638c2ecf20Sopenharmony_ciDEFINE_EVENT(spi_transfer, spi_transfer_start, 1648c2ecf20Sopenharmony_ci 1658c2ecf20Sopenharmony_ci TP_PROTO(struct spi_message *msg, struct spi_transfer *xfer), 1668c2ecf20Sopenharmony_ci 1678c2ecf20Sopenharmony_ci TP_ARGS(msg, xfer) 1688c2ecf20Sopenharmony_ci 1698c2ecf20Sopenharmony_ci); 1708c2ecf20Sopenharmony_ci 1718c2ecf20Sopenharmony_ciDEFINE_EVENT(spi_transfer, spi_transfer_stop, 1728c2ecf20Sopenharmony_ci 1738c2ecf20Sopenharmony_ci TP_PROTO(struct spi_message *msg, struct spi_transfer *xfer), 1748c2ecf20Sopenharmony_ci 1758c2ecf20Sopenharmony_ci TP_ARGS(msg, xfer) 1768c2ecf20Sopenharmony_ci 1778c2ecf20Sopenharmony_ci); 1788c2ecf20Sopenharmony_ci 1798c2ecf20Sopenharmony_ci#endif /* _TRACE_POWER_H */ 1808c2ecf20Sopenharmony_ci 1818c2ecf20Sopenharmony_ci/* This part must be outside protection */ 1828c2ecf20Sopenharmony_ci#include <trace/define_trace.h> 183