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