Skip to content

Commit 309ed96

Browse files
osharabiogabbay
authored andcommitted
accel/habanalabs: add traces for dma mappings
In order to get a full picture of DMA mappings (e.g. to track DMAR errors), DMA mappings APIs should be covered. Signed-off-by: Ohad Sharabi <[email protected]> Reviewed-by: Oded Gabbay <[email protected]> Signed-off-by: Oded Gabbay <[email protected]>
1 parent d7aa294 commit 309ed96

File tree

1 file changed

+43
-0
lines changed

1 file changed

+43
-0
lines changed

include/trace/events/habanalabs.h

Lines changed: 43 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -87,6 +87,49 @@ DEFINE_EVENT(habanalabs_dma_alloc_template, habanalabs_dma_free,
8787
TP_PROTO(struct device *dev, u64 cpu_addr, u64 dma_addr, size_t size, const char *caller),
8888
TP_ARGS(dev, cpu_addr, dma_addr, size, caller));
8989

90+
DECLARE_EVENT_CLASS(habanalabs_dma_map_template,
91+
TP_PROTO(struct device *dev, u64 phys_addr, u64 dma_addr, size_t len,
92+
enum dma_data_direction dir, const char *caller),
93+
94+
TP_ARGS(dev, phys_addr, dma_addr, len, dir, caller),
95+
96+
TP_STRUCT__entry(
97+
__string(dname, dev_name(dev))
98+
__field(u64, phys_addr)
99+
__field(u64, dma_addr)
100+
__field(u32, len)
101+
__field(int, dir)
102+
__field(const char *, caller)
103+
),
104+
105+
TP_fast_assign(
106+
__assign_str(dname, dev_name(dev));
107+
__entry->phys_addr = phys_addr;
108+
__entry->dma_addr = dma_addr;
109+
__entry->len = len;
110+
__entry->dir = dir;
111+
__entry->caller = caller;
112+
),
113+
114+
TP_printk("%s: phys_addr: %#llx, dma_addr: %#llx, len: %#x, dir: %d, caller: %s",
115+
__get_str(dname),
116+
__entry->phys_addr,
117+
__entry->dma_addr,
118+
__entry->len,
119+
__entry->dir,
120+
__entry->caller)
121+
);
122+
123+
DEFINE_EVENT(habanalabs_dma_map_template, habanalabs_dma_map_page,
124+
TP_PROTO(struct device *dev, u64 phys_addr, u64 dma_addr, size_t len,
125+
enum dma_data_direction dir, const char *caller),
126+
TP_ARGS(dev, phys_addr, dma_addr, len, dir, caller));
127+
128+
DEFINE_EVENT(habanalabs_dma_map_template, habanalabs_dma_unmap_page,
129+
TP_PROTO(struct device *dev, u64 phys_addr, u64 dma_addr, size_t len,
130+
enum dma_data_direction dir, const char *caller),
131+
TP_ARGS(dev, phys_addr, dma_addr, len, dir, caller));
132+
90133
DECLARE_EVENT_CLASS(habanalabs_comms_template,
91134
TP_PROTO(struct device *dev, char *op_str),
92135

0 commit comments

Comments
 (0)