blob: 288c0c54a2b4ace63a94549c136fe255e2982089 [file] [log] [blame]
Zoltan Kiss2b2b6142013-09-04 21:11:05 +01001#undef TRACE_SYSTEM
2#define TRACE_SYSTEM swiotlb
3
4#if !defined(_TRACE_SWIOTLB_H) || defined(TRACE_HEADER_MULTI_READ)
5#define _TRACE_SWIOTLB_H
6
7#include <linux/tracepoint.h>
8
9TRACE_EVENT(swiotlb_bounced,
10
11 TP_PROTO(struct device *dev,
12 dma_addr_t dev_addr,
13 size_t size,
Geert Uytterhoeven1fd1e6c2016-12-16 14:28:41 +010014 enum swiotlb_force swiotlb_force),
Zoltan Kiss2b2b6142013-09-04 21:11:05 +010015
16 TP_ARGS(dev, dev_addr, size, swiotlb_force),
17
18 TP_STRUCT__entry(
Geert Uytterhoeven1fd1e6c2016-12-16 14:28:41 +010019 __string( dev_name, dev_name(dev) )
20 __field( u64, dma_mask )
21 __field( dma_addr_t, dev_addr )
22 __field( size_t, size )
23 __field( enum swiotlb_force, swiotlb_force )
Zoltan Kiss2b2b6142013-09-04 21:11:05 +010024 ),
25
26 TP_fast_assign(
27 __assign_str(dev_name, dev_name(dev));
28 __entry->dma_mask = (dev->dma_mask ? *dev->dma_mask : 0);
29 __entry->dev_addr = dev_addr;
30 __entry->size = size;
31 __entry->swiotlb_force = swiotlb_force;
32 ),
33
34 TP_printk("dev_name: %s dma_mask=%llx dev_addr=%llx "
35 "size=%zu %s",
36 __get_str(dev_name),
37 __entry->dma_mask,
38 (unsigned long long)__entry->dev_addr,
39 __entry->size,
Geert Uytterhoeven1fd1e6c2016-12-16 14:28:41 +010040 __print_symbolic(__entry->swiotlb_force,
41 { SWIOTLB_NORMAL, "NORMAL" },
Geert Uytterhoeven41c6b3e2016-12-16 14:28:42 +010042 { SWIOTLB_FORCE, "FORCE" },
43 { SWIOTLB_NO_FORCE, "NO_FORCE" }))
Zoltan Kiss2b2b6142013-09-04 21:11:05 +010044);
45
46#endif /* _TRACE_SWIOTLB_H */
47
48/* This part must be outside protection */
49#include <trace/define_trace.h>