149 lines
3.8 KiB
C
149 lines
3.8 KiB
C
|
// SPDX-License-Identifier: MIT
|
||
|
/*
|
||
|
* Copyright © 2020 Intel Corporation
|
||
|
*/
|
||
|
|
||
|
#include <drm/drm_print.h>
|
||
|
|
||
|
#include "gt/intel_gt_debugfs.h"
|
||
|
#include "gt/uc/intel_guc_ads.h"
|
||
|
#include "gt/uc/intel_guc_ct.h"
|
||
|
#include "gt/uc/intel_guc_slpc.h"
|
||
|
#include "gt/uc/intel_guc_submission.h"
|
||
|
#include "intel_guc.h"
|
||
|
#include "intel_guc_debugfs.h"
|
||
|
#include "intel_guc_log_debugfs.h"
|
||
|
|
||
|
static int guc_info_show(struct seq_file *m, void *data)
|
||
|
{
|
||
|
struct intel_guc *guc = m->private;
|
||
|
struct drm_printer p = drm_seq_file_printer(m);
|
||
|
|
||
|
if (!intel_guc_is_supported(guc))
|
||
|
return -ENODEV;
|
||
|
|
||
|
intel_guc_load_status(guc, &p);
|
||
|
drm_puts(&p, "\n");
|
||
|
intel_guc_log_info(&guc->log, &p);
|
||
|
|
||
|
if (!intel_guc_submission_is_used(guc))
|
||
|
return 0;
|
||
|
|
||
|
intel_guc_ct_print_info(&guc->ct, &p);
|
||
|
intel_guc_submission_print_info(guc, &p);
|
||
|
intel_guc_ads_print_policy_info(guc, &p);
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(guc_info);
|
||
|
|
||
|
static int guc_registered_contexts_show(struct seq_file *m, void *data)
|
||
|
{
|
||
|
struct intel_guc *guc = m->private;
|
||
|
struct drm_printer p = drm_seq_file_printer(m);
|
||
|
|
||
|
if (!intel_guc_submission_is_used(guc))
|
||
|
return -ENODEV;
|
||
|
|
||
|
intel_guc_submission_print_context_info(guc, &p);
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(guc_registered_contexts);
|
||
|
|
||
|
static int guc_slpc_info_show(struct seq_file *m, void *unused)
|
||
|
{
|
||
|
struct intel_guc *guc = m->private;
|
||
|
struct intel_guc_slpc *slpc = &guc->slpc;
|
||
|
struct drm_printer p = drm_seq_file_printer(m);
|
||
|
|
||
|
if (!intel_guc_slpc_is_used(guc))
|
||
|
return -ENODEV;
|
||
|
|
||
|
return intel_guc_slpc_print_info(slpc, &p);
|
||
|
}
|
||
|
DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(guc_slpc_info);
|
||
|
|
||
|
static bool intel_eval_slpc_support(void *data)
|
||
|
{
|
||
|
struct intel_guc *guc = (struct intel_guc *)data;
|
||
|
|
||
|
return intel_guc_slpc_is_used(guc);
|
||
|
}
|
||
|
|
||
|
static int guc_sched_disable_delay_ms_get(void *data, u64 *val)
|
||
|
{
|
||
|
struct intel_guc *guc = data;
|
||
|
|
||
|
if (!intel_guc_submission_is_used(guc))
|
||
|
return -ENODEV;
|
||
|
|
||
|
*val = (u64)guc->submission_state.sched_disable_delay_ms;
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
static int guc_sched_disable_delay_ms_set(void *data, u64 val)
|
||
|
{
|
||
|
struct intel_guc *guc = data;
|
||
|
|
||
|
if (!intel_guc_submission_is_used(guc))
|
||
|
return -ENODEV;
|
||
|
|
||
|
/* clamp to a practical limit, 1 minute is reasonable for a longest delay */
|
||
|
guc->submission_state.sched_disable_delay_ms = min_t(u64, val, 60000);
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
DEFINE_SIMPLE_ATTRIBUTE(guc_sched_disable_delay_ms_fops,
|
||
|
guc_sched_disable_delay_ms_get,
|
||
|
guc_sched_disable_delay_ms_set, "%lld\n");
|
||
|
|
||
|
static int guc_sched_disable_gucid_threshold_get(void *data, u64 *val)
|
||
|
{
|
||
|
struct intel_guc *guc = data;
|
||
|
|
||
|
if (!intel_guc_submission_is_used(guc))
|
||
|
return -ENODEV;
|
||
|
|
||
|
*val = guc->submission_state.sched_disable_gucid_threshold;
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
static int guc_sched_disable_gucid_threshold_set(void *data, u64 val)
|
||
|
{
|
||
|
struct intel_guc *guc = data;
|
||
|
|
||
|
if (!intel_guc_submission_is_used(guc))
|
||
|
return -ENODEV;
|
||
|
|
||
|
if (val > intel_guc_sched_disable_gucid_threshold_max(guc))
|
||
|
guc->submission_state.sched_disable_gucid_threshold =
|
||
|
intel_guc_sched_disable_gucid_threshold_max(guc);
|
||
|
else
|
||
|
guc->submission_state.sched_disable_gucid_threshold = val;
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
DEFINE_SIMPLE_ATTRIBUTE(guc_sched_disable_gucid_threshold_fops,
|
||
|
guc_sched_disable_gucid_threshold_get,
|
||
|
guc_sched_disable_gucid_threshold_set, "%lld\n");
|
||
|
|
||
|
void intel_guc_debugfs_register(struct intel_guc *guc, struct dentry *root)
|
||
|
{
|
||
|
static const struct intel_gt_debugfs_file files[] = {
|
||
|
{ "guc_info", &guc_info_fops, NULL },
|
||
|
{ "guc_registered_contexts", &guc_registered_contexts_fops, NULL },
|
||
|
{ "guc_slpc_info", &guc_slpc_info_fops, &intel_eval_slpc_support},
|
||
|
{ "guc_sched_disable_delay_ms", &guc_sched_disable_delay_ms_fops, NULL },
|
||
|
{ "guc_sched_disable_gucid_threshold", &guc_sched_disable_gucid_threshold_fops,
|
||
|
NULL },
|
||
|
};
|
||
|
|
||
|
if (!intel_guc_is_supported(guc))
|
||
|
return;
|
||
|
|
||
|
intel_gt_debugfs_register_files(root, files, ARRAY_SIZE(files), guc);
|
||
|
intel_guc_log_debugfs_register(&guc->log, root);
|
||
|
}
|