netdev-genl-gen.c 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  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/netdev.yaml */
  4. /* YNL-GEN kernel source */
  5. /* To regenerate run: tools/net/ynl/ynl-regen.sh */
  6. #include <net/netlink.h>
  7. #include <net/genetlink.h>
  8. #include "netdev-genl-gen.h"
  9. #include <uapi/linux/netdev.h>
  10. #include <net/netdev_netlink.h>
  11. /* Integer value ranges */
  12. static const struct netlink_range_validation netdev_a_page_pool_id_range = {
  13. .min = 1ULL,
  14. .max = U32_MAX,
  15. };
  16. static const struct netlink_range_validation netdev_a_page_pool_ifindex_range = {
  17. .min = 1ULL,
  18. .max = S32_MAX,
  19. };
  20. static const struct netlink_range_validation netdev_a_napi_defer_hard_irqs_range = {
  21. .max = S32_MAX,
  22. };
  23. /* Common nested types */
  24. const struct nla_policy netdev_page_pool_info_nl_policy[NETDEV_A_PAGE_POOL_IFINDEX + 1] = {
  25. [NETDEV_A_PAGE_POOL_ID] = NLA_POLICY_FULL_RANGE(NLA_UINT, &netdev_a_page_pool_id_range),
  26. [NETDEV_A_PAGE_POOL_IFINDEX] = NLA_POLICY_FULL_RANGE(NLA_U32, &netdev_a_page_pool_ifindex_range),
  27. };
  28. const struct nla_policy netdev_queue_id_nl_policy[NETDEV_A_QUEUE_TYPE + 1] = {
  29. [NETDEV_A_QUEUE_ID] = { .type = NLA_U32, },
  30. [NETDEV_A_QUEUE_TYPE] = NLA_POLICY_MAX(NLA_U32, 1),
  31. };
  32. /* NETDEV_CMD_DEV_GET - do */
  33. static const struct nla_policy netdev_dev_get_nl_policy[NETDEV_A_DEV_IFINDEX + 1] = {
  34. [NETDEV_A_DEV_IFINDEX] = NLA_POLICY_MIN(NLA_U32, 1),
  35. };
  36. /* NETDEV_CMD_PAGE_POOL_GET - do */
  37. #ifdef CONFIG_PAGE_POOL
  38. static const struct nla_policy netdev_page_pool_get_nl_policy[NETDEV_A_PAGE_POOL_ID + 1] = {
  39. [NETDEV_A_PAGE_POOL_ID] = NLA_POLICY_FULL_RANGE(NLA_UINT, &netdev_a_page_pool_id_range),
  40. };
  41. #endif /* CONFIG_PAGE_POOL */
  42. /* NETDEV_CMD_PAGE_POOL_STATS_GET - do */
  43. #ifdef CONFIG_PAGE_POOL_STATS
  44. static const struct nla_policy netdev_page_pool_stats_get_nl_policy[NETDEV_A_PAGE_POOL_STATS_INFO + 1] = {
  45. [NETDEV_A_PAGE_POOL_STATS_INFO] = NLA_POLICY_NESTED(netdev_page_pool_info_nl_policy),
  46. };
  47. #endif /* CONFIG_PAGE_POOL_STATS */
  48. /* NETDEV_CMD_QUEUE_GET - do */
  49. static const struct nla_policy netdev_queue_get_do_nl_policy[NETDEV_A_QUEUE_TYPE + 1] = {
  50. [NETDEV_A_QUEUE_IFINDEX] = NLA_POLICY_MIN(NLA_U32, 1),
  51. [NETDEV_A_QUEUE_TYPE] = NLA_POLICY_MAX(NLA_U32, 1),
  52. [NETDEV_A_QUEUE_ID] = { .type = NLA_U32, },
  53. };
  54. /* NETDEV_CMD_QUEUE_GET - dump */
  55. static const struct nla_policy netdev_queue_get_dump_nl_policy[NETDEV_A_QUEUE_IFINDEX + 1] = {
  56. [NETDEV_A_QUEUE_IFINDEX] = NLA_POLICY_MIN(NLA_U32, 1),
  57. };
  58. /* NETDEV_CMD_NAPI_GET - do */
  59. static const struct nla_policy netdev_napi_get_do_nl_policy[NETDEV_A_NAPI_ID + 1] = {
  60. [NETDEV_A_NAPI_ID] = { .type = NLA_U32, },
  61. };
  62. /* NETDEV_CMD_NAPI_GET - dump */
  63. static const struct nla_policy netdev_napi_get_dump_nl_policy[NETDEV_A_NAPI_IFINDEX + 1] = {
  64. [NETDEV_A_NAPI_IFINDEX] = NLA_POLICY_MIN(NLA_U32, 1),
  65. };
  66. /* NETDEV_CMD_QSTATS_GET - dump */
  67. static const struct nla_policy netdev_qstats_get_nl_policy[NETDEV_A_QSTATS_SCOPE + 1] = {
  68. [NETDEV_A_QSTATS_IFINDEX] = NLA_POLICY_MIN(NLA_U32, 1),
  69. [NETDEV_A_QSTATS_SCOPE] = NLA_POLICY_MASK(NLA_UINT, 0x1),
  70. };
  71. /* NETDEV_CMD_BIND_RX - do */
  72. static const struct nla_policy netdev_bind_rx_nl_policy[NETDEV_A_DMABUF_FD + 1] = {
  73. [NETDEV_A_DMABUF_IFINDEX] = NLA_POLICY_MIN(NLA_U32, 1),
  74. [NETDEV_A_DMABUF_FD] = { .type = NLA_U32, },
  75. [NETDEV_A_DMABUF_QUEUES] = NLA_POLICY_NESTED(netdev_queue_id_nl_policy),
  76. };
  77. /* NETDEV_CMD_NAPI_SET - do */
  78. static const struct nla_policy netdev_napi_set_nl_policy[NETDEV_A_NAPI_THREADED + 1] = {
  79. [NETDEV_A_NAPI_ID] = { .type = NLA_U32, },
  80. [NETDEV_A_NAPI_DEFER_HARD_IRQS] = NLA_POLICY_FULL_RANGE(NLA_U32, &netdev_a_napi_defer_hard_irqs_range),
  81. [NETDEV_A_NAPI_GRO_FLUSH_TIMEOUT] = { .type = NLA_UINT, },
  82. [NETDEV_A_NAPI_IRQ_SUSPEND_TIMEOUT] = { .type = NLA_UINT, },
  83. [NETDEV_A_NAPI_THREADED] = NLA_POLICY_MAX(NLA_U32, 2),
  84. };
  85. /* NETDEV_CMD_BIND_TX - do */
  86. static const struct nla_policy netdev_bind_tx_nl_policy[NETDEV_A_DMABUF_FD + 1] = {
  87. [NETDEV_A_DMABUF_IFINDEX] = NLA_POLICY_MIN(NLA_U32, 1),
  88. [NETDEV_A_DMABUF_FD] = { .type = NLA_U32, },
  89. };
  90. /* Ops table for netdev */
  91. static const struct genl_split_ops netdev_nl_ops[] = {
  92. {
  93. .cmd = NETDEV_CMD_DEV_GET,
  94. .doit = netdev_nl_dev_get_doit,
  95. .policy = netdev_dev_get_nl_policy,
  96. .maxattr = NETDEV_A_DEV_IFINDEX,
  97. .flags = GENL_CMD_CAP_DO,
  98. },
  99. {
  100. .cmd = NETDEV_CMD_DEV_GET,
  101. .dumpit = netdev_nl_dev_get_dumpit,
  102. .flags = GENL_CMD_CAP_DUMP,
  103. },
  104. #ifdef CONFIG_PAGE_POOL
  105. {
  106. .cmd = NETDEV_CMD_PAGE_POOL_GET,
  107. .doit = netdev_nl_page_pool_get_doit,
  108. .policy = netdev_page_pool_get_nl_policy,
  109. .maxattr = NETDEV_A_PAGE_POOL_ID,
  110. .flags = GENL_CMD_CAP_DO,
  111. },
  112. {
  113. .cmd = NETDEV_CMD_PAGE_POOL_GET,
  114. .dumpit = netdev_nl_page_pool_get_dumpit,
  115. .flags = GENL_CMD_CAP_DUMP,
  116. },
  117. #endif /* CONFIG_PAGE_POOL */
  118. #ifdef CONFIG_PAGE_POOL_STATS
  119. {
  120. .cmd = NETDEV_CMD_PAGE_POOL_STATS_GET,
  121. .doit = netdev_nl_page_pool_stats_get_doit,
  122. .policy = netdev_page_pool_stats_get_nl_policy,
  123. .maxattr = NETDEV_A_PAGE_POOL_STATS_INFO,
  124. .flags = GENL_CMD_CAP_DO,
  125. },
  126. {
  127. .cmd = NETDEV_CMD_PAGE_POOL_STATS_GET,
  128. .dumpit = netdev_nl_page_pool_stats_get_dumpit,
  129. .flags = GENL_CMD_CAP_DUMP,
  130. },
  131. #endif /* CONFIG_PAGE_POOL_STATS */
  132. {
  133. .cmd = NETDEV_CMD_QUEUE_GET,
  134. .doit = netdev_nl_queue_get_doit,
  135. .policy = netdev_queue_get_do_nl_policy,
  136. .maxattr = NETDEV_A_QUEUE_TYPE,
  137. .flags = GENL_CMD_CAP_DO,
  138. },
  139. {
  140. .cmd = NETDEV_CMD_QUEUE_GET,
  141. .dumpit = netdev_nl_queue_get_dumpit,
  142. .policy = netdev_queue_get_dump_nl_policy,
  143. .maxattr = NETDEV_A_QUEUE_IFINDEX,
  144. .flags = GENL_CMD_CAP_DUMP,
  145. },
  146. {
  147. .cmd = NETDEV_CMD_NAPI_GET,
  148. .doit = netdev_nl_napi_get_doit,
  149. .policy = netdev_napi_get_do_nl_policy,
  150. .maxattr = NETDEV_A_NAPI_ID,
  151. .flags = GENL_CMD_CAP_DO,
  152. },
  153. {
  154. .cmd = NETDEV_CMD_NAPI_GET,
  155. .dumpit = netdev_nl_napi_get_dumpit,
  156. .policy = netdev_napi_get_dump_nl_policy,
  157. .maxattr = NETDEV_A_NAPI_IFINDEX,
  158. .flags = GENL_CMD_CAP_DUMP,
  159. },
  160. {
  161. .cmd = NETDEV_CMD_QSTATS_GET,
  162. .dumpit = netdev_nl_qstats_get_dumpit,
  163. .policy = netdev_qstats_get_nl_policy,
  164. .maxattr = NETDEV_A_QSTATS_SCOPE,
  165. .flags = GENL_CMD_CAP_DUMP,
  166. },
  167. {
  168. .cmd = NETDEV_CMD_BIND_RX,
  169. .doit = netdev_nl_bind_rx_doit,
  170. .policy = netdev_bind_rx_nl_policy,
  171. .maxattr = NETDEV_A_DMABUF_FD,
  172. .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
  173. },
  174. {
  175. .cmd = NETDEV_CMD_NAPI_SET,
  176. .doit = netdev_nl_napi_set_doit,
  177. .policy = netdev_napi_set_nl_policy,
  178. .maxattr = NETDEV_A_NAPI_THREADED,
  179. .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
  180. },
  181. {
  182. .cmd = NETDEV_CMD_BIND_TX,
  183. .doit = netdev_nl_bind_tx_doit,
  184. .policy = netdev_bind_tx_nl_policy,
  185. .maxattr = NETDEV_A_DMABUF_FD,
  186. .flags = GENL_CMD_CAP_DO,
  187. },
  188. };
  189. static const struct genl_multicast_group netdev_nl_mcgrps[] = {
  190. [NETDEV_NLGRP_MGMT] = { "mgmt", },
  191. [NETDEV_NLGRP_PAGE_POOL] = { "page-pool", },
  192. };
  193. static void __netdev_nl_sock_priv_init(void *priv)
  194. {
  195. netdev_nl_sock_priv_init(priv);
  196. }
  197. static void __netdev_nl_sock_priv_destroy(void *priv)
  198. {
  199. netdev_nl_sock_priv_destroy(priv);
  200. }
  201. struct genl_family netdev_nl_family __ro_after_init = {
  202. .name = NETDEV_FAMILY_NAME,
  203. .version = NETDEV_FAMILY_VERSION,
  204. .netnsok = true,
  205. .parallel_ops = true,
  206. .module = THIS_MODULE,
  207. .split_ops = netdev_nl_ops,
  208. .n_split_ops = ARRAY_SIZE(netdev_nl_ops),
  209. .mcgrps = netdev_nl_mcgrps,
  210. .n_mcgrps = ARRAY_SIZE(netdev_nl_mcgrps),
  211. .sock_priv_size = sizeof(struct netdev_nl_sock),
  212. .sock_priv_init = __netdev_nl_sock_priv_init,
  213. .sock_priv_destroy = __netdev_nl_sock_priv_destroy,
  214. };