1bfcd3a46SJiri Pirko /* 2bfcd3a46SJiri Pirko * include/uapi/linux/devlink.h - Network physical device Netlink interface 3bfcd3a46SJiri Pirko * Copyright (c) 2016 Mellanox Technologies. All rights reserved. 4bfcd3a46SJiri Pirko * Copyright (c) 2016 Jiri Pirko <[email protected]> 5bfcd3a46SJiri Pirko * 6bfcd3a46SJiri Pirko * This program is free software; you can redistribute it and/or modify 7bfcd3a46SJiri Pirko * it under the terms of the GNU General Public License as published by 8bfcd3a46SJiri Pirko * the Free Software Foundation; either version 2 of the License, or 9bfcd3a46SJiri Pirko * (at your option) any later version. 10bfcd3a46SJiri Pirko */ 11bfcd3a46SJiri Pirko 12bfcd3a46SJiri Pirko #ifndef _UAPI_LINUX_DEVLINK_H_ 13bfcd3a46SJiri Pirko #define _UAPI_LINUX_DEVLINK_H_ 14bfcd3a46SJiri Pirko 15bfcd3a46SJiri Pirko #define DEVLINK_GENL_NAME "devlink" 16bfcd3a46SJiri Pirko #define DEVLINK_GENL_VERSION 0x1 17bfcd3a46SJiri Pirko #define DEVLINK_GENL_MCGRP_CONFIG_NAME "config" 18bfcd3a46SJiri Pirko 19bfcd3a46SJiri Pirko enum devlink_command { 20bfcd3a46SJiri Pirko /* don't change the order or add anything between, this is ABI! */ 21bfcd3a46SJiri Pirko DEVLINK_CMD_UNSPEC, 22bfcd3a46SJiri Pirko 23bfcd3a46SJiri Pirko DEVLINK_CMD_GET, /* can dump */ 24bfcd3a46SJiri Pirko DEVLINK_CMD_SET, 25bfcd3a46SJiri Pirko DEVLINK_CMD_NEW, 26bfcd3a46SJiri Pirko DEVLINK_CMD_DEL, 27bfcd3a46SJiri Pirko 28bfcd3a46SJiri Pirko DEVLINK_CMD_PORT_GET, /* can dump */ 29bfcd3a46SJiri Pirko DEVLINK_CMD_PORT_SET, 30bfcd3a46SJiri Pirko DEVLINK_CMD_PORT_NEW, 31bfcd3a46SJiri Pirko DEVLINK_CMD_PORT_DEL, 32bfcd3a46SJiri Pirko 33bfcd3a46SJiri Pirko DEVLINK_CMD_PORT_SPLIT, 34bfcd3a46SJiri Pirko DEVLINK_CMD_PORT_UNSPLIT, 35bfcd3a46SJiri Pirko 36*bf797471SJiri Pirko DEVLINK_CMD_SB_GET, /* can dump */ 37*bf797471SJiri Pirko DEVLINK_CMD_SB_SET, 38*bf797471SJiri Pirko DEVLINK_CMD_SB_NEW, 39*bf797471SJiri Pirko DEVLINK_CMD_SB_DEL, 40*bf797471SJiri Pirko 41*bf797471SJiri Pirko DEVLINK_CMD_SB_POOL_GET, /* can dump */ 42*bf797471SJiri Pirko DEVLINK_CMD_SB_POOL_SET, 43*bf797471SJiri Pirko DEVLINK_CMD_SB_POOL_NEW, 44*bf797471SJiri Pirko DEVLINK_CMD_SB_POOL_DEL, 45*bf797471SJiri Pirko 46*bf797471SJiri Pirko DEVLINK_CMD_SB_PORT_POOL_GET, /* can dump */ 47*bf797471SJiri Pirko DEVLINK_CMD_SB_PORT_POOL_SET, 48*bf797471SJiri Pirko DEVLINK_CMD_SB_PORT_POOL_NEW, 49*bf797471SJiri Pirko DEVLINK_CMD_SB_PORT_POOL_DEL, 50*bf797471SJiri Pirko 51*bf797471SJiri Pirko DEVLINK_CMD_SB_TC_POOL_BIND_GET, /* can dump */ 52*bf797471SJiri Pirko DEVLINK_CMD_SB_TC_POOL_BIND_SET, 53*bf797471SJiri Pirko DEVLINK_CMD_SB_TC_POOL_BIND_NEW, 54*bf797471SJiri Pirko DEVLINK_CMD_SB_TC_POOL_BIND_DEL, 55*bf797471SJiri Pirko 56bfcd3a46SJiri Pirko /* add new commands above here */ 57bfcd3a46SJiri Pirko 58bfcd3a46SJiri Pirko __DEVLINK_CMD_MAX, 59bfcd3a46SJiri Pirko DEVLINK_CMD_MAX = __DEVLINK_CMD_MAX - 1 60bfcd3a46SJiri Pirko }; 61bfcd3a46SJiri Pirko 62bfcd3a46SJiri Pirko enum devlink_port_type { 63bfcd3a46SJiri Pirko DEVLINK_PORT_TYPE_NOTSET, 64bfcd3a46SJiri Pirko DEVLINK_PORT_TYPE_AUTO, 65bfcd3a46SJiri Pirko DEVLINK_PORT_TYPE_ETH, 66bfcd3a46SJiri Pirko DEVLINK_PORT_TYPE_IB, 67bfcd3a46SJiri Pirko }; 68bfcd3a46SJiri Pirko 69*bf797471SJiri Pirko enum devlink_sb_pool_type { 70*bf797471SJiri Pirko DEVLINK_SB_POOL_TYPE_INGRESS, 71*bf797471SJiri Pirko DEVLINK_SB_POOL_TYPE_EGRESS, 72*bf797471SJiri Pirko }; 73*bf797471SJiri Pirko 74*bf797471SJiri Pirko /* static threshold - limiting the maximum number of bytes. 75*bf797471SJiri Pirko * dynamic threshold - limiting the maximum number of bytes 76*bf797471SJiri Pirko * based on the currently available free space in the shared buffer pool. 77*bf797471SJiri Pirko * In this mode, the maximum quota is calculated based 78*bf797471SJiri Pirko * on the following formula: 79*bf797471SJiri Pirko * max_quota = alpha / (1 + alpha) * Free_Buffer 80*bf797471SJiri Pirko * While Free_Buffer is the amount of none-occupied buffer associated to 81*bf797471SJiri Pirko * the relevant pool. 82*bf797471SJiri Pirko * The value range which can be passed is 0-20 and serves 83*bf797471SJiri Pirko * for computation of alpha by following formula: 84*bf797471SJiri Pirko * alpha = 2 ^ (passed_value - 10) 85*bf797471SJiri Pirko */ 86*bf797471SJiri Pirko 87*bf797471SJiri Pirko enum devlink_sb_threshold_type { 88*bf797471SJiri Pirko DEVLINK_SB_THRESHOLD_TYPE_STATIC, 89*bf797471SJiri Pirko DEVLINK_SB_THRESHOLD_TYPE_DYNAMIC, 90*bf797471SJiri Pirko }; 91*bf797471SJiri Pirko 92*bf797471SJiri Pirko #define DEVLINK_SB_THRESHOLD_TO_ALPHA_MAX 20 93*bf797471SJiri Pirko 94bfcd3a46SJiri Pirko enum devlink_attr { 95bfcd3a46SJiri Pirko /* don't change the order or add anything between, this is ABI! */ 96bfcd3a46SJiri Pirko DEVLINK_ATTR_UNSPEC, 97bfcd3a46SJiri Pirko 98bfcd3a46SJiri Pirko /* bus name + dev name together are a handle for devlink entity */ 99bfcd3a46SJiri Pirko DEVLINK_ATTR_BUS_NAME, /* string */ 100bfcd3a46SJiri Pirko DEVLINK_ATTR_DEV_NAME, /* string */ 101bfcd3a46SJiri Pirko 102bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_INDEX, /* u32 */ 103bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_TYPE, /* u16 */ 104bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_DESIRED_TYPE, /* u16 */ 105bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_NETDEV_IFINDEX, /* u32 */ 106bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_NETDEV_NAME, /* string */ 107bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_IBDEV_NAME, /* string */ 108bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_SPLIT_COUNT, /* u32 */ 109bfcd3a46SJiri Pirko DEVLINK_ATTR_PORT_SPLIT_GROUP, /* u32 */ 110*bf797471SJiri Pirko DEVLINK_ATTR_SB_INDEX, /* u32 */ 111*bf797471SJiri Pirko DEVLINK_ATTR_SB_SIZE, /* u32 */ 112*bf797471SJiri Pirko DEVLINK_ATTR_SB_INGRESS_POOL_COUNT, /* u16 */ 113*bf797471SJiri Pirko DEVLINK_ATTR_SB_EGRESS_POOL_COUNT, /* u16 */ 114*bf797471SJiri Pirko DEVLINK_ATTR_SB_INGRESS_TC_COUNT, /* u16 */ 115*bf797471SJiri Pirko DEVLINK_ATTR_SB_EGRESS_TC_COUNT, /* u16 */ 116*bf797471SJiri Pirko DEVLINK_ATTR_SB_POOL_INDEX, /* u16 */ 117*bf797471SJiri Pirko DEVLINK_ATTR_SB_POOL_TYPE, /* u8 */ 118*bf797471SJiri Pirko DEVLINK_ATTR_SB_POOL_SIZE, /* u32 */ 119*bf797471SJiri Pirko DEVLINK_ATTR_SB_POOL_THRESHOLD_TYPE, /* u8 */ 120*bf797471SJiri Pirko DEVLINK_ATTR_SB_THRESHOLD, /* u32 */ 121*bf797471SJiri Pirko DEVLINK_ATTR_SB_TC_INDEX, /* u16 */ 122bfcd3a46SJiri Pirko 123bfcd3a46SJiri Pirko /* add new attributes above here, update the policy in devlink.c */ 124bfcd3a46SJiri Pirko 125bfcd3a46SJiri Pirko __DEVLINK_ATTR_MAX, 126bfcd3a46SJiri Pirko DEVLINK_ATTR_MAX = __DEVLINK_ATTR_MAX - 1 127bfcd3a46SJiri Pirko }; 128bfcd3a46SJiri Pirko 129bfcd3a46SJiri Pirko #endif /* _UAPI_LINUX_DEVLINK_H_ */ 130