Linux kernel mirror (for testing)
git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel
os
linux
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/net_shaper.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 "shaper_nl_gen.h"
11
12#include <uapi/linux/net_shaper.h>
13
14/* Common nested types */
15const struct nla_policy net_shaper_handle_nl_policy[NET_SHAPER_A_HANDLE_ID + 1] = {
16 [NET_SHAPER_A_HANDLE_SCOPE] = NLA_POLICY_MAX(NLA_U32, 3),
17 [NET_SHAPER_A_HANDLE_ID] = { .type = NLA_U32, },
18};
19
20const struct nla_policy net_shaper_leaf_info_nl_policy[NET_SHAPER_A_WEIGHT + 1] = {
21 [NET_SHAPER_A_HANDLE] = NLA_POLICY_NESTED(net_shaper_handle_nl_policy),
22 [NET_SHAPER_A_PRIORITY] = { .type = NLA_U32, },
23 [NET_SHAPER_A_WEIGHT] = { .type = NLA_U32, },
24};
25
26/* NET_SHAPER_CMD_GET - do */
27static const struct nla_policy net_shaper_get_do_nl_policy[NET_SHAPER_A_IFINDEX + 1] = {
28 [NET_SHAPER_A_IFINDEX] = { .type = NLA_U32, },
29 [NET_SHAPER_A_HANDLE] = NLA_POLICY_NESTED(net_shaper_handle_nl_policy),
30};
31
32/* NET_SHAPER_CMD_GET - dump */
33static const struct nla_policy net_shaper_get_dump_nl_policy[NET_SHAPER_A_IFINDEX + 1] = {
34 [NET_SHAPER_A_IFINDEX] = { .type = NLA_U32, },
35};
36
37/* NET_SHAPER_CMD_SET - do */
38static const struct nla_policy net_shaper_set_nl_policy[NET_SHAPER_A_IFINDEX + 1] = {
39 [NET_SHAPER_A_IFINDEX] = { .type = NLA_U32, },
40 [NET_SHAPER_A_HANDLE] = NLA_POLICY_NESTED(net_shaper_handle_nl_policy),
41 [NET_SHAPER_A_METRIC] = NLA_POLICY_MAX(NLA_U32, 1),
42 [NET_SHAPER_A_BW_MIN] = { .type = NLA_UINT, },
43 [NET_SHAPER_A_BW_MAX] = { .type = NLA_UINT, },
44 [NET_SHAPER_A_BURST] = { .type = NLA_UINT, },
45 [NET_SHAPER_A_PRIORITY] = { .type = NLA_U32, },
46 [NET_SHAPER_A_WEIGHT] = { .type = NLA_U32, },
47};
48
49/* NET_SHAPER_CMD_DELETE - do */
50static const struct nla_policy net_shaper_delete_nl_policy[NET_SHAPER_A_IFINDEX + 1] = {
51 [NET_SHAPER_A_IFINDEX] = { .type = NLA_U32, },
52 [NET_SHAPER_A_HANDLE] = NLA_POLICY_NESTED(net_shaper_handle_nl_policy),
53};
54
55/* NET_SHAPER_CMD_GROUP - do */
56static const struct nla_policy net_shaper_group_nl_policy[NET_SHAPER_A_LEAVES + 1] = {
57 [NET_SHAPER_A_IFINDEX] = { .type = NLA_U32, },
58 [NET_SHAPER_A_PARENT] = NLA_POLICY_NESTED(net_shaper_handle_nl_policy),
59 [NET_SHAPER_A_HANDLE] = NLA_POLICY_NESTED(net_shaper_handle_nl_policy),
60 [NET_SHAPER_A_METRIC] = NLA_POLICY_MAX(NLA_U32, 1),
61 [NET_SHAPER_A_BW_MIN] = { .type = NLA_UINT, },
62 [NET_SHAPER_A_BW_MAX] = { .type = NLA_UINT, },
63 [NET_SHAPER_A_BURST] = { .type = NLA_UINT, },
64 [NET_SHAPER_A_PRIORITY] = { .type = NLA_U32, },
65 [NET_SHAPER_A_WEIGHT] = { .type = NLA_U32, },
66 [NET_SHAPER_A_LEAVES] = NLA_POLICY_NESTED(net_shaper_leaf_info_nl_policy),
67};
68
69/* NET_SHAPER_CMD_CAP_GET - do */
70static const struct nla_policy net_shaper_cap_get_do_nl_policy[NET_SHAPER_A_CAPS_SCOPE + 1] = {
71 [NET_SHAPER_A_CAPS_IFINDEX] = { .type = NLA_U32, },
72 [NET_SHAPER_A_CAPS_SCOPE] = NLA_POLICY_MAX(NLA_U32, 3),
73};
74
75/* NET_SHAPER_CMD_CAP_GET - dump */
76static const struct nla_policy net_shaper_cap_get_dump_nl_policy[NET_SHAPER_A_CAPS_IFINDEX + 1] = {
77 [NET_SHAPER_A_CAPS_IFINDEX] = { .type = NLA_U32, },
78};
79
80/* Ops table for net_shaper */
81static const struct genl_split_ops net_shaper_nl_ops[] = {
82 {
83 .cmd = NET_SHAPER_CMD_GET,
84 .pre_doit = net_shaper_nl_pre_doit,
85 .doit = net_shaper_nl_get_doit,
86 .post_doit = net_shaper_nl_post_doit,
87 .policy = net_shaper_get_do_nl_policy,
88 .maxattr = NET_SHAPER_A_IFINDEX,
89 .flags = GENL_CMD_CAP_DO,
90 },
91 {
92 .cmd = NET_SHAPER_CMD_GET,
93 .start = net_shaper_nl_pre_dumpit,
94 .dumpit = net_shaper_nl_get_dumpit,
95 .done = net_shaper_nl_post_dumpit,
96 .policy = net_shaper_get_dump_nl_policy,
97 .maxattr = NET_SHAPER_A_IFINDEX,
98 .flags = GENL_CMD_CAP_DUMP,
99 },
100 {
101 .cmd = NET_SHAPER_CMD_SET,
102 .pre_doit = net_shaper_nl_pre_doit,
103 .doit = net_shaper_nl_set_doit,
104 .post_doit = net_shaper_nl_post_doit,
105 .policy = net_shaper_set_nl_policy,
106 .maxattr = NET_SHAPER_A_IFINDEX,
107 .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
108 },
109 {
110 .cmd = NET_SHAPER_CMD_DELETE,
111 .pre_doit = net_shaper_nl_pre_doit,
112 .doit = net_shaper_nl_delete_doit,
113 .post_doit = net_shaper_nl_post_doit,
114 .policy = net_shaper_delete_nl_policy,
115 .maxattr = NET_SHAPER_A_IFINDEX,
116 .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
117 },
118 {
119 .cmd = NET_SHAPER_CMD_GROUP,
120 .pre_doit = net_shaper_nl_pre_doit,
121 .doit = net_shaper_nl_group_doit,
122 .post_doit = net_shaper_nl_post_doit,
123 .policy = net_shaper_group_nl_policy,
124 .maxattr = NET_SHAPER_A_LEAVES,
125 .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
126 },
127 {
128 .cmd = NET_SHAPER_CMD_CAP_GET,
129 .pre_doit = net_shaper_nl_cap_pre_doit,
130 .doit = net_shaper_nl_cap_get_doit,
131 .post_doit = net_shaper_nl_cap_post_doit,
132 .policy = net_shaper_cap_get_do_nl_policy,
133 .maxattr = NET_SHAPER_A_CAPS_SCOPE,
134 .flags = GENL_CMD_CAP_DO,
135 },
136 {
137 .cmd = NET_SHAPER_CMD_CAP_GET,
138 .start = net_shaper_nl_cap_pre_dumpit,
139 .dumpit = net_shaper_nl_cap_get_dumpit,
140 .done = net_shaper_nl_cap_post_dumpit,
141 .policy = net_shaper_cap_get_dump_nl_policy,
142 .maxattr = NET_SHAPER_A_CAPS_IFINDEX,
143 .flags = GENL_CMD_CAP_DUMP,
144 },
145};
146
147struct genl_family net_shaper_nl_family __ro_after_init = {
148 .name = NET_SHAPER_FAMILY_NAME,
149 .version = NET_SHAPER_FAMILY_VERSION,
150 .netnsok = true,
151 .parallel_ops = true,
152 .module = THIS_MODULE,
153 .split_ops = net_shaper_nl_ops,
154 .n_split_ops = ARRAY_SIZE(net_shaper_nl_ops),
155};