xref: /openbsd-src/sys/dev/pci/drm/i915/gt/intel_gt_sysfs.c (revision f005ef32267c16bdb134f0e9fa4477dbe07c263a)
11bb76ff1Sjsg // SPDX-License-Identifier: MIT
21bb76ff1Sjsg /*
31bb76ff1Sjsg  * Copyright © 2022 Intel Corporation
41bb76ff1Sjsg  */
51bb76ff1Sjsg 
61bb76ff1Sjsg #include <drm/drm_device.h>
71bb76ff1Sjsg #include <linux/device.h>
81bb76ff1Sjsg #include <linux/kobject.h>
91bb76ff1Sjsg #include <linux/printk.h>
101bb76ff1Sjsg #include <linux/sysfs.h>
111bb76ff1Sjsg 
121bb76ff1Sjsg #include "i915_drv.h"
131bb76ff1Sjsg #include "i915_sysfs.h"
141bb76ff1Sjsg #include "intel_gt.h"
15*f005ef32Sjsg #include "intel_gt_print.h"
161bb76ff1Sjsg #include "intel_gt_sysfs.h"
171bb76ff1Sjsg #include "intel_gt_sysfs_pm.h"
181bb76ff1Sjsg #include "intel_gt_types.h"
191bb76ff1Sjsg #include "intel_rc6.h"
201bb76ff1Sjsg 
211bb76ff1Sjsg #ifdef notyet
221bb76ff1Sjsg 
is_object_gt(struct kobject * kobj)231bb76ff1Sjsg bool is_object_gt(struct kobject *kobj)
241bb76ff1Sjsg {
251bb76ff1Sjsg 	return !strncmp(kobj->name, "gt", 2);
261bb76ff1Sjsg }
271bb76ff1Sjsg 
intel_gt_sysfs_get_drvdata(struct kobject * kobj,const char * name)28850b1841Sjsg struct intel_gt *intel_gt_sysfs_get_drvdata(struct kobject *kobj,
291bb76ff1Sjsg 					    const char *name)
301bb76ff1Sjsg {
311bb76ff1Sjsg 	/*
321bb76ff1Sjsg 	 * We are interested at knowing from where the interface
331bb76ff1Sjsg 	 * has been called, whether it's called from gt/ or from
341bb76ff1Sjsg 	 * the parent directory.
351bb76ff1Sjsg 	 * From the interface position it depends also the value of
361bb76ff1Sjsg 	 * the private data.
371bb76ff1Sjsg 	 * If the interface is called from gt/ then private data is
381bb76ff1Sjsg 	 * of the "struct intel_gt *" type, otherwise it's * a
391bb76ff1Sjsg 	 * "struct drm_i915_private *" type.
401bb76ff1Sjsg 	 */
411bb76ff1Sjsg 	if (!is_object_gt(kobj)) {
42850b1841Sjsg 		struct device *dev = kobj_to_dev(kobj);
431bb76ff1Sjsg 		struct drm_i915_private *i915 = kdev_minor_to_i915(dev);
441bb76ff1Sjsg 
451bb76ff1Sjsg 		return to_gt(i915);
461bb76ff1Sjsg 	}
471bb76ff1Sjsg 
481bb76ff1Sjsg 	return kobj_to_gt(kobj);
491bb76ff1Sjsg }
501bb76ff1Sjsg 
gt_get_parent_obj(struct intel_gt * gt)511bb76ff1Sjsg static struct kobject *gt_get_parent_obj(struct intel_gt *gt)
521bb76ff1Sjsg {
531bb76ff1Sjsg 	return &gt->i915->drm.primary->kdev->kobj;
541bb76ff1Sjsg }
551bb76ff1Sjsg 
id_show(struct kobject * kobj,struct kobj_attribute * attr,char * buf)56850b1841Sjsg static ssize_t id_show(struct kobject *kobj,
57850b1841Sjsg 		       struct kobj_attribute *attr,
581bb76ff1Sjsg 		       char *buf)
591bb76ff1Sjsg {
60850b1841Sjsg 	struct intel_gt *gt = intel_gt_sysfs_get_drvdata(kobj, attr->attr.name);
611bb76ff1Sjsg 
621bb76ff1Sjsg 	return sysfs_emit(buf, "%u\n", gt->info.id);
631bb76ff1Sjsg }
64850b1841Sjsg static struct kobj_attribute attr_id = __ATTR_RO(id);
651bb76ff1Sjsg 
661bb76ff1Sjsg static struct attribute *id_attrs[] = {
67850b1841Sjsg 	&attr_id.attr,
681bb76ff1Sjsg 	NULL,
691bb76ff1Sjsg };
701bb76ff1Sjsg ATTRIBUTE_GROUPS(id);
711bb76ff1Sjsg 
721bb76ff1Sjsg /* A kobject needs a release() method even if it does nothing */
kobj_gt_release(struct kobject * kobj)731bb76ff1Sjsg static void kobj_gt_release(struct kobject *kobj)
741bb76ff1Sjsg {
751bb76ff1Sjsg }
761bb76ff1Sjsg 
77*f005ef32Sjsg static const struct kobj_type kobj_gt_type = {
781bb76ff1Sjsg 	.release = kobj_gt_release,
791bb76ff1Sjsg 	.sysfs_ops = &kobj_sysfs_ops,
801bb76ff1Sjsg 	.default_groups = id_groups,
811bb76ff1Sjsg };
821bb76ff1Sjsg 
831bb76ff1Sjsg #endif /* notyet */
841bb76ff1Sjsg 
intel_gt_sysfs_register(struct intel_gt * gt)851bb76ff1Sjsg void intel_gt_sysfs_register(struct intel_gt *gt)
861bb76ff1Sjsg {
871bb76ff1Sjsg #ifdef notyet
881bb76ff1Sjsg 	/*
891bb76ff1Sjsg 	 * We need to make things right with the
901bb76ff1Sjsg 	 * ABI compatibility. The files were originally
911bb76ff1Sjsg 	 * generated under the parent directory.
921bb76ff1Sjsg 	 *
931bb76ff1Sjsg 	 * We generate the files only for gt 0
941bb76ff1Sjsg 	 * to avoid duplicates.
951bb76ff1Sjsg 	 */
961bb76ff1Sjsg 	if (gt_is_root(gt))
971bb76ff1Sjsg 		intel_gt_sysfs_pm_init(gt, gt_get_parent_obj(gt));
981bb76ff1Sjsg 
991bb76ff1Sjsg 	/* init and xfer ownership to sysfs tree */
1001bb76ff1Sjsg 	if (kobject_init_and_add(&gt->sysfs_gt, &kobj_gt_type,
1011bb76ff1Sjsg 				 gt->i915->sysfs_gt, "gt%d", gt->info.id))
1021bb76ff1Sjsg 		goto exit_fail;
1031bb76ff1Sjsg 
1041bb76ff1Sjsg 	gt->sysfs_defaults = kobject_create_and_add(".defaults", &gt->sysfs_gt);
1051bb76ff1Sjsg 	if (!gt->sysfs_defaults)
1061bb76ff1Sjsg 		goto exit_fail;
1071bb76ff1Sjsg 
1081bb76ff1Sjsg 	intel_gt_sysfs_pm_init(gt, &gt->sysfs_gt);
1091bb76ff1Sjsg 
1101bb76ff1Sjsg 	return;
1111bb76ff1Sjsg 
1121bb76ff1Sjsg exit_fail:
1131bb76ff1Sjsg 	kobject_put(&gt->sysfs_gt);
114*f005ef32Sjsg 	gt_warn(gt, "failed to initialize sysfs root\n");
1151bb76ff1Sjsg #endif
1161bb76ff1Sjsg }
1171bb76ff1Sjsg 
intel_gt_sysfs_unregister(struct intel_gt * gt)1181bb76ff1Sjsg void intel_gt_sysfs_unregister(struct intel_gt *gt)
1191bb76ff1Sjsg {
1201bb76ff1Sjsg #ifdef notyet
1211bb76ff1Sjsg 	kobject_put(gt->sysfs_defaults);
1221bb76ff1Sjsg 	kobject_put(&gt->sysfs_gt);
1231bb76ff1Sjsg #endif
1241bb76ff1Sjsg }
125