at master 5.6 kB view raw
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/dpll.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 "dpll_nl.h" 11 12#include <uapi/linux/dpll.h> 13 14/* Common nested types */ 15const struct nla_policy dpll_pin_parent_device_nl_policy[DPLL_A_PIN_PHASE_OFFSET + 1] = { 16 [DPLL_A_PIN_PARENT_ID] = { .type = NLA_U32, }, 17 [DPLL_A_PIN_DIRECTION] = NLA_POLICY_RANGE(NLA_U32, 1, 2), 18 [DPLL_A_PIN_PRIO] = { .type = NLA_U32, }, 19 [DPLL_A_PIN_STATE] = NLA_POLICY_RANGE(NLA_U32, 1, 3), 20 [DPLL_A_PIN_PHASE_OFFSET] = { .type = NLA_S64, }, 21}; 22 23const struct nla_policy dpll_pin_parent_pin_nl_policy[DPLL_A_PIN_STATE + 1] = { 24 [DPLL_A_PIN_PARENT_ID] = { .type = NLA_U32, }, 25 [DPLL_A_PIN_STATE] = NLA_POLICY_RANGE(NLA_U32, 1, 3), 26}; 27 28const struct nla_policy dpll_reference_sync_nl_policy[DPLL_A_PIN_STATE + 1] = { 29 [DPLL_A_PIN_ID] = { .type = NLA_U32, }, 30 [DPLL_A_PIN_STATE] = NLA_POLICY_RANGE(NLA_U32, 1, 3), 31}; 32 33/* DPLL_CMD_DEVICE_ID_GET - do */ 34static const struct nla_policy dpll_device_id_get_nl_policy[DPLL_A_TYPE + 1] = { 35 [DPLL_A_MODULE_NAME] = { .type = NLA_NUL_STRING, }, 36 [DPLL_A_CLOCK_ID] = { .type = NLA_U64, }, 37 [DPLL_A_TYPE] = NLA_POLICY_RANGE(NLA_U32, 1, 2), 38}; 39 40/* DPLL_CMD_DEVICE_GET - do */ 41static const struct nla_policy dpll_device_get_nl_policy[DPLL_A_ID + 1] = { 42 [DPLL_A_ID] = { .type = NLA_U32, }, 43}; 44 45/* DPLL_CMD_DEVICE_SET - do */ 46static const struct nla_policy dpll_device_set_nl_policy[DPLL_A_PHASE_OFFSET_AVG_FACTOR + 1] = { 47 [DPLL_A_ID] = { .type = NLA_U32, }, 48 [DPLL_A_PHASE_OFFSET_MONITOR] = NLA_POLICY_MAX(NLA_U32, 1), 49 [DPLL_A_PHASE_OFFSET_AVG_FACTOR] = { .type = NLA_U32, }, 50}; 51 52/* DPLL_CMD_PIN_ID_GET - do */ 53static const struct nla_policy dpll_pin_id_get_nl_policy[DPLL_A_PIN_TYPE + 1] = { 54 [DPLL_A_PIN_MODULE_NAME] = { .type = NLA_NUL_STRING, }, 55 [DPLL_A_PIN_CLOCK_ID] = { .type = NLA_U64, }, 56 [DPLL_A_PIN_BOARD_LABEL] = { .type = NLA_NUL_STRING, }, 57 [DPLL_A_PIN_PANEL_LABEL] = { .type = NLA_NUL_STRING, }, 58 [DPLL_A_PIN_PACKAGE_LABEL] = { .type = NLA_NUL_STRING, }, 59 [DPLL_A_PIN_TYPE] = NLA_POLICY_RANGE(NLA_U32, 1, 5), 60}; 61 62/* DPLL_CMD_PIN_GET - do */ 63static const struct nla_policy dpll_pin_get_do_nl_policy[DPLL_A_PIN_ID + 1] = { 64 [DPLL_A_PIN_ID] = { .type = NLA_U32, }, 65}; 66 67/* DPLL_CMD_PIN_GET - dump */ 68static const struct nla_policy dpll_pin_get_dump_nl_policy[DPLL_A_PIN_ID + 1] = { 69 [DPLL_A_PIN_ID] = { .type = NLA_U32, }, 70}; 71 72/* DPLL_CMD_PIN_SET - do */ 73static const struct nla_policy dpll_pin_set_nl_policy[DPLL_A_PIN_REFERENCE_SYNC + 1] = { 74 [DPLL_A_PIN_ID] = { .type = NLA_U32, }, 75 [DPLL_A_PIN_FREQUENCY] = { .type = NLA_U64, }, 76 [DPLL_A_PIN_DIRECTION] = NLA_POLICY_RANGE(NLA_U32, 1, 2), 77 [DPLL_A_PIN_PRIO] = { .type = NLA_U32, }, 78 [DPLL_A_PIN_STATE] = NLA_POLICY_RANGE(NLA_U32, 1, 3), 79 [DPLL_A_PIN_PARENT_DEVICE] = NLA_POLICY_NESTED(dpll_pin_parent_device_nl_policy), 80 [DPLL_A_PIN_PARENT_PIN] = NLA_POLICY_NESTED(dpll_pin_parent_pin_nl_policy), 81 [DPLL_A_PIN_PHASE_ADJUST] = { .type = NLA_S32, }, 82 [DPLL_A_PIN_ESYNC_FREQUENCY] = { .type = NLA_U64, }, 83 [DPLL_A_PIN_REFERENCE_SYNC] = NLA_POLICY_NESTED(dpll_reference_sync_nl_policy), 84}; 85 86/* Ops table for dpll */ 87static const struct genl_split_ops dpll_nl_ops[] = { 88 { 89 .cmd = DPLL_CMD_DEVICE_ID_GET, 90 .pre_doit = dpll_lock_doit, 91 .doit = dpll_nl_device_id_get_doit, 92 .post_doit = dpll_unlock_doit, 93 .policy = dpll_device_id_get_nl_policy, 94 .maxattr = DPLL_A_TYPE, 95 .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO, 96 }, 97 { 98 .cmd = DPLL_CMD_DEVICE_GET, 99 .pre_doit = dpll_pre_doit, 100 .doit = dpll_nl_device_get_doit, 101 .post_doit = dpll_post_doit, 102 .policy = dpll_device_get_nl_policy, 103 .maxattr = DPLL_A_ID, 104 .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO, 105 }, 106 { 107 .cmd = DPLL_CMD_DEVICE_GET, 108 .dumpit = dpll_nl_device_get_dumpit, 109 .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DUMP, 110 }, 111 { 112 .cmd = DPLL_CMD_DEVICE_SET, 113 .pre_doit = dpll_pre_doit, 114 .doit = dpll_nl_device_set_doit, 115 .post_doit = dpll_post_doit, 116 .policy = dpll_device_set_nl_policy, 117 .maxattr = DPLL_A_PHASE_OFFSET_AVG_FACTOR, 118 .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO, 119 }, 120 { 121 .cmd = DPLL_CMD_PIN_ID_GET, 122 .pre_doit = dpll_lock_doit, 123 .doit = dpll_nl_pin_id_get_doit, 124 .post_doit = dpll_unlock_doit, 125 .policy = dpll_pin_id_get_nl_policy, 126 .maxattr = DPLL_A_PIN_TYPE, 127 .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO, 128 }, 129 { 130 .cmd = DPLL_CMD_PIN_GET, 131 .pre_doit = dpll_pin_pre_doit, 132 .doit = dpll_nl_pin_get_doit, 133 .post_doit = dpll_pin_post_doit, 134 .policy = dpll_pin_get_do_nl_policy, 135 .maxattr = DPLL_A_PIN_ID, 136 .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO, 137 }, 138 { 139 .cmd = DPLL_CMD_PIN_GET, 140 .dumpit = dpll_nl_pin_get_dumpit, 141 .policy = dpll_pin_get_dump_nl_policy, 142 .maxattr = DPLL_A_PIN_ID, 143 .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DUMP, 144 }, 145 { 146 .cmd = DPLL_CMD_PIN_SET, 147 .pre_doit = dpll_pin_pre_doit, 148 .doit = dpll_nl_pin_set_doit, 149 .post_doit = dpll_pin_post_doit, 150 .policy = dpll_pin_set_nl_policy, 151 .maxattr = DPLL_A_PIN_REFERENCE_SYNC, 152 .flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO, 153 }, 154}; 155 156static const struct genl_multicast_group dpll_nl_mcgrps[] = { 157 [DPLL_NLGRP_MONITOR] = { "monitor", }, 158}; 159 160struct genl_family dpll_nl_family __ro_after_init = { 161 .name = DPLL_FAMILY_NAME, 162 .version = DPLL_FAMILY_VERSION, 163 .netnsok = true, 164 .parallel_ops = true, 165 .module = THIS_MODULE, 166 .split_ops = dpll_nl_ops, 167 .n_split_ops = ARRAY_SIZE(dpll_nl_ops), 168 .mcgrps = dpll_nl_mcgrps, 169 .n_mcgrps = ARRAY_SIZE(dpll_nl_mcgrps), 170};