1*33e5ee78SThomas 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