Back to home page

OSCL-LXR

 
 

    


0001 /* SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB */
0002 /* Copyright (c) 2021, NVIDIA CORPORATION & AFFILIATES. All rights reserved. */
0003 
0004 #ifndef __MLX5_ESW_QOS_H__
0005 #define __MLX5_ESW_QOS_H__
0006 
0007 #ifdef CONFIG_MLX5_ESWITCH
0008 
0009 int mlx5_esw_qos_set_vport_rate(struct mlx5_eswitch *esw, struct mlx5_vport *evport,
0010                 u32 max_rate, u32 min_rate);
0011 void mlx5_esw_qos_vport_disable(struct mlx5_eswitch *esw, struct mlx5_vport *vport);
0012 
0013 int mlx5_esw_devlink_rate_leaf_tx_share_set(struct devlink_rate *rate_leaf, void *priv,
0014                         u64 tx_share, struct netlink_ext_ack *extack);
0015 int mlx5_esw_devlink_rate_leaf_tx_max_set(struct devlink_rate *rate_leaf, void *priv,
0016                       u64 tx_max, struct netlink_ext_ack *extack);
0017 int mlx5_esw_devlink_rate_node_tx_share_set(struct devlink_rate *rate_node, void *priv,
0018                         u64 tx_share, struct netlink_ext_ack *extack);
0019 int mlx5_esw_devlink_rate_node_tx_max_set(struct devlink_rate *rate_node, void *priv,
0020                       u64 tx_max, struct netlink_ext_ack *extack);
0021 int mlx5_esw_devlink_rate_node_new(struct devlink_rate *rate_node, void **priv,
0022                    struct netlink_ext_ack *extack);
0023 int mlx5_esw_devlink_rate_node_del(struct devlink_rate *rate_node, void *priv,
0024                    struct netlink_ext_ack *extack);
0025 int mlx5_esw_devlink_rate_parent_set(struct devlink_rate *devlink_rate,
0026                      struct devlink_rate *parent,
0027                      void *priv, void *parent_priv,
0028                      struct netlink_ext_ack *extack);
0029 #endif
0030 
0031 #endif