1e2be04c7SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */ 2bfcd3a46SJiri Pirko /* 3bfcd3a46SJiri Pirko * include/uapi/linux/devlink.h - Network physical device Netlink interface 4bfcd3a46SJiri Pirko * Copyright (c) 2016 Mellanox Technologies. All rights reserved. 5bfcd3a46SJiri Pirko * Copyright (c) 2016 Jiri Pirko <[email protected]> 6bfcd3a46SJiri Pirko * 7bfcd3a46SJiri Pirko * This program is free software; you can redistribute it and/or modify 8bfcd3a46SJiri Pirko * it under the terms of the GNU General Public License as published by 9bfcd3a46SJiri Pirko * the Free Software Foundation; either version 2 of the License, or 10bfcd3a46SJiri Pirko * (at your option) any later version. 11bfcd3a46SJiri Pirko */ 12bfcd3a46SJiri Pirko 13bfcd3a46SJiri Pirko #ifndef _UAPI_LINUX_DEVLINK_H_ 14bfcd3a46SJiri Pirko #define _UAPI_LINUX_DEVLINK_H_ 15bfcd3a46SJiri Pirko 16bfcd3a46SJiri Pirko #define DEVLINK_GENL_NAME "devlink" 17bfcd3a46SJiri Pirko #define DEVLINK_GENL_VERSION 0x1 18bfcd3a46SJiri Pirko #define DEVLINK_GENL_MCGRP_CONFIG_NAME "config" 19bfcd3a46SJiri Pirko 20bfcd3a46SJiri Pirko enum devlink_command { 21bfcd3a46SJiri Pirko /* don't change the order or add anything between, this is ABI! */ 22bfcd3a46SJiri Pirko DEVLINK_CMD_UNSPEC, 23bfcd3a46SJiri Pirko 24bfcd3a46SJiri Pirko DEVLINK_CMD_GET, /* can dump */ 25bfcd3a46SJiri Pirko DEVLINK_CMD_SET, 26bfcd3a46SJiri Pirko DEVLINK_CMD_NEW, 27bfcd3a46SJiri Pirko DEVLINK_CMD_DEL, 28bfcd3a46SJiri Pirko 29bfcd3a46SJiri Pirko DEVLINK_CMD_PORT_GET, /* can dump */ 30bfcd3a46SJiri Pirko DEVLINK_CMD_PORT_SET, 31bfcd3a46SJiri Pirko DEVLINK_CMD_PORT_NEW, 32bfcd3a46SJiri Pirko DEVLINK_CMD_PORT_DEL, 33bfcd3a46SJiri Pirko 34bfcd3a46SJiri Pirko DEVLINK_CMD_PORT_SPLIT, 35bfcd3a46SJiri Pirko DEVLINK_CMD_PORT_UNSPLIT, 36bfcd3a46SJiri Pirko 37bf797471SJiri Pirko DEVLINK_CMD_SB_GET, /* can dump */ 38bf797471SJiri Pirko DEVLINK_CMD_SB_SET, 39bf797471SJiri Pirko DEVLINK_CMD_SB_NEW, 40bf797471SJiri Pirko DEVLINK_CMD_SB_DEL, 41bf797471SJiri Pirko 42bf797471SJiri Pirko DEVLINK_CMD_SB_POOL_GET, /* can dump */ 43bf797471SJiri Pirko DEVLINK_CMD_SB_POOL_SET, 44bf797471SJiri Pirko DEVLINK_CMD_SB_POOL_NEW, 45bf797471SJiri Pirko DEVLINK_CMD_SB_POOL_DEL, 46bf797471SJiri Pirko 47bf797471SJiri Pirko DEVLINK_CMD_SB_PORT_POOL_GET, /* can dump */ 48bf797471SJiri Pirko DEVLINK_CMD_SB_PORT_POOL_SET, 49bf797471SJiri Pirko DEVLINK_CMD_SB_PORT_POOL_NEW, 50bf797471SJiri Pirko DEVLINK_CMD_SB_PORT_POOL_DEL, 51bf797471SJiri Pirko 52bf797471SJiri Pirko DEVLINK_CMD_SB_TC_POOL_BIND_GET, /* can dump */ 53bf797471SJiri Pirko DEVLINK_CMD_SB_TC_POOL_BIND_SET, 54bf797471SJiri Pirko DEVLINK_CMD_SB_TC_POOL_BIND_NEW, 55bf797471SJiri Pirko DEVLINK_CMD_SB_TC_POOL_BIND_DEL, 56bf797471SJiri Pirko 57df38dafdSJiri Pirko /* Shared buffer occupancy monitoring commands */ 58df38dafdSJiri Pirko DEVLINK_CMD_SB_OCC_SNAPSHOT, 59df38dafdSJiri Pirko DEVLINK_CMD_SB_OCC_MAX_CLEAR, 60df38dafdSJiri Pirko 61adf200f3SJiri Pirko DEVLINK_CMD_ESWITCH_GET, 62adf200f3SJiri Pirko #define DEVLINK_CMD_ESWITCH_MODE_GET /* obsolete, never use this! */ \ 63adf200f3SJiri Pirko DEVLINK_CMD_ESWITCH_GET 64adf200f3SJiri Pirko 65adf200f3SJiri Pirko DEVLINK_CMD_ESWITCH_SET, 66adf200f3SJiri Pirko #define DEVLINK_CMD_ESWITCH_MODE_SET /* obsolete, never use this! */ \ 67adf200f3SJiri Pirko DEVLINK_CMD_ESWITCH_SET 68adf200f3SJiri Pirko 691555d204SArkadi Sharshevsky DEVLINK_CMD_DPIPE_TABLE_GET, 701555d204SArkadi Sharshevsky DEVLINK_CMD_DPIPE_ENTRIES_GET, 711555d204SArkadi Sharshevsky DEVLINK_CMD_DPIPE_HEADERS_GET, 721555d204SArkadi Sharshevsky DEVLINK_CMD_DPIPE_TABLE_COUNTERS_SET, 73d9f9b9a4SArkadi Sharshevsky DEVLINK_CMD_RESOURCE_SET, 74d9f9b9a4SArkadi Sharshevsky DEVLINK_CMD_RESOURCE_DUMP, 75bfcd3a46SJiri Pirko 76*2d8dc5bbSArkadi Sharshevsky /* Hot driver reload, makes configuration changes take place. The 77*2d8dc5bbSArkadi Sharshevsky * devlink instance is not released during the process. 78*2d8dc5bbSArkadi Sharshevsky */ 79*2d8dc5bbSArkadi Sharshevsky DEVLINK_CMD_RELOAD, 80*2d8dc5bbSArkadi Sharshevsky 811555d204SArkadi Sharshevsky /* add new commands above here */ 82bfcd3a46SJiri Pirko __DEVLINK_CMD_MAX, 83bfcd3a46SJiri Pirko DEVLINK_CMD_MAX = __DEVLINK_CMD_MAX - 1 84bfcd3a46SJiri Pirko }; 85bfcd3a46SJiri Pirko 86bfcd3a46SJiri Pirko enum devlink_port_type { 87bfcd3a46SJiri Pirko DEVLINK_PORT_TYPE_NOTSET, 88bfcd3a46SJiri Pirko DEVLINK_PORT_TYPE_AUTO, 89bfcd3a46SJiri Pirko DEVLINK_PORT_TYPE_ETH, 90bfcd3a46SJiri Pirko DEVLINK_PORT_TYPE_IB, 91bfcd3a46SJiri Pirko }; 92bfcd3a46SJiri Pirko 93bf797471SJiri Pirko enum devlink_sb_pool_type { 94bf797471SJiri Pirko DEVLINK_SB_POOL_TYPE_INGRESS, 95bf797471SJiri Pirko DEVLINK_SB_POOL_TYPE_EGRESS, 96bf797471SJiri Pirko }; 97bf797471SJiri Pirko 98bf797471SJiri Pirko /* static threshold - limiting the maximum number of bytes. 99bf797471SJiri Pirko * dynamic threshold - limiting the maximum number of bytes 100bf797471SJiri Pirko * based on the currently available free space in the shared buffer pool. 101bf797471SJiri Pirko * In this mode, the maximum quota is calculated based 102bf797471SJiri Pirko * on the following formula: 103bf797471SJiri Pirko * max_quota = alpha / (1 + alpha) * Free_Buffer 104bf797471SJiri Pirko * While Free_Buffer is the amount of none-occupied buffer associated to 105bf797471SJiri Pirko * the relevant pool. 106bf797471SJiri Pirko * The value range which can be passed is 0-20 and serves 107bf797471SJiri Pirko * for computation of alpha by following formula: 108bf797471SJiri Pirko * alpha = 2 ^ (passed_value - 10) 109bf797471SJiri Pirko */ 110bf797471SJiri Pirko 111bf797471SJiri Pirko enum devlink_sb_threshold_type { 112bf797471SJiri Pirko DEVLINK_SB_THRESHOLD_TYPE_STATIC, 113bf797471SJiri Pirko DEVLINK_SB_THRESHOLD_TYPE_DYNAMIC, 114bf797471SJiri Pirko }; 115bf797471SJiri Pirko 116bf797471SJiri Pirko #define DEVLINK_SB_THRESHOLD_TO_ALPHA_MAX 20 117bf797471SJiri Pirko 11808f4b591SOr Gerlitz enum devlink_eswitch_mode { 11908f4b591SOr Gerlitz DEVLINK_ESWITCH_MODE_LEGACY, 12008f4b591SOr Gerlitz DEVLINK_ESWITCH_MODE_SWITCHDEV, 12108f4b591SOr Gerlitz }; 12208f4b591SOr Gerlitz 12359bfde01SRoi Dayan enum devlink_eswitch_inline_mode { 12459bfde01SRoi Dayan DEVLINK_ESWITCH_INLINE_MODE_NONE, 12559bfde01SRoi Dayan DEVLINK_ESWITCH_INLINE_MODE_LINK, 12659bfde01SRoi Dayan DEVLINK_ESWITCH_INLINE_MODE_NETWORK, 12759bfde01SRoi Dayan DEVLINK_ESWITCH_INLINE_MODE_TRANSPORT, 12859bfde01SRoi Dayan }; 12959bfde01SRoi Dayan 130f43e9b06SRoi Dayan enum devlink_eswitch_encap_mode { 131f43e9b06SRoi Dayan DEVLINK_ESWITCH_ENCAP_MODE_NONE, 132f43e9b06SRoi Dayan DEVLINK_ESWITCH_ENCAP_MODE_BASIC, 133f43e9b06SRoi Dayan }; 134f43e9b06SRoi Dayan 135bfcd3a46SJiri Pirko enum devlink_attr { 136bfcd3a46SJiri Pirko /* don't change the order or add anything between, this is ABI! */ 137bfcd3a46SJiri Pirko DEVLINK_ATTR_UNSPEC, 138bfcd3a46SJiri Pirko 139bfcd3a46SJiri Pirko /* bus name + dev name together are a handle for devlink entity */ 140bfcd3a46SJiri Pirko DEVLINK_ATTR_BUS_NAME, /* string */ 141bfcd3a46SJiri Pirko DEVLINK_ATTR_DEV_NAME, /* string */ 142bfcd3a46SJiri Pirko 143bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_INDEX, /* u32 */ 144bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_TYPE, /* u16 */ 145bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_DESIRED_TYPE, /* u16 */ 146bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_NETDEV_IFINDEX, /* u32 */ 147bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_NETDEV_NAME, /* string */ 148bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_IBDEV_NAME, /* string */ 149bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_SPLIT_COUNT, /* u32 */ 150bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_SPLIT_GROUP, /* u32 */ 151bf797471SJiri Pirko DEVLINK_ATTR_SB_INDEX, /* u32 */ 152bf797471SJiri Pirko DEVLINK_ATTR_SB_SIZE, /* u32 */ 153bf797471SJiri Pirko DEVLINK_ATTR_SB_INGRESS_POOL_COUNT, /* u16 */ 154bf797471SJiri Pirko DEVLINK_ATTR_SB_EGRESS_POOL_COUNT, /* u16 */ 155bf797471SJiri Pirko DEVLINK_ATTR_SB_INGRESS_TC_COUNT, /* u16 */ 156bf797471SJiri Pirko DEVLINK_ATTR_SB_EGRESS_TC_COUNT, /* u16 */ 157bf797471SJiri Pirko DEVLINK_ATTR_SB_POOL_INDEX, /* u16 */ 158bf797471SJiri Pirko DEVLINK_ATTR_SB_POOL_TYPE, /* u8 */ 159bf797471SJiri Pirko DEVLINK_ATTR_SB_POOL_SIZE, /* u32 */ 160bf797471SJiri Pirko DEVLINK_ATTR_SB_POOL_THRESHOLD_TYPE, /* u8 */ 161bf797471SJiri Pirko DEVLINK_ATTR_SB_THRESHOLD, /* u32 */ 162bf797471SJiri Pirko DEVLINK_ATTR_SB_TC_INDEX, /* u16 */ 163df38dafdSJiri Pirko DEVLINK_ATTR_SB_OCC_CUR, /* u32 */ 164df38dafdSJiri Pirko DEVLINK_ATTR_SB_OCC_MAX, /* u32 */ 16508f4b591SOr Gerlitz DEVLINK_ATTR_ESWITCH_MODE, /* u16 */ 16659bfde01SRoi Dayan DEVLINK_ATTR_ESWITCH_INLINE_MODE, /* u8 */ 167bfcd3a46SJiri Pirko 1681555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLES, /* nested */ 1691555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLE, /* nested */ 1701555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLE_NAME, /* string */ 1711555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLE_SIZE, /* u64 */ 1721555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLE_MATCHES, /* nested */ 1731555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLE_ACTIONS, /* nested */ 1741555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLE_COUNTERS_ENABLED, /* u8 */ 1751555d204SArkadi Sharshevsky 1761555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ENTRIES, /* nested */ 1771555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ENTRY, /* nested */ 1781555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ENTRY_INDEX, /* u64 */ 1791555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ENTRY_MATCH_VALUES, /* nested */ 1801555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ENTRY_ACTION_VALUES, /* nested */ 1811555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ENTRY_COUNTER, /* u64 */ 1821555d204SArkadi Sharshevsky 1831555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_MATCH, /* nested */ 1841555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_MATCH_VALUE, /* nested */ 1851555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_MATCH_TYPE, /* u32 */ 1861555d204SArkadi Sharshevsky 1871555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ACTION, /* nested */ 1881555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ACTION_VALUE, /* nested */ 1891555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ACTION_TYPE, /* u32 */ 1901555d204SArkadi Sharshevsky 1911555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_VALUE, 1921555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_VALUE_MASK, 1931555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_VALUE_MAPPING, /* u32 */ 1941555d204SArkadi Sharshevsky 1951555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADERS, /* nested */ 1961555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADER, /* nested */ 1971555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADER_NAME, /* string */ 1981555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADER_ID, /* u32 */ 1991555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADER_FIELDS, /* nested */ 2001555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADER_GLOBAL, /* u8 */ 2011555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADER_INDEX, /* u32 */ 2021555d204SArkadi Sharshevsky 2031555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_FIELD, /* nested */ 2041555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_FIELD_NAME, /* string */ 2051555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_FIELD_ID, /* u32 */ 2061555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_FIELD_BITWIDTH, /* u32 */ 2071555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_FIELD_MAPPING_TYPE, /* u32 */ 2081555d204SArkadi Sharshevsky 2091555d204SArkadi Sharshevsky DEVLINK_ATTR_PAD, 2101555d204SArkadi Sharshevsky 211f43e9b06SRoi Dayan DEVLINK_ATTR_ESWITCH_ENCAP_MODE, /* u8 */ 212d9f9b9a4SArkadi Sharshevsky DEVLINK_ATTR_RESOURCE_LIST, /* nested */ 213d9f9b9a4SArkadi Sharshevsky DEVLINK_ATTR_RESOURCE, /* nested */ 214d9f9b9a4SArkadi Sharshevsky DEVLINK_ATTR_RESOURCE_NAME, /* string */ 215d9f9b9a4SArkadi Sharshevsky DEVLINK_ATTR_RESOURCE_ID, /* u64 */ 216d9f9b9a4SArkadi Sharshevsky DEVLINK_ATTR_RESOURCE_SIZE, /* u64 */ 217d9f9b9a4SArkadi Sharshevsky DEVLINK_ATTR_RESOURCE_SIZE_NEW, /* u64 */ 218d9f9b9a4SArkadi Sharshevsky DEVLINK_ATTR_RESOURCE_SIZE_VALID, /* u8 */ 219d9f9b9a4SArkadi Sharshevsky DEVLINK_ATTR_RESOURCE_SIZE_MIN, /* u64 */ 220d9f9b9a4SArkadi Sharshevsky DEVLINK_ATTR_RESOURCE_SIZE_MAX, /* u64 */ 221d9f9b9a4SArkadi Sharshevsky DEVLINK_ATTR_RESOURCE_SIZE_GRAN, /* u64 */ 222d9f9b9a4SArkadi Sharshevsky DEVLINK_ATTR_RESOURCE_UNIT, /* u8 */ 223d9f9b9a4SArkadi Sharshevsky DEVLINK_ATTR_RESOURCE_OCC, /* u64 */ 224f43e9b06SRoi Dayan 225bfcd3a46SJiri Pirko /* add new attributes above here, update the policy in devlink.c */ 226bfcd3a46SJiri Pirko 227bfcd3a46SJiri Pirko __DEVLINK_ATTR_MAX, 228bfcd3a46SJiri Pirko DEVLINK_ATTR_MAX = __DEVLINK_ATTR_MAX - 1 229bfcd3a46SJiri Pirko }; 230bfcd3a46SJiri Pirko 2311555d204SArkadi Sharshevsky /* Mapping between internal resource described by the field and system 2321555d204SArkadi Sharshevsky * structure 2331555d204SArkadi Sharshevsky */ 2341555d204SArkadi Sharshevsky enum devlink_dpipe_field_mapping_type { 2351555d204SArkadi Sharshevsky DEVLINK_DPIPE_FIELD_MAPPING_TYPE_NONE, 2361555d204SArkadi Sharshevsky DEVLINK_DPIPE_FIELD_MAPPING_TYPE_IFINDEX, 2371555d204SArkadi Sharshevsky }; 2381555d204SArkadi Sharshevsky 2391555d204SArkadi Sharshevsky /* Match type - specify the type of the match */ 2401555d204SArkadi Sharshevsky enum devlink_dpipe_match_type { 2411555d204SArkadi Sharshevsky DEVLINK_DPIPE_MATCH_TYPE_FIELD_EXACT, 2421555d204SArkadi Sharshevsky }; 2431555d204SArkadi Sharshevsky 2441555d204SArkadi Sharshevsky /* Action type - specify the action type */ 2451555d204SArkadi Sharshevsky enum devlink_dpipe_action_type { 2461555d204SArkadi Sharshevsky DEVLINK_DPIPE_ACTION_TYPE_FIELD_MODIFY, 2471555d204SArkadi Sharshevsky }; 2481555d204SArkadi Sharshevsky 24911770091SArkadi Sharshevsky enum devlink_dpipe_field_ethernet_id { 25011770091SArkadi Sharshevsky DEVLINK_DPIPE_FIELD_ETHERNET_DST_MAC, 25111770091SArkadi Sharshevsky }; 25211770091SArkadi Sharshevsky 2533fb886ecSArkadi Sharshevsky enum devlink_dpipe_field_ipv4_id { 2543fb886ecSArkadi Sharshevsky DEVLINK_DPIPE_FIELD_IPV4_DST_IP, 2553fb886ecSArkadi Sharshevsky }; 2563fb886ecSArkadi Sharshevsky 2571797f5b3SArkadi Sharshevsky enum devlink_dpipe_field_ipv6_id { 2581797f5b3SArkadi Sharshevsky DEVLINK_DPIPE_FIELD_IPV6_DST_IP, 2591797f5b3SArkadi Sharshevsky }; 2601797f5b3SArkadi Sharshevsky 26111770091SArkadi Sharshevsky enum devlink_dpipe_header_id { 26211770091SArkadi Sharshevsky DEVLINK_DPIPE_HEADER_ETHERNET, 2633fb886ecSArkadi Sharshevsky DEVLINK_DPIPE_HEADER_IPV4, 2641797f5b3SArkadi Sharshevsky DEVLINK_DPIPE_HEADER_IPV6, 26511770091SArkadi Sharshevsky }; 26611770091SArkadi Sharshevsky 267d9f9b9a4SArkadi Sharshevsky enum devlink_resource_unit { 268d9f9b9a4SArkadi Sharshevsky DEVLINK_RESOURCE_UNIT_ENTRY, 269d9f9b9a4SArkadi Sharshevsky }; 270d9f9b9a4SArkadi Sharshevsky 271bfcd3a46SJiri Pirko #endif /* _UAPI_LINUX_DEVLINK_H_ */ 272