// SPDX-License-Identifier: MIT /* * Copyright © 2020 Intel Corporation */ #include #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); }