xref: /linux/drivers/gpu/drm/drm_ras_nl.c (revision a3e50e7279996cd987001fd8a3db36e72665f8f7)
1 // SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) OR BSD-3-Clause)
2 /* Do not edit directly, auto-generated from: */
3 /*	Documentation/netlink/specs/drm_ras.yaml */
4 /* YNL-GEN kernel source */
5 /* To regenerate run: tools/net/ynl/ynl-regen.sh */
6 
7 #include <net/netlink.h>
8 #include <net/genetlink.h>
9 
10 #include "drm_ras_nl.h"
11 
12 #include <uapi/drm/drm_ras.h>
13 
14 /* DRM_RAS_CMD_GET_ERROR_COUNTER - do */
15 static const struct nla_policy drm_ras_get_error_counter_do_nl_policy[DRM_RAS_A_ERROR_COUNTER_ATTRS_ERROR_ID + 1] = {
16 	[DRM_RAS_A_ERROR_COUNTER_ATTRS_NODE_ID] = { .type = NLA_U32, },
17 	[DRM_RAS_A_ERROR_COUNTER_ATTRS_ERROR_ID] = { .type = NLA_U32, },
18 };
19 
20 /* DRM_RAS_CMD_GET_ERROR_COUNTER - dump */
21 static const struct nla_policy drm_ras_get_error_counter_dump_nl_policy[DRM_RAS_A_ERROR_COUNTER_ATTRS_NODE_ID + 1] = {
22 	[DRM_RAS_A_ERROR_COUNTER_ATTRS_NODE_ID] = { .type = NLA_U32, },
23 };
24 
25 /* DRM_RAS_CMD_CLEAR_ERROR_COUNTER - do */
26 static const struct nla_policy drm_ras_clear_error_counter_nl_policy[DRM_RAS_A_ERROR_COUNTER_ATTRS_ERROR_ID + 1] = {
27 	[DRM_RAS_A_ERROR_COUNTER_ATTRS_NODE_ID] = { .type = NLA_U32, },
28 	[DRM_RAS_A_ERROR_COUNTER_ATTRS_ERROR_ID] = { .type = NLA_U32, },
29 };
30 
31 /* Ops table for drm_ras */
32 static const struct genl_split_ops drm_ras_nl_ops[] = {
33 	{
34 		.cmd	= DRM_RAS_CMD_LIST_NODES,
35 		.dumpit	= drm_ras_nl_list_nodes_dumpit,
36 		.flags	= GENL_ADMIN_PERM | GENL_CMD_CAP_DUMP,
37 	},
38 	{
39 		.cmd		= DRM_RAS_CMD_GET_ERROR_COUNTER,
40 		.doit		= drm_ras_nl_get_error_counter_doit,
41 		.policy		= drm_ras_get_error_counter_do_nl_policy,
42 		.maxattr	= DRM_RAS_A_ERROR_COUNTER_ATTRS_ERROR_ID,
43 		.flags		= GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
44 	},
45 	{
46 		.cmd		= DRM_RAS_CMD_GET_ERROR_COUNTER,
47 		.dumpit		= drm_ras_nl_get_error_counter_dumpit,
48 		.policy		= drm_ras_get_error_counter_dump_nl_policy,
49 		.maxattr	= DRM_RAS_A_ERROR_COUNTER_ATTRS_NODE_ID,
50 		.flags		= GENL_ADMIN_PERM | GENL_CMD_CAP_DUMP,
51 	},
52 	{
53 		.cmd		= DRM_RAS_CMD_CLEAR_ERROR_COUNTER,
54 		.doit		= drm_ras_nl_clear_error_counter_doit,
55 		.policy		= drm_ras_clear_error_counter_nl_policy,
56 		.maxattr	= DRM_RAS_A_ERROR_COUNTER_ATTRS_ERROR_ID,
57 		.flags		= GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
58 	},
59 };
60 
61 struct genl_family drm_ras_nl_family __ro_after_init = {
62 	.name		= DRM_RAS_FAMILY_NAME,
63 	.version	= DRM_RAS_FAMILY_VERSION,
64 	.netnsok	= true,
65 	.parallel_ops	= true,
66 	.module		= THIS_MODULE,
67 	.split_ops	= drm_ras_nl_ops,
68 	.n_split_ops	= ARRAY_SIZE(drm_ras_nl_ops),
69 };
70