[PATCH] drm/amdgpu: add pci BDF info in trace amdgpu_device_r[w]reg()
Kevin Wang
kevin1.wang at amd.com
Mon Mar 1 10:05:42 UTC 2021
add pci BDF info in amdgpu_device_r[w]reg trace event to support
muti-device in one host.
Signed-off-by: Kevin Wang <kevin1.wang at amd.com>
---
drivers/gpu/drm/amd/amdgpu/amdgpu_device.c | 4 +-
drivers/gpu/drm/amd/amdgpu/amdgpu_trace.h | 53 +++++++++++++---------
2 files changed, 33 insertions(+), 24 deletions(-)
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
index 71805dfd9e25..8819672d3ecb 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
@@ -355,7 +355,7 @@ uint32_t amdgpu_device_rreg(struct amdgpu_device *adev,
ret = adev->pcie_rreg(adev, reg * 4);
}
- trace_amdgpu_device_rreg(adev->pdev->device, reg, ret);
+ trace_amdgpu_device_rreg(adev->pdev, reg, ret);
return ret;
}
@@ -440,7 +440,7 @@ void amdgpu_device_wreg(struct amdgpu_device *adev,
adev->pcie_wreg(adev, reg * 4, v);
}
- trace_amdgpu_device_wreg(adev->pdev->device, reg, v);
+ trace_amdgpu_device_wreg(adev->pdev, reg, v);
}
/*
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_trace.h b/drivers/gpu/drm/amd/amdgpu/amdgpu_trace.h
index ce8dc995c10c..1fa774fb805e 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_trace.h
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_trace.h
@@ -35,42 +35,51 @@
#define AMDGPU_JOB_GET_TIMELINE_NAME(job) \
job->base.s_fence->finished.ops->get_timeline_name(&job->base.s_fence->finished)
+
TRACE_EVENT(amdgpu_device_rreg,
- TP_PROTO(unsigned did, uint32_t reg, uint32_t value),
- TP_ARGS(did, reg, value),
+ TP_PROTO(struct pci_dev *pdev, uint32_t reg, uint32_t value),
+ TP_ARGS(pdev, reg, value),
TP_STRUCT__entry(
- __field(unsigned, did)
- __field(uint32_t, reg)
- __field(uint32_t, value)
+ __field(uint16_t, device)
+ __field(uint8_t, bus)
+ __field(uint8_t, devfn)
+ __field(uint32_t, reg)
+ __field(uint32_t, value)
),
TP_fast_assign(
- __entry->did = did;
+ __entry->device = pdev->device;
+ __entry->bus = pdev->bus->number;
+ __entry->devfn = pdev->devfn;
__entry->reg = reg;
__entry->value = value;
- ),
- TP_printk("0x%04lx, 0x%08lx, 0x%08lx",
- (unsigned long)__entry->did,
- (unsigned long)__entry->reg,
- (unsigned long)__entry->value)
+ ),
+ TP_printk("%04x %02x:%02x.%1x: 0x%08x, 0x%08x",
+ __entry->device,
+ __entry->bus, __entry->devfn >> 3, __entry->devfn & 0x7,
+ __entry->reg, __entry->value)
);
TRACE_EVENT(amdgpu_device_wreg,
- TP_PROTO(unsigned did, uint32_t reg, uint32_t value),
- TP_ARGS(did, reg, value),
+ TP_PROTO(struct pci_dev *pdev, uint32_t reg, uint32_t value),
+ TP_ARGS(pdev, reg, value),
TP_STRUCT__entry(
- __field(unsigned, did)
- __field(uint32_t, reg)
- __field(uint32_t, value)
+ __field(uint16_t, device)
+ __field(uint8_t, bus)
+ __field(uint8_t, devfn)
+ __field(uint32_t, reg)
+ __field(uint32_t, value)
),
TP_fast_assign(
- __entry->did = did;
+ __entry->device = pdev->device;
+ __entry->bus = pdev->bus->number;
+ __entry->devfn = pdev->devfn;
__entry->reg = reg;
__entry->value = value;
- ),
- TP_printk("0x%04lx, 0x%08lx, 0x%08lx",
- (unsigned long)__entry->did,
- (unsigned long)__entry->reg,
- (unsigned long)__entry->value)
+ ),
+ TP_printk("%04x %02x:%02x.%1x: 0x%08x, 0x%08x",
+ __entry->device,
+ __entry->bus, __entry->devfn >> 3, __entry->devfn & 0x7,
+ __entry->reg, __entry->value)
);
TRACE_EVENT(amdgpu_iv,
--
2.17.1
More information about the amd-gfx
mailing list