| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161 |
- // SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) OR BSD-3-Clause)
- /* Do not edit directly, auto-generated from: */
- /* Documentation/netlink/specs/dpll.yaml */
- /* YNL-GEN kernel source */
- #include <net/netlink.h>
- #include <net/genetlink.h>
- #include "dpll_nl.h"
- #include <uapi/linux/dpll.h>
- /* Common nested types */
- const struct nla_policy dpll_pin_parent_device_nl_policy[DPLL_A_PIN_PHASE_OFFSET + 1] = {
- [DPLL_A_PIN_PARENT_ID] = { .type = NLA_U32, },
- [DPLL_A_PIN_DIRECTION] = NLA_POLICY_RANGE(NLA_U32, 1, 2),
- [DPLL_A_PIN_PRIO] = { .type = NLA_U32, },
- [DPLL_A_PIN_STATE] = NLA_POLICY_RANGE(NLA_U32, 1, 3),
- [DPLL_A_PIN_PHASE_OFFSET] = { .type = NLA_S64, },
- };
- const struct nla_policy dpll_pin_parent_pin_nl_policy[DPLL_A_PIN_STATE + 1] = {
- [DPLL_A_PIN_PARENT_ID] = { .type = NLA_U32, },
- [DPLL_A_PIN_STATE] = NLA_POLICY_RANGE(NLA_U32, 1, 3),
- };
- /* DPLL_CMD_DEVICE_ID_GET - do */
- static const struct nla_policy dpll_device_id_get_nl_policy[DPLL_A_TYPE + 1] = {
- [DPLL_A_MODULE_NAME] = { .type = NLA_NUL_STRING, },
- [DPLL_A_CLOCK_ID] = { .type = NLA_U64, },
- [DPLL_A_TYPE] = NLA_POLICY_RANGE(NLA_U32, 1, 2),
- };
- /* DPLL_CMD_DEVICE_GET - do */
- static const struct nla_policy dpll_device_get_nl_policy[DPLL_A_ID + 1] = {
- [DPLL_A_ID] = { .type = NLA_U32, },
- };
- /* DPLL_CMD_DEVICE_SET - do */
- static const struct nla_policy dpll_device_set_nl_policy[DPLL_A_ID + 1] = {
- [DPLL_A_ID] = { .type = NLA_U32, },
- };
- /* DPLL_CMD_PIN_ID_GET - do */
- static const struct nla_policy dpll_pin_id_get_nl_policy[DPLL_A_PIN_TYPE + 1] = {
- [DPLL_A_PIN_MODULE_NAME] = { .type = NLA_NUL_STRING, },
- [DPLL_A_PIN_CLOCK_ID] = { .type = NLA_U64, },
- [DPLL_A_PIN_BOARD_LABEL] = { .type = NLA_NUL_STRING, },
- [DPLL_A_PIN_PANEL_LABEL] = { .type = NLA_NUL_STRING, },
- [DPLL_A_PIN_PACKAGE_LABEL] = { .type = NLA_NUL_STRING, },
- [DPLL_A_PIN_TYPE] = NLA_POLICY_RANGE(NLA_U32, 1, 5),
- };
- /* DPLL_CMD_PIN_GET - do */
- static const struct nla_policy dpll_pin_get_do_nl_policy[DPLL_A_PIN_ID + 1] = {
- [DPLL_A_PIN_ID] = { .type = NLA_U32, },
- };
- /* DPLL_CMD_PIN_GET - dump */
- static const struct nla_policy dpll_pin_get_dump_nl_policy[DPLL_A_PIN_ID + 1] = {
- [DPLL_A_PIN_ID] = { .type = NLA_U32, },
- };
- /* DPLL_CMD_PIN_SET - do */
- static const struct nla_policy dpll_pin_set_nl_policy[DPLL_A_PIN_ESYNC_FREQUENCY + 1] = {
- [DPLL_A_PIN_ID] = { .type = NLA_U32, },
- [DPLL_A_PIN_FREQUENCY] = { .type = NLA_U64, },
- [DPLL_A_PIN_DIRECTION] = NLA_POLICY_RANGE(NLA_U32, 1, 2),
- [DPLL_A_PIN_PRIO] = { .type = NLA_U32, },
- [DPLL_A_PIN_STATE] = NLA_POLICY_RANGE(NLA_U32, 1, 3),
- [DPLL_A_PIN_PARENT_DEVICE] = NLA_POLICY_NESTED(dpll_pin_parent_device_nl_policy),
- [DPLL_A_PIN_PARENT_PIN] = NLA_POLICY_NESTED(dpll_pin_parent_pin_nl_policy),
- [DPLL_A_PIN_PHASE_ADJUST] = { .type = NLA_S32, },
- [DPLL_A_PIN_ESYNC_FREQUENCY] = { .type = NLA_U64, },
- };
- /* Ops table for dpll */
- static const struct genl_split_ops dpll_nl_ops[] = {
- {
- .cmd = DPLL_CMD_DEVICE_ID_GET,
- .pre_doit = dpll_lock_doit,
- .doit = dpll_nl_device_id_get_doit,
- .post_doit = dpll_unlock_doit,
- .policy = dpll_device_id_get_nl_policy,
- .maxattr = DPLL_A_TYPE,
- .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
- },
- {
- .cmd = DPLL_CMD_DEVICE_GET,
- .pre_doit = dpll_pre_doit,
- .doit = dpll_nl_device_get_doit,
- .post_doit = dpll_post_doit,
- .policy = dpll_device_get_nl_policy,
- .maxattr = DPLL_A_ID,
- .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
- },
- {
- .cmd = DPLL_CMD_DEVICE_GET,
- .dumpit = dpll_nl_device_get_dumpit,
- .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DUMP,
- },
- {
- .cmd = DPLL_CMD_DEVICE_SET,
- .pre_doit = dpll_pre_doit,
- .doit = dpll_nl_device_set_doit,
- .post_doit = dpll_post_doit,
- .policy = dpll_device_set_nl_policy,
- .maxattr = DPLL_A_ID,
- .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
- },
- {
- .cmd = DPLL_CMD_PIN_ID_GET,
- .pre_doit = dpll_lock_doit,
- .doit = dpll_nl_pin_id_get_doit,
- .post_doit = dpll_unlock_doit,
- .policy = dpll_pin_id_get_nl_policy,
- .maxattr = DPLL_A_PIN_TYPE,
- .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
- },
- {
- .cmd = DPLL_CMD_PIN_GET,
- .pre_doit = dpll_pin_pre_doit,
- .doit = dpll_nl_pin_get_doit,
- .post_doit = dpll_pin_post_doit,
- .policy = dpll_pin_get_do_nl_policy,
- .maxattr = DPLL_A_PIN_ID,
- .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
- },
- {
- .cmd = DPLL_CMD_PIN_GET,
- .dumpit = dpll_nl_pin_get_dumpit,
- .policy = dpll_pin_get_dump_nl_policy,
- .maxattr = DPLL_A_PIN_ID,
- .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DUMP,
- },
- {
- .cmd = DPLL_CMD_PIN_SET,
- .pre_doit = dpll_pin_pre_doit,
- .doit = dpll_nl_pin_set_doit,
- .post_doit = dpll_pin_post_doit,
- .policy = dpll_pin_set_nl_policy,
- .maxattr = DPLL_A_PIN_ESYNC_FREQUENCY,
- .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
- },
- };
- static const struct genl_multicast_group dpll_nl_mcgrps[] = {
- [DPLL_NLGRP_MONITOR] = { "monitor", },
- };
- struct genl_family dpll_nl_family __ro_after_init = {
- .name = DPLL_FAMILY_NAME,
- .version = DPLL_FAMILY_VERSION,
- .netnsok = true,
- .parallel_ops = true,
- .module = THIS_MODULE,
- .split_ops = dpll_nl_ops,
- .n_split_ops = ARRAY_SIZE(dpll_nl_ops),
- .mcgrps = dpll_nl_mcgrps,
- .n_mcgrps = ARRAY_SIZE(dpll_nl_mcgrps),
- };
|