1// SPDX-License-Identifier: MIT
2/*
3 * Copyright �� 2022 Intel Corporation
4 */
5
6#include "xe_gt_sysfs.h"
7
8#include <linux/kobject.h>
9#include <linux/sysfs.h>
10
11#include <drm/drm_managed.h>
12
13#include "xe_gt.h"
14
15static void xe_gt_sysfs_kobj_release(struct kobject *kobj)
16{
17	kfree(kobj);
18}
19
20static const struct kobj_type xe_gt_sysfs_kobj_type = {
21	.release = xe_gt_sysfs_kobj_release,
22	.sysfs_ops = &kobj_sysfs_ops,
23};
24
25static void gt_sysfs_fini(struct drm_device *drm, void *arg)
26{
27	struct xe_gt *gt = arg;
28
29	kobject_put(gt->sysfs);
30}
31
32void xe_gt_sysfs_init(struct xe_gt *gt)
33{
34	struct xe_tile *tile = gt_to_tile(gt);
35	struct xe_device *xe = gt_to_xe(gt);
36	struct kobj_gt *kg;
37	int err;
38
39	kg = kzalloc(sizeof(*kg), GFP_KERNEL);
40	if (!kg)
41		return;
42
43	kobject_init(&kg->base, &xe_gt_sysfs_kobj_type);
44	kg->gt = gt;
45
46	err = kobject_add(&kg->base, tile->sysfs, "gt%d", gt->info.id);
47	if (err) {
48		drm_warn(&xe->drm, "failed to add GT sysfs directory, err: %d\n", err);
49		kobject_put(&kg->base);
50		return;
51	}
52
53	gt->sysfs = &kg->base;
54
55	err = drmm_add_action_or_reset(&xe->drm, gt_sysfs_fini, gt);
56	if (err) {
57		drm_warn(&xe->drm, "%s: drmm_add_action_or_reset failed, err: %d\n",
58			 __func__, err);
59		return;
60	}
61}
62