netdev-genl-gen.c 6.2 KB

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