mirror of
https://github.com/torvalds/linux.git
synced 2026-04-27 19:12:29 -04:00
clangd reports many "unused header" warnings throughout the Xe driver. Start working to clean this up by removing unnecessary includes in our .c files and/or replacing them with explicit includes of other headers that were previously being included indirectly. By far the most common offender here was unnecessary inclusion of xe_gt.h. That likely originates from the early days of xe.ko when xe_mmio did not exist and all register accesses, including those unrelated to GTs, were done with GT functions. There's still a lot of additional #include cleanup that can be done in the headers themselves; that will come as a followup series. v2: - Squash the 79-patch series down to a single patch. (MattB) Reviewed-by: Matthew Brost <matthew.brost@intel.com> Link: https://patch.msgid.link/20260115032803.4067824-2-matthew.d.roper@intel.com Signed-off-by: Matt Roper <matthew.d.roper@intel.com>
117 lines
4.3 KiB
C
117 lines
4.3 KiB
C
// SPDX-License-Identifier: MIT
|
|
/*
|
|
* Copyright © 2024 Intel Corporation
|
|
*/
|
|
|
|
#include <linux/atomic.h>
|
|
|
|
#include <drm/drm_print.h>
|
|
|
|
#include "xe_gt_stats.h"
|
|
#include "xe_gt_types.h"
|
|
|
|
/**
|
|
* xe_gt_stats_incr - Increments the specified stats counter
|
|
* @gt: GT structure
|
|
* @id: xe_gt_stats_id type id that needs to be incremented
|
|
* @incr: value to be incremented with
|
|
*
|
|
* Increments the specified stats counter.
|
|
*/
|
|
void xe_gt_stats_incr(struct xe_gt *gt, const enum xe_gt_stats_id id, int incr)
|
|
{
|
|
if (id >= __XE_GT_STATS_NUM_IDS)
|
|
return;
|
|
|
|
atomic64_add(incr, >->stats.counters[id]);
|
|
}
|
|
|
|
#define DEF_STAT_STR(ID, name) [XE_GT_STATS_ID_##ID] = name
|
|
|
|
static const char *const stat_description[__XE_GT_STATS_NUM_IDS] = {
|
|
DEF_STAT_STR(SVM_PAGEFAULT_COUNT, "svm_pagefault_count"),
|
|
DEF_STAT_STR(TLB_INVAL, "tlb_inval_count"),
|
|
DEF_STAT_STR(SVM_TLB_INVAL_COUNT, "svm_tlb_inval_count"),
|
|
DEF_STAT_STR(SVM_TLB_INVAL_US, "svm_tlb_inval_us"),
|
|
DEF_STAT_STR(VMA_PAGEFAULT_COUNT, "vma_pagefault_count"),
|
|
DEF_STAT_STR(VMA_PAGEFAULT_KB, "vma_pagefault_kb"),
|
|
DEF_STAT_STR(SVM_4K_PAGEFAULT_COUNT, "svm_4K_pagefault_count"),
|
|
DEF_STAT_STR(SVM_64K_PAGEFAULT_COUNT, "svm_64K_pagefault_count"),
|
|
DEF_STAT_STR(SVM_2M_PAGEFAULT_COUNT, "svm_2M_pagefault_count"),
|
|
DEF_STAT_STR(SVM_4K_VALID_PAGEFAULT_COUNT, "svm_4K_valid_pagefault_count"),
|
|
DEF_STAT_STR(SVM_64K_VALID_PAGEFAULT_COUNT, "svm_64K_valid_pagefault_count"),
|
|
DEF_STAT_STR(SVM_2M_VALID_PAGEFAULT_COUNT, "svm_2M_valid_pagefault_count"),
|
|
DEF_STAT_STR(SVM_4K_PAGEFAULT_US, "svm_4K_pagefault_us"),
|
|
DEF_STAT_STR(SVM_64K_PAGEFAULT_US, "svm_64K_pagefault_us"),
|
|
DEF_STAT_STR(SVM_2M_PAGEFAULT_US, "svm_2M_pagefault_us"),
|
|
DEF_STAT_STR(SVM_4K_MIGRATE_COUNT, "svm_4K_migrate_count"),
|
|
DEF_STAT_STR(SVM_64K_MIGRATE_COUNT, "svm_64K_migrate_count"),
|
|
DEF_STAT_STR(SVM_2M_MIGRATE_COUNT, "svm_2M_migrate_count"),
|
|
DEF_STAT_STR(SVM_4K_MIGRATE_US, "svm_4K_migrate_us"),
|
|
DEF_STAT_STR(SVM_64K_MIGRATE_US, "svm_64K_migrate_us"),
|
|
DEF_STAT_STR(SVM_2M_MIGRATE_US, "svm_2M_migrate_us"),
|
|
DEF_STAT_STR(SVM_DEVICE_COPY_US, "svm_device_copy_us"),
|
|
DEF_STAT_STR(SVM_4K_DEVICE_COPY_US, "svm_4K_device_copy_us"),
|
|
DEF_STAT_STR(SVM_64K_DEVICE_COPY_US, "svm_64K_device_copy_us"),
|
|
DEF_STAT_STR(SVM_2M_DEVICE_COPY_US, "svm_2M_device_copy_us"),
|
|
DEF_STAT_STR(SVM_CPU_COPY_US, "svm_cpu_copy_us"),
|
|
DEF_STAT_STR(SVM_4K_CPU_COPY_US, "svm_4K_cpu_copy_us"),
|
|
DEF_STAT_STR(SVM_64K_CPU_COPY_US, "svm_64K_cpu_copy_us"),
|
|
DEF_STAT_STR(SVM_2M_CPU_COPY_US, "svm_2M_cpu_copy_us"),
|
|
DEF_STAT_STR(SVM_DEVICE_COPY_KB, "svm_device_copy_kb"),
|
|
DEF_STAT_STR(SVM_CPU_COPY_KB, "svm_cpu_copy_kb"),
|
|
DEF_STAT_STR(SVM_4K_GET_PAGES_US, "svm_4K_get_pages_us"),
|
|
DEF_STAT_STR(SVM_64K_GET_PAGES_US, "svm_64K_get_pages_us"),
|
|
DEF_STAT_STR(SVM_2M_GET_PAGES_US, "svm_2M_get_pages_us"),
|
|
DEF_STAT_STR(SVM_4K_BIND_US, "svm_4K_bind_us"),
|
|
DEF_STAT_STR(SVM_64K_BIND_US, "svm_64K_bind_us"),
|
|
DEF_STAT_STR(SVM_2M_BIND_US, "svm_2M_bind_us"),
|
|
DEF_STAT_STR(HW_ENGINE_GROUP_SUSPEND_LR_QUEUE_COUNT,
|
|
"hw_engine_group_suspend_lr_queue_count"),
|
|
DEF_STAT_STR(HW_ENGINE_GROUP_SKIP_LR_QUEUE_COUNT,
|
|
"hw_engine_group_skip_lr_queue_count"),
|
|
DEF_STAT_STR(HW_ENGINE_GROUP_WAIT_DMA_QUEUE_COUNT,
|
|
"hw_engine_group_wait_dma_queue_count"),
|
|
DEF_STAT_STR(HW_ENGINE_GROUP_SUSPEND_LR_QUEUE_US,
|
|
"hw_engine_group_suspend_lr_queue_us"),
|
|
DEF_STAT_STR(HW_ENGINE_GROUP_WAIT_DMA_QUEUE_US,
|
|
"hw_engine_group_wait_dma_queue_us"),
|
|
DEF_STAT_STR(PRL_4K_ENTRY_COUNT, "prl_4k_entry_count"),
|
|
DEF_STAT_STR(PRL_64K_ENTRY_COUNT, "prl_64k_entry_count"),
|
|
DEF_STAT_STR(PRL_2M_ENTRY_COUNT, "prl_2m_entry_count"),
|
|
DEF_STAT_STR(PRL_ISSUED_COUNT, "prl_issued_count"),
|
|
DEF_STAT_STR(PRL_ABORTED_COUNT, "prl_aborted_count"),
|
|
};
|
|
|
|
/**
|
|
* xe_gt_stats_print_info - Print the GT stats
|
|
* @gt: GT structure
|
|
* @p: drm_printer where it will be printed out.
|
|
*
|
|
* This prints out all the available GT stats.
|
|
*/
|
|
int xe_gt_stats_print_info(struct xe_gt *gt, struct drm_printer *p)
|
|
{
|
|
enum xe_gt_stats_id id;
|
|
|
|
for (id = 0; id < __XE_GT_STATS_NUM_IDS; ++id)
|
|
drm_printf(p, "%s: %lld\n", stat_description[id],
|
|
atomic64_read(>->stats.counters[id]));
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**
|
|
* xe_gt_stats_clear - Clear the GT stats
|
|
* @gt: GT structure
|
|
*
|
|
* This clear (zeros) all the available GT stats.
|
|
*/
|
|
void xe_gt_stats_clear(struct xe_gt *gt)
|
|
{
|
|
int id;
|
|
|
|
for (id = 0; id < ARRAY_SIZE(gt->stats.counters); ++id)
|
|
atomic64_set(>->stats.counters[id], 0);
|
|
}
|