1*e2be04c7SGreg 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, 73bfcd3a46SJiri Pirko 741555d204SArkadi Sharshevsky /* add new commands above here */ 75bfcd3a46SJiri Pirko __DEVLINK_CMD_MAX, 76bfcd3a46SJiri Pirko DEVLINK_CMD_MAX = __DEVLINK_CMD_MAX - 1 77bfcd3a46SJiri Pirko }; 78bfcd3a46SJiri Pirko 79bfcd3a46SJiri Pirko enum devlink_port_type { 80bfcd3a46SJiri Pirko DEVLINK_PORT_TYPE_NOTSET, 81bfcd3a46SJiri Pirko DEVLINK_PORT_TYPE_AUTO, 82bfcd3a46SJiri Pirko DEVLINK_PORT_TYPE_ETH, 83bfcd3a46SJiri Pirko DEVLINK_PORT_TYPE_IB, 84bfcd3a46SJiri Pirko }; 85bfcd3a46SJiri Pirko 86bf797471SJiri Pirko enum devlink_sb_pool_type { 87bf797471SJiri Pirko DEVLINK_SB_POOL_TYPE_INGRESS, 88bf797471SJiri Pirko DEVLINK_SB_POOL_TYPE_EGRESS, 89bf797471SJiri Pirko }; 90bf797471SJiri Pirko 91bf797471SJiri Pirko /* static threshold - limiting the maximum number of bytes. 92bf797471SJiri Pirko * dynamic threshold - limiting the maximum number of bytes 93bf797471SJiri Pirko * based on the currently available free space in the shared buffer pool. 94bf797471SJiri Pirko * In this mode, the maximum quota is calculated based 95bf797471SJiri Pirko * on the following formula: 96bf797471SJiri Pirko * max_quota = alpha / (1 + alpha) * Free_Buffer 97bf797471SJiri Pirko * While Free_Buffer is the amount of none-occupied buffer associated to 98bf797471SJiri Pirko * the relevant pool. 99bf797471SJiri Pirko * The value range which can be passed is 0-20 and serves 100bf797471SJiri Pirko * for computation of alpha by following formula: 101bf797471SJiri Pirko * alpha = 2 ^ (passed_value - 10) 102bf797471SJiri Pirko */ 103bf797471SJiri Pirko 104bf797471SJiri Pirko enum devlink_sb_threshold_type { 105bf797471SJiri Pirko DEVLINK_SB_THRESHOLD_TYPE_STATIC, 106bf797471SJiri Pirko DEVLINK_SB_THRESHOLD_TYPE_DYNAMIC, 107bf797471SJiri Pirko }; 108bf797471SJiri Pirko 109bf797471SJiri Pirko #define DEVLINK_SB_THRESHOLD_TO_ALPHA_MAX 20 110bf797471SJiri Pirko 11108f4b591SOr Gerlitz enum devlink_eswitch_mode { 11208f4b591SOr Gerlitz DEVLINK_ESWITCH_MODE_LEGACY, 11308f4b591SOr Gerlitz DEVLINK_ESWITCH_MODE_SWITCHDEV, 11408f4b591SOr Gerlitz }; 11508f4b591SOr Gerlitz 11659bfde01SRoi Dayan enum devlink_eswitch_inline_mode { 11759bfde01SRoi Dayan DEVLINK_ESWITCH_INLINE_MODE_NONE, 11859bfde01SRoi Dayan DEVLINK_ESWITCH_INLINE_MODE_LINK, 11959bfde01SRoi Dayan DEVLINK_ESWITCH_INLINE_MODE_NETWORK, 12059bfde01SRoi Dayan DEVLINK_ESWITCH_INLINE_MODE_TRANSPORT, 12159bfde01SRoi Dayan }; 12259bfde01SRoi Dayan 123f43e9b06SRoi Dayan enum devlink_eswitch_encap_mode { 124f43e9b06SRoi Dayan DEVLINK_ESWITCH_ENCAP_MODE_NONE, 125f43e9b06SRoi Dayan DEVLINK_ESWITCH_ENCAP_MODE_BASIC, 126f43e9b06SRoi Dayan }; 127f43e9b06SRoi Dayan 128bfcd3a46SJiri Pirko enum devlink_attr { 129bfcd3a46SJiri Pirko /* don't change the order or add anything between, this is ABI! */ 130bfcd3a46SJiri Pirko DEVLINK_ATTR_UNSPEC, 131bfcd3a46SJiri Pirko 132bfcd3a46SJiri Pirko /* bus name + dev name together are a handle for devlink entity */ 133bfcd3a46SJiri Pirko DEVLINK_ATTR_BUS_NAME, /* string */ 134bfcd3a46SJiri Pirko DEVLINK_ATTR_DEV_NAME, /* string */ 135bfcd3a46SJiri Pirko 136bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_INDEX, /* u32 */ 137bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_TYPE, /* u16 */ 138bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_DESIRED_TYPE, /* u16 */ 139bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_NETDEV_IFINDEX, /* u32 */ 140bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_NETDEV_NAME, /* string */ 141bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_IBDEV_NAME, /* string */ 142bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_SPLIT_COUNT, /* u32 */ 143bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_SPLIT_GROUP, /* u32 */ 144bf797471SJiri Pirko DEVLINK_ATTR_SB_INDEX, /* u32 */ 145bf797471SJiri Pirko DEVLINK_ATTR_SB_SIZE, /* u32 */ 146bf797471SJiri Pirko DEVLINK_ATTR_SB_INGRESS_POOL_COUNT, /* u16 */ 147bf797471SJiri Pirko DEVLINK_ATTR_SB_EGRESS_POOL_COUNT, /* u16 */ 148bf797471SJiri Pirko DEVLINK_ATTR_SB_INGRESS_TC_COUNT, /* u16 */ 149bf797471SJiri Pirko DEVLINK_ATTR_SB_EGRESS_TC_COUNT, /* u16 */ 150bf797471SJiri Pirko DEVLINK_ATTR_SB_POOL_INDEX, /* u16 */ 151bf797471SJiri Pirko DEVLINK_ATTR_SB_POOL_TYPE, /* u8 */ 152bf797471SJiri Pirko DEVLINK_ATTR_SB_POOL_SIZE, /* u32 */ 153bf797471SJiri Pirko DEVLINK_ATTR_SB_POOL_THRESHOLD_TYPE, /* u8 */ 154bf797471SJiri Pirko DEVLINK_ATTR_SB_THRESHOLD, /* u32 */ 155bf797471SJiri Pirko DEVLINK_ATTR_SB_TC_INDEX, /* u16 */ 156df38dafdSJiri Pirko DEVLINK_ATTR_SB_OCC_CUR, /* u32 */ 157df38dafdSJiri Pirko DEVLINK_ATTR_SB_OCC_MAX, /* u32 */ 15808f4b591SOr Gerlitz DEVLINK_ATTR_ESWITCH_MODE, /* u16 */ 15959bfde01SRoi Dayan DEVLINK_ATTR_ESWITCH_INLINE_MODE, /* u8 */ 160bfcd3a46SJiri Pirko 1611555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLES, /* nested */ 1621555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLE, /* nested */ 1631555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLE_NAME, /* string */ 1641555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLE_SIZE, /* u64 */ 1651555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLE_MATCHES, /* nested */ 1661555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLE_ACTIONS, /* nested */ 1671555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_TABLE_COUNTERS_ENABLED, /* u8 */ 1681555d204SArkadi Sharshevsky 1691555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ENTRIES, /* nested */ 1701555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ENTRY, /* nested */ 1711555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ENTRY_INDEX, /* u64 */ 1721555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ENTRY_MATCH_VALUES, /* nested */ 1731555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ENTRY_ACTION_VALUES, /* nested */ 1741555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ENTRY_COUNTER, /* u64 */ 1751555d204SArkadi Sharshevsky 1761555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_MATCH, /* nested */ 1771555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_MATCH_VALUE, /* nested */ 1781555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_MATCH_TYPE, /* u32 */ 1791555d204SArkadi Sharshevsky 1801555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ACTION, /* nested */ 1811555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ACTION_VALUE, /* nested */ 1821555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_ACTION_TYPE, /* u32 */ 1831555d204SArkadi Sharshevsky 1841555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_VALUE, 1851555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_VALUE_MASK, 1861555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_VALUE_MAPPING, /* u32 */ 1871555d204SArkadi Sharshevsky 1881555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADERS, /* nested */ 1891555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADER, /* nested */ 1901555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADER_NAME, /* string */ 1911555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADER_ID, /* u32 */ 1921555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADER_FIELDS, /* nested */ 1931555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADER_GLOBAL, /* u8 */ 1941555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_HEADER_INDEX, /* u32 */ 1951555d204SArkadi Sharshevsky 1961555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_FIELD, /* nested */ 1971555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_FIELD_NAME, /* string */ 1981555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_FIELD_ID, /* u32 */ 1991555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_FIELD_BITWIDTH, /* u32 */ 2001555d204SArkadi Sharshevsky DEVLINK_ATTR_DPIPE_FIELD_MAPPING_TYPE, /* u32 */ 2011555d204SArkadi Sharshevsky 2021555d204SArkadi Sharshevsky DEVLINK_ATTR_PAD, 2031555d204SArkadi Sharshevsky 204f43e9b06SRoi Dayan DEVLINK_ATTR_ESWITCH_ENCAP_MODE, /* u8 */ 205f43e9b06SRoi Dayan 206bfcd3a46SJiri Pirko /* add new attributes above here, update the policy in devlink.c */ 207bfcd3a46SJiri Pirko 208bfcd3a46SJiri Pirko __DEVLINK_ATTR_MAX, 209bfcd3a46SJiri Pirko DEVLINK_ATTR_MAX = __DEVLINK_ATTR_MAX - 1 210bfcd3a46SJiri Pirko }; 211bfcd3a46SJiri Pirko 2121555d204SArkadi Sharshevsky /* Mapping between internal resource described by the field and system 2131555d204SArkadi Sharshevsky * structure 2141555d204SArkadi Sharshevsky */ 2151555d204SArkadi Sharshevsky enum devlink_dpipe_field_mapping_type { 2161555d204SArkadi Sharshevsky DEVLINK_DPIPE_FIELD_MAPPING_TYPE_NONE, 2171555d204SArkadi Sharshevsky DEVLINK_DPIPE_FIELD_MAPPING_TYPE_IFINDEX, 2181555d204SArkadi Sharshevsky }; 2191555d204SArkadi Sharshevsky 2201555d204SArkadi Sharshevsky /* Match type - specify the type of the match */ 2211555d204SArkadi Sharshevsky enum devlink_dpipe_match_type { 2221555d204SArkadi Sharshevsky DEVLINK_DPIPE_MATCH_TYPE_FIELD_EXACT, 2231555d204SArkadi Sharshevsky }; 2241555d204SArkadi Sharshevsky 2251555d204SArkadi Sharshevsky /* Action type - specify the action type */ 2261555d204SArkadi Sharshevsky enum devlink_dpipe_action_type { 2271555d204SArkadi Sharshevsky DEVLINK_DPIPE_ACTION_TYPE_FIELD_MODIFY, 2281555d204SArkadi Sharshevsky }; 2291555d204SArkadi Sharshevsky 23011770091SArkadi Sharshevsky enum devlink_dpipe_field_ethernet_id { 23111770091SArkadi Sharshevsky DEVLINK_DPIPE_FIELD_ETHERNET_DST_MAC, 23211770091SArkadi Sharshevsky }; 23311770091SArkadi Sharshevsky 2343fb886ecSArkadi Sharshevsky enum devlink_dpipe_field_ipv4_id { 2353fb886ecSArkadi Sharshevsky DEVLINK_DPIPE_FIELD_IPV4_DST_IP, 2363fb886ecSArkadi Sharshevsky }; 2373fb886ecSArkadi Sharshevsky 2381797f5b3SArkadi Sharshevsky enum devlink_dpipe_field_ipv6_id { 2391797f5b3SArkadi Sharshevsky DEVLINK_DPIPE_FIELD_IPV6_DST_IP, 2401797f5b3SArkadi Sharshevsky }; 2411797f5b3SArkadi Sharshevsky 24211770091SArkadi Sharshevsky enum devlink_dpipe_header_id { 24311770091SArkadi Sharshevsky DEVLINK_DPIPE_HEADER_ETHERNET, 2443fb886ecSArkadi Sharshevsky DEVLINK_DPIPE_HEADER_IPV4, 2451797f5b3SArkadi Sharshevsky DEVLINK_DPIPE_HEADER_IPV6, 24611770091SArkadi Sharshevsky }; 24711770091SArkadi Sharshevsky 248bfcd3a46SJiri Pirko #endif /* _UAPI_LINUX_DEVLINK_H_ */ 249