__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
/* SPDX-License-Identifier: GPL-2.0 */
#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_controller,
TP_PROTO(struct spi_controller *controller),
TP_ARGS(controller),
TP_STRUCT__entry(
__field( int, bus_num )
),
TP_fast_assign(
__entry->bus_num = controller->bus_num;
),
TP_printk("spi%d", (int)__entry->bus_num)
);
DEFINE_EVENT(spi_controller, spi_controller_idle,
TP_PROTO(struct spi_controller *controller),
TP_ARGS(controller)
);
DEFINE_EVENT(spi_controller, spi_controller_busy,
TP_PROTO(struct spi_controller *controller),
TP_ARGS(controller)
);
TRACE_EVENT(spi_setup,
TP_PROTO(struct spi_device *spi, int status),
TP_ARGS(spi, status),
TP_STRUCT__entry(
__field(int, bus_num)
__field(int, chip_select)
__field(unsigned long, mode)
__field(unsigned int, bits_per_word)
__field(unsigned int, max_speed_hz)
__field(int, status)
),
TP_fast_assign(
__entry->bus_num = spi->controller->bus_num;
__entry->chip_select = spi_get_chipselect(spi, 0);
__entry->mode = spi->mode;
__entry->bits_per_word = spi->bits_per_word;
__entry->max_speed_hz = spi->max_speed_hz;
__entry->status = status;
),
TP_printk("spi%d.%d setup mode %lu, %s%s%s%s%u bits/w, %u Hz max --> %d",
__entry->bus_num, __entry->chip_select,
(__entry->mode & SPI_MODE_X_MASK),
(__entry->mode & SPI_CS_HIGH) ? "cs_high, " : "",
(__entry->mode & SPI_LSB_FIRST) ? "lsb, " : "",
(__entry->mode & SPI_3WIRE) ? "3wire, " : "",
(__entry->mode & SPI_LOOP) ? "loopback, " : "",
__entry->bits_per_word, __entry->max_speed_hz,
__entry->status)
);
TRACE_EVENT(spi_set_cs,
TP_PROTO(struct spi_device *spi, bool enable),
TP_ARGS(spi, enable),
TP_STRUCT__entry(
__field(int, bus_num)
__field(int, chip_select)
__field(unsigned long, mode)
__field(bool, enable)
),
TP_fast_assign(
__entry->bus_num = spi->controller->bus_num;
__entry->chip_select = spi_get_chipselect(spi, 0);
__entry->mode = spi->mode;
__entry->enable = enable;
),
TP_printk("spi%d.%d %s%s",
__entry->bus_num, __entry->chip_select,
__entry->enable ? "activate" : "deactivate",
(__entry->mode & SPI_CS_HIGH) ? ", cs_high" : "")
);
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->controller->bus_num;
__entry->chip_select = spi_get_chipselect(msg->spi, 0);
__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->controller->bus_num;
__entry->chip_select = spi_get_chipselect(msg->spi, 0);
__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)
);
/*
* Consider a buffer valid if non-NULL and if it doesn't match the dummy buffer
* that only exist to work with controllers that have SPI_CONTROLLER_MUST_TX or
* SPI_CONTROLLER_MUST_RX.
*/
#define spi_valid_txbuf(msg, xfer) \
(xfer->tx_buf && xfer->tx_buf != msg->spi->controller->dummy_tx)
#define spi_valid_rxbuf(msg, xfer) \
(xfer->rx_buf && xfer->rx_buf != msg->spi->controller->dummy_rx)
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 )
__dynamic_array(u8, rx_buf,
spi_valid_rxbuf(msg, xfer) ?
(xfer->len < 64 ? xfer->len : 64) : 0)
__dynamic_array(u8, tx_buf,
spi_valid_txbuf(msg, xfer) ?
(xfer->len < 64 ? xfer->len : 64) : 0)
),
TP_fast_assign(
__entry->bus_num = msg->spi->controller->bus_num;
__entry->chip_select = spi_get_chipselect(msg->spi, 0);
__entry->xfer = xfer;
__entry->len = xfer->len;
if (spi_valid_txbuf(msg, xfer))
memcpy(__get_dynamic_array(tx_buf),
xfer->tx_buf, __get_dynamic_array_len(tx_buf));
if (spi_valid_rxbuf(msg, xfer))
memcpy(__get_dynamic_array(rx_buf),
xfer->rx_buf, __get_dynamic_array_len(rx_buf));
),
TP_printk("spi%d.%d %p len=%d tx=[%*phD] rx=[%*phD]",
__entry->bus_num, __entry->chip_select,
__entry->xfer, __entry->len,
__get_dynamic_array_len(tx_buf), __get_dynamic_array(tx_buf),
__get_dynamic_array_len(rx_buf), __get_dynamic_array(rx_buf))
);
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>
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| 9p.h | File | 6.19 KB | 0644 |
|
| afs.h | File | 56.82 KB | 0644 |
|
| alarmtimer.h | File | 2.04 KB | 0644 |
|
| amdxdna.h | File | 2.72 KB | 0644 |
|
| asoc.h | File | 5.39 KB | 0644 |
|
| avc.h | File | 1.23 KB | 0644 |
|
| bcache.h | File | 11.44 KB | 0644 |
|
| block.h | File | 15.84 KB | 0644 |
|
| bpf_test_run.h | File | 1.23 KB | 0644 |
|
| bridge.h | File | 4.59 KB | 0644 |
|
| btrfs.h | File | 70.77 KB | 0644 |
|
| cachefiles.h | File | 23.19 KB | 0644 |
|
| capability.h | File | 1.67 KB | 0644 |
|
| cgroup.h | File | 6.26 KB | 0644 |
|
| clk.h | File | 5.96 KB | 0644 |
|
| cma.h | File | 2.71 KB | 0644 |
|
| compaction.h | File | 7.73 KB | 0644 |
|
| context_tracking.h | File | 1.15 KB | 0644 |
|
| cpuhp.h | File | 1.83 KB | 0644 |
|
| csd.h | File | 1.49 KB | 0644 |
|
| damon.h | File | 2.23 KB | 0644 |
|
| devfreq.h | File | 1.87 KB | 0644 |
|
| devlink.h | File | 6.46 KB | 0644 |
|
| dlm.h | File | 20.27 KB | 0644 |
|
| dma.h | File | 13.16 KB | 0644 |
|
| dma_fence.h | File | 1.59 KB | 0644 |
|
| erofs.h | File | 5.25 KB | 0644 |
|
| error_report.h | File | 2.06 KB | 0644 |
|
| ext4.h | File | 75.18 KB | 0644 |
|
| f2fs.h | File | 58.55 KB | 0644 |
|
| fib.h | File | 2.52 KB | 0644 |
|
| fib6.h | File | 2.49 KB | 0644 |
|
| filelock.h | File | 7.28 KB | 0644 |
|
| filemap.h | File | 4.56 KB | 0644 |
|
| firewire.h | File | 30.85 KB | 0644 |
|
| firewire_ohci.h | File | 3.41 KB | 0644 |
|
| fs_dax.h | File | 8.27 KB | 0644 |
|
| fscache.h | File | 14.27 KB | 0644 |
|
| fsi.h | File | 5.58 KB | 0644 |
|
| fsi_master_aspeed.h | File | 2.28 KB | 0644 |
|
| fsi_master_ast_cf.h | File | 3.67 KB | 0644 |
|
| fsi_master_gpio.h | File | 3.92 KB | 0644 |
|
| fsi_master_i2cr.h | File | 3.17 KB | 0644 |
|
| gpio.h | File | 1.07 KB | 0644 |
|
| gpu_mem.h | File | 1.21 KB | 0644 |
|
| habanalabs.h | File | 5.77 KB | 0644 |
|
| handshake.h | File | 8.21 KB | 0644 |
|
| host1x.h | File | 5.54 KB | 0644 |
|
| huge_memory.h | File | 6.54 KB | 0644 |
|
| hugetlbfs.h | File | 3.73 KB | 0644 |
|
| hw_pressure.h | File | 698 B | 0644 |
|
| hwmon.h | File | 1.43 KB | 0644 |
|
| i2c.h | File | 3.95 KB | 0644 |
|
| i2c_slave.h | File | 1.84 KB | 0644 |
|
| ib_mad.h | File | 12.42 KB | 0644 |
|
| ib_umad.h | File | 4 KB | 0644 |
|
| icmp.h | File | 1.54 KB | 0644 |
|
| initcall.h | File | 1.27 KB | 0644 |
|
| intel-sst.h | File | 2.51 KB | 0644 |
|
| intel_ifs.h | File | 1.39 KB | 0644 |
|
| intel_ish.h | File | 547 B | 0644 |
|
| io_uring.h | File | 16.45 KB | 0644 |
|
| iocost.h | File | 6.14 KB | 0644 |
|
| iommu.h | File | 2.95 KB | 0644 |
|
| ipi.h | File | 2.85 KB | 0644 |
|
| irq.h | File | 4.7 KB | 0644 |
|
| irq_matrix.h | File | 4.94 KB | 0644 |
|
| iscsi.h | File | 2.24 KB | 0644 |
|
| jbd2.h | File | 12.6 KB | 0644 |
|
| kmem.h | File | 9.57 KB | 0644 |
|
| ksm.h | File | 6.02 KB | 0644 |
|
| kvm.h | File | 11.77 KB | 0644 |
|
| kyber.h | File | 2.27 KB | 0644 |
|
| libata.h | File | 23.72 KB | 0644 |
|
| lock.h | File | 2.76 KB | 0644 |
|
| maple_tree.h | File | 2.69 KB | 0644 |
|
| mce.h | File | 2.53 KB | 0644 |
|
| mctp.h | File | 1.77 KB | 0644 |
|
| mdio.h | File | 1.02 KB | 0644 |
|
| memcg.h | File | 2.21 KB | 0644 |
|
| migrate.h | File | 3.74 KB | 0644 |
|
| mlxsw.h | File | 2.62 KB | 0644 |
|
| mmap.h | File | 2.72 KB | 0644 |
|
| mmap_lock.h | File | 1.69 KB | 0644 |
|
| mmc.h | File | 7.2 KB | 0644 |
|
| mmflags.h | File | 9.88 KB | 0644 |
|
| module.h | File | 2.75 KB | 0644 |
|
| mptcp.h | File | 4.71 KB | 0644 |
|
| napi.h | File | 1.9 KB | 0644 |
|
| nbd.h | File | 2.14 KB | 0644 |
|
| neigh.h | File | 6.86 KB | 0644 |
|
| net.h | File | 7.71 KB | 0644 |
|
| net_probe_common.h | File | 3.26 KB | 0644 |
|
| netfs.h | File | 24.34 KB | 0644 |
|
| netlink.h | File | 485 B | 0644 |
|
| nilfs2.h | File | 5.34 KB | 0644 |
|
| nmi.h | File | 780 B | 0644 |
|
| notifier.h | File | 1.07 KB | 0644 |
|
| objagg.h | File | 4.58 KB | 0644 |
|
| oom.h | File | 4.95 KB | 0644 |
|
| osnoise.h | File | 2.93 KB | 0644 |
|
| page_isolation.h | File | 943 B | 0644 |
|
| page_pool.h | File | 2.76 KB | 0644 |
|
| page_ref.h | File | 2.98 KB | 0644 |
|
| pagemap.h | File | 2.14 KB | 0644 |
|
| percpu.h | File | 3.11 KB | 0644 |
|
| power.h | File | 11.3 KB | 0644 |
|
| power_cpu_migrate.h | File | 1.59 KB | 0644 |
|
| preemptirq.h | File | 1.8 KB | 0644 |
|
| printk.h | File | 786 B | 0644 |
|
| pwc.h | File | 1.63 KB | 0644 |
|
| pwm.h | File | 3.85 KB | 0644 |
|
| qdisc.h | File | 3.73 KB | 0644 |
|
| qla.h | File | 905 B | 0644 |
|
| qrtr.h | File | 2.53 KB | 0644 |
|
| rcu.h | File | 24.74 KB | 0644 |
|
| rdma_core.h | File | 7.02 KB | 0644 |
|
| regulator.h | File | 2.81 KB | 0644 |
|
| rpcgss.h | File | 14.58 KB | 0644 |
|
| rpcrdma.h | File | 50.19 KB | 0644 |
|
| rpm.h | File | 3.35 KB | 0644 |
|
| rseq.h | File | 1.45 KB | 0644 |
|
| rtc.h | File | 3.28 KB | 0644 |
|
| rust_sample.h | File | 683 B | 0644 |
|
| rwmmio.h | File | 2.67 KB | 0644 |
|
| rxrpc.h | File | 79.53 KB | 0644 |
|
| sched.h | File | 20.02 KB | 0644 |
|
| sched_ext.h | File | 536 B | 0644 |
|
| scmi.h | File | 4.63 KB | 0644 |
|
| scsi.h | File | 11.84 KB | 0644 |
|
| sctp.h | File | 2.38 KB | 0644 |
|
| signal.h | File | 3.4 KB | 0644 |
|
| siox.h | File | 1.99 KB | 0644 |
|
| skb.h | File | 2.04 KB | 0644 |
|
| smbus.h | File | 7.33 KB | 0644 |
|
| sock.h | File | 7.56 KB | 0644 |
|
| sof.h | File | 3.16 KB | 0644 |
|
| sof_intel.h | File | 3.87 KB | 0644 |
|
| spi.h | File | 5.86 KB | 0644 |
|
| spmi.h | File | 3.24 KB | 0644 |
|
| sunrpc.h | File | 59.37 KB | 0644 |
|
| sunvnet.h | File | 3.06 KB | 0644 |
|
| swiotlb.h | File | 1.01 KB | 0644 |
|
| syscalls.h | File | 1.48 KB | 0644 |
|
| target.h | File | 7.62 KB | 0644 |
|
| task.h | File | 2.27 KB | 0644 |
|
| tcp.h | File | 18.68 KB | 0644 |
|
| tegra_apb_dma.h | File | 1.52 KB | 0644 |
|
| thp.h | File | 2.48 KB | 0644 |
|
| timer.h | File | 10.88 KB | 0644 |
|
| timer_migration.h | File | 6.86 KB | 0644 |
|
| timestamp.h | File | 2.92 KB | 0644 |
|
| tlb.h | File | 1.41 KB | 0644 |
|
| udp.h | File | 1.25 KB | 0644 |
|
| v4l2.h | File | 8.81 KB | 0644 |
|
| vb2.h | File | 1.73 KB | 0644 |
|
| vmalloc.h | File | 3.2 KB | 0644 |
|
| vmscan.h | File | 13.92 KB | 0644 |
|
| vsock_virtio_transport_common.h | File | 3.71 KB | 0644 |
|
| watchdog.h | File | 1.45 KB | 0644 |
|
| wbt.h | File | 3.82 KB | 0644 |
|
| workqueue.h | File | 2.98 KB | 0644 |
|
| writeback.h | File | 22.52 KB | 0644 |
|
| xdp.h | File | 10.05 KB | 0644 |
|
| xen.h | File | 13.9 KB | 0644 |
|