xref: /openbmc/linux/drivers/vfio/pci/trace.h (revision 33e5ee78)
133e5ee78SThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */
27f928917SAlexey Kardashevskiy /*
37f928917SAlexey Kardashevskiy  * VFIO PCI mmap/mmap_fault tracepoints
47f928917SAlexey Kardashevskiy  *
57f928917SAlexey Kardashevskiy  * Copyright (C) 2018 IBM Corp.  All rights reserved.
67f928917SAlexey Kardashevskiy  *     Author: Alexey Kardashevskiy <aik@ozlabs.ru>
77f928917SAlexey Kardashevskiy  */
87f928917SAlexey Kardashevskiy 
97f928917SAlexey Kardashevskiy #undef TRACE_SYSTEM
107f928917SAlexey Kardashevskiy #define TRACE_SYSTEM vfio_pci
117f928917SAlexey Kardashevskiy 
127f928917SAlexey Kardashevskiy #if !defined(_TRACE_VFIO_PCI_H) || defined(TRACE_HEADER_MULTI_READ)
137f928917SAlexey Kardashevskiy #define _TRACE_VFIO_PCI_H
147f928917SAlexey Kardashevskiy 
157f928917SAlexey Kardashevskiy #include <linux/tracepoint.h>
167f928917SAlexey Kardashevskiy 
177f928917SAlexey Kardashevskiy TRACE_EVENT(vfio_pci_nvgpu_mmap_fault,
187f928917SAlexey Kardashevskiy 	TP_PROTO(struct pci_dev *pdev, unsigned long hpa, unsigned long ua,
197f928917SAlexey Kardashevskiy 			vm_fault_t ret),
207f928917SAlexey Kardashevskiy 	TP_ARGS(pdev, hpa, ua, ret),
217f928917SAlexey Kardashevskiy 
227f928917SAlexey Kardashevskiy 	TP_STRUCT__entry(
237f928917SAlexey Kardashevskiy 		__field(const char *, name)
247f928917SAlexey Kardashevskiy 		__field(unsigned long, hpa)
257f928917SAlexey Kardashevskiy 		__field(unsigned long, ua)
267f928917SAlexey Kardashevskiy 		__field(int, ret)
277f928917SAlexey Kardashevskiy 	),
287f928917SAlexey Kardashevskiy 
297f928917SAlexey Kardashevskiy 	TP_fast_assign(
307f928917SAlexey Kardashevskiy 		__entry->name = dev_name(&pdev->dev),
317f928917SAlexey Kardashevskiy 		__entry->hpa = hpa;
327f928917SAlexey Kardashevskiy 		__entry->ua = ua;
337f928917SAlexey Kardashevskiy 		__entry->ret = ret;
347f928917SAlexey Kardashevskiy 	),
357f928917SAlexey Kardashevskiy 
367f928917SAlexey Kardashevskiy 	TP_printk("%s: %lx -> %lx ret=%d", __entry->name, __entry->hpa,
377f928917SAlexey Kardashevskiy 			__entry->ua, __entry->ret)
387f928917SAlexey Kardashevskiy );
397f928917SAlexey Kardashevskiy 
407f928917SAlexey Kardashevskiy TRACE_EVENT(vfio_pci_nvgpu_mmap,
417f928917SAlexey Kardashevskiy 	TP_PROTO(struct pci_dev *pdev, unsigned long hpa, unsigned long ua,
427f928917SAlexey Kardashevskiy 			unsigned long size, int ret),
437f928917SAlexey Kardashevskiy 	TP_ARGS(pdev, hpa, ua, size, ret),
447f928917SAlexey Kardashevskiy 
457f928917SAlexey Kardashevskiy 	TP_STRUCT__entry(
467f928917SAlexey Kardashevskiy 		__field(const char *, name)
477f928917SAlexey Kardashevskiy 		__field(unsigned long, hpa)
487f928917SAlexey Kardashevskiy 		__field(unsigned long, ua)
497f928917SAlexey Kardashevskiy 		__field(unsigned long, size)
507f928917SAlexey Kardashevskiy 		__field(int, ret)
517f928917SAlexey Kardashevskiy 	),
527f928917SAlexey Kardashevskiy 
537f928917SAlexey Kardashevskiy 	TP_fast_assign(
547f928917SAlexey Kardashevskiy 		__entry->name = dev_name(&pdev->dev),
557f928917SAlexey Kardashevskiy 		__entry->hpa = hpa;
567f928917SAlexey Kardashevskiy 		__entry->ua = ua;
577f928917SAlexey Kardashevskiy 		__entry->size = size;
587f928917SAlexey Kardashevskiy 		__entry->ret = ret;
597f928917SAlexey Kardashevskiy 	),
607f928917SAlexey Kardashevskiy 
617f928917SAlexey Kardashevskiy 	TP_printk("%s: %lx -> %lx size=%lx ret=%d", __entry->name, __entry->hpa,
627f928917SAlexey Kardashevskiy 			__entry->ua, __entry->size, __entry->ret)
637f928917SAlexey Kardashevskiy );
647f928917SAlexey Kardashevskiy 
657f928917SAlexey Kardashevskiy TRACE_EVENT(vfio_pci_npu2_mmap,
667f928917SAlexey Kardashevskiy 	TP_PROTO(struct pci_dev *pdev, unsigned long hpa, unsigned long ua,
677f928917SAlexey Kardashevskiy 			unsigned long size, int ret),
687f928917SAlexey Kardashevskiy 	TP_ARGS(pdev, hpa, ua, size, ret),
697f928917SAlexey Kardashevskiy 
707f928917SAlexey Kardashevskiy 	TP_STRUCT__entry(
717f928917SAlexey Kardashevskiy 		__field(const char *, name)
727f928917SAlexey Kardashevskiy 		__field(unsigned long, hpa)
737f928917SAlexey Kardashevskiy 		__field(unsigned long, ua)
747f928917SAlexey Kardashevskiy 		__field(unsigned long, size)
757f928917SAlexey Kardashevskiy 		__field(int, ret)
767f928917SAlexey Kardashevskiy 	),
777f928917SAlexey Kardashevskiy 
787f928917SAlexey Kardashevskiy 	TP_fast_assign(
797f928917SAlexey Kardashevskiy 		__entry->name = dev_name(&pdev->dev),
807f928917SAlexey Kardashevskiy 		__entry->hpa = hpa;
817f928917SAlexey Kardashevskiy 		__entry->ua = ua;
827f928917SAlexey Kardashevskiy 		__entry->size = size;
837f928917SAlexey Kardashevskiy 		__entry->ret = ret;
847f928917SAlexey Kardashevskiy 	),
857f928917SAlexey Kardashevskiy 
867f928917SAlexey Kardashevskiy 	TP_printk("%s: %lx -> %lx size=%lx ret=%d", __entry->name, __entry->hpa,
877f928917SAlexey Kardashevskiy 			__entry->ua, __entry->size, __entry->ret)
887f928917SAlexey Kardashevskiy );
897f928917SAlexey Kardashevskiy 
907f928917SAlexey Kardashevskiy #endif /* _TRACE_VFIO_PCI_H */
917f928917SAlexey Kardashevskiy 
927f928917SAlexey Kardashevskiy #undef TRACE_INCLUDE_PATH
93d1fc1176SMasahiro Yamada #define TRACE_INCLUDE_PATH ../../drivers/vfio/pci
947f928917SAlexey Kardashevskiy #undef TRACE_INCLUDE_FILE
957f928917SAlexey Kardashevskiy #define TRACE_INCLUDE_FILE trace
967f928917SAlexey Kardashevskiy 
977f928917SAlexey Kardashevskiy /* This part must be outside protection */
987f928917SAlexey Kardashevskiy #include <trace/define_trace.h>
99