Linux Audio

Check our new training course

Loading...
  1// SPDX-License-Identifier: MIT
  2/*
  3 * Copyright © 2020 Intel Corporation
  4 */
  5
  6#include <drm/drm_print.h>
  7
  8#include "gt/intel_gt_debugfs.h"
  9#include "gt/uc/intel_guc_ads.h"
 10#include "gt/uc/intel_guc_ct.h"
 11#include "gt/uc/intel_guc_slpc.h"
 12#include "gt/uc/intel_guc_submission.h"
 13#include "intel_guc.h"
 14#include "intel_guc_debugfs.h"
 15#include "intel_guc_log_debugfs.h"
 16
 17static int guc_info_show(struct seq_file *m, void *data)
 18{
 19	struct intel_guc *guc = m->private;
 20	struct drm_printer p = drm_seq_file_printer(m);
 21
 22	if (!intel_guc_is_supported(guc))
 23		return -ENODEV;
 24
 25	intel_guc_load_status(guc, &p);
 26	drm_puts(&p, "\n");
 27	intel_guc_log_info(&guc->log, &p);
 28
 29	if (!intel_guc_submission_is_used(guc))
 30		return 0;
 31
 32	intel_guc_ct_print_info(&guc->ct, &p);
 33	intel_guc_submission_print_info(guc, &p);
 34	intel_guc_ads_print_policy_info(guc, &p);
 35
 36	return 0;
 37}
 38DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(guc_info);
 39
 40static int guc_registered_contexts_show(struct seq_file *m, void *data)
 41{
 42	struct intel_guc *guc = m->private;
 43	struct drm_printer p = drm_seq_file_printer(m);
 44
 45	if (!intel_guc_submission_is_used(guc))
 46		return -ENODEV;
 47
 48	intel_guc_submission_print_context_info(guc, &p);
 49
 50	return 0;
 51}
 52DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(guc_registered_contexts);
 53
 54static int guc_slpc_info_show(struct seq_file *m, void *unused)
 55{
 56	struct intel_guc *guc = m->private;
 57	struct intel_guc_slpc *slpc = &guc->slpc;
 58	struct drm_printer p = drm_seq_file_printer(m);
 59
 60	if (!intel_guc_slpc_is_used(guc))
 61		return -ENODEV;
 62
 63	return intel_guc_slpc_print_info(slpc, &p);
 64}
 65DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(guc_slpc_info);
 66
 67static bool intel_eval_slpc_support(void *data)
 68{
 69	struct intel_guc *guc = (struct intel_guc *)data;
 70
 71	return intel_guc_slpc_is_used(guc);
 72}
 73
 74static int guc_sched_disable_delay_ms_get(void *data, u64 *val)
 75{
 76	struct intel_guc *guc = data;
 77
 78	if (!intel_guc_submission_is_used(guc))
 79		return -ENODEV;
 80
 81	*val = (u64)guc->submission_state.sched_disable_delay_ms;
 82
 83	return 0;
 84}
 85
 86static int guc_sched_disable_delay_ms_set(void *data, u64 val)
 87{
 88	struct intel_guc *guc = data;
 89
 90	if (!intel_guc_submission_is_used(guc))
 91		return -ENODEV;
 92
 93	/* clamp to a practical limit, 1 minute is reasonable for a longest delay */
 94	guc->submission_state.sched_disable_delay_ms = min_t(u64, val, 60000);
 95
 96	return 0;
 97}
 98DEFINE_SIMPLE_ATTRIBUTE(guc_sched_disable_delay_ms_fops,
 99			guc_sched_disable_delay_ms_get,
100			guc_sched_disable_delay_ms_set, "%lld\n");
101
102static int guc_sched_disable_gucid_threshold_get(void *data, u64 *val)
103{
104	struct intel_guc *guc = data;
105
106	if (!intel_guc_submission_is_used(guc))
107		return -ENODEV;
108
109	*val = guc->submission_state.sched_disable_gucid_threshold;
110	return 0;
111}
112
113static int guc_sched_disable_gucid_threshold_set(void *data, u64 val)
114{
115	struct intel_guc *guc = data;
116
117	if (!intel_guc_submission_is_used(guc))
118		return -ENODEV;
119
120	if (val > intel_guc_sched_disable_gucid_threshold_max(guc))
121		guc->submission_state.sched_disable_gucid_threshold =
122			intel_guc_sched_disable_gucid_threshold_max(guc);
123	else
124		guc->submission_state.sched_disable_gucid_threshold = val;
125
126	return 0;
127}
128DEFINE_SIMPLE_ATTRIBUTE(guc_sched_disable_gucid_threshold_fops,
129			guc_sched_disable_gucid_threshold_get,
130			guc_sched_disable_gucid_threshold_set, "%lld\n");
131
132void intel_guc_debugfs_register(struct intel_guc *guc, struct dentry *root)
133{
134	static const struct intel_gt_debugfs_file files[] = {
135		{ "guc_info", &guc_info_fops, NULL },
136		{ "guc_registered_contexts", &guc_registered_contexts_fops, NULL },
137		{ "guc_slpc_info", &guc_slpc_info_fops, &intel_eval_slpc_support},
138		{ "guc_sched_disable_delay_ms", &guc_sched_disable_delay_ms_fops, NULL },
139		{ "guc_sched_disable_gucid_threshold", &guc_sched_disable_gucid_threshold_fops,
140		   NULL },
141	};
142
143	if (!intel_guc_is_supported(guc))
144		return;
145
146	intel_gt_debugfs_register_files(root, files, ARRAY_SIZE(files), guc);
147	intel_guc_log_debugfs_register(&guc->log, root);
148}