]> Git Repo - linux.git/blob - drivers/gpu/drm/i915/gt/uc/intel_guc_debugfs.c
Merge tag 'amd-drm-next-6.5-2023-06-09' of https://gitlab.freedesktop.org/agd5f/linux...
[linux.git] / drivers / gpu / drm / i915 / gt / uc / intel_guc_debugfs.c
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
17 static 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 }
38 DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(guc_info);
39
40 static 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 }
52 DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(guc_registered_contexts);
53
54 static 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 }
65 DEFINE_INTEL_GT_DEBUGFS_ATTRIBUTE(guc_slpc_info);
66
67 static 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
74 static 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
86 static 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 }
98 DEFINE_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
102 static 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
113 static 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 }
128 DEFINE_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
132 void 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 }
This page took 0.044248 seconds and 4 git commands to generate.