提交 055b2b78 编写于 作者: H Hao Chen 提交者: Zheng Zengkai

net: hns3: add support to set/get tx copybreak buf size via ethtool for hns3 driver

mainline inclusion
from mainline-master
commit e445f08a
category: feature
bugzilla: https://gitee.com/openeuler/kernel/issues/I4M1HB
CVE: NA

Reference: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=e445f08af2b1

----------------------------------------------------------------------

Tx copybreak buf size is used for tx copybreak feature, the feature is
used for small size packet or frag. It adds a queue based tx shared
bounce buffer to memcpy the small packet when the len of xmitted skb is
below tx_copybreak(value to distinguish small size and normal size),
and reduce the overhead of dma map and unmap when IOMMU is on.

Support setting it via ethtool --set-tunable parameter and getting
it via ethtool --get-tunable parameter.
Signed-off-by: NHao Chen <chenhao288@hisilicon.com>
Signed-off-by: NGuangbin Huang <huangguangbin2@huawei.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
Reviewed-by: NYongxin Li <liyongxin1@huawei.com>
Signed-off-by: NJunxin Chen <chenjunxin1@huawei.com>
Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
上级 3ccbb88e
...@@ -5531,8 +5531,8 @@ static int hns3_reset_notify_uninit_enet(struct hnae3_handle *handle) ...@@ -5531,8 +5531,8 @@ static int hns3_reset_notify_uninit_enet(struct hnae3_handle *handle)
return 0; return 0;
} }
static int hns3_reset_notify(struct hnae3_handle *handle, int hns3_reset_notify(struct hnae3_handle *handle,
enum hnae3_reset_notify_type type) enum hnae3_reset_notify_type type)
{ {
int ret = 0; int ret = 0;
......
...@@ -705,6 +705,8 @@ void hns3_set_vector_coalesce_tx_ql(struct hns3_enet_tqp_vector *tqp_vector, ...@@ -705,6 +705,8 @@ void hns3_set_vector_coalesce_tx_ql(struct hns3_enet_tqp_vector *tqp_vector,
u32 ql_value); u32 ql_value);
void hns3_request_update_promisc_mode(struct hnae3_handle *handle); void hns3_request_update_promisc_mode(struct hnae3_handle *handle);
int hns3_reset_notify(struct hnae3_handle *handle,
enum hnae3_reset_notify_type type);
#ifdef CONFIG_HNS3_DCB #ifdef CONFIG_HNS3_DCB
void hns3_dcbnl_setup(struct hnae3_handle *handle); void hns3_dcbnl_setup(struct hnae3_handle *handle);
......
...@@ -1695,6 +1695,7 @@ static int hns3_get_tunable(struct net_device *netdev, ...@@ -1695,6 +1695,7 @@ static int hns3_get_tunable(struct net_device *netdev,
void *data) void *data)
{ {
struct hns3_nic_priv *priv = netdev_priv(netdev); struct hns3_nic_priv *priv = netdev_priv(netdev);
struct hnae3_handle *h = priv->ae_handle;
int ret = 0; int ret = 0;
switch (tuna->id) { switch (tuna->id) {
...@@ -1705,6 +1706,9 @@ static int hns3_get_tunable(struct net_device *netdev, ...@@ -1705,6 +1706,9 @@ static int hns3_get_tunable(struct net_device *netdev,
case ETHTOOL_RX_COPYBREAK: case ETHTOOL_RX_COPYBREAK:
*(u32 *)data = priv->rx_copybreak; *(u32 *)data = priv->rx_copybreak;
break; break;
case ETHTOOL_TX_COPYBREAK_BUF_SIZE:
*(u32 *)data = h->kinfo.tx_spare_buf_size;
break;
default: default:
ret = -EOPNOTSUPP; ret = -EOPNOTSUPP;
break; break;
...@@ -1713,11 +1717,43 @@ static int hns3_get_tunable(struct net_device *netdev, ...@@ -1713,11 +1717,43 @@ static int hns3_get_tunable(struct net_device *netdev,
return ret; return ret;
} }
static int hns3_set_tx_spare_buf_size(struct net_device *netdev,
u32 data)
{
struct hns3_nic_priv *priv = netdev_priv(netdev);
struct hnae3_handle *h = priv->ae_handle;
int ret;
if (hns3_nic_resetting(netdev))
return -EBUSY;
h->kinfo.tx_spare_buf_size = data;
ret = hns3_reset_notify(h, HNAE3_DOWN_CLIENT);
if (ret)
return ret;
ret = hns3_reset_notify(h, HNAE3_UNINIT_CLIENT);
if (ret)
return ret;
ret = hns3_reset_notify(h, HNAE3_INIT_CLIENT);
if (ret)
return ret;
ret = hns3_reset_notify(h, HNAE3_UP_CLIENT);
if (ret)
hns3_reset_notify(h, HNAE3_UNINIT_CLIENT);
return ret;
}
static int hns3_set_tunable(struct net_device *netdev, static int hns3_set_tunable(struct net_device *netdev,
const struct ethtool_tunable *tuna, const struct ethtool_tunable *tuna,
const void *data) const void *data)
{ {
struct hns3_nic_priv *priv = netdev_priv(netdev); struct hns3_nic_priv *priv = netdev_priv(netdev);
u32 old_tx_spare_buf_size, new_tx_spare_buf_size;
struct hnae3_handle *h = priv->ae_handle; struct hnae3_handle *h = priv->ae_handle;
int i, ret = 0; int i, ret = 0;
...@@ -1735,6 +1771,26 @@ static int hns3_set_tunable(struct net_device *netdev, ...@@ -1735,6 +1771,26 @@ static int hns3_set_tunable(struct net_device *netdev,
for (i = h->kinfo.num_tqps; i < h->kinfo.num_tqps * 2; i++) for (i = h->kinfo.num_tqps; i < h->kinfo.num_tqps * 2; i++)
priv->ring[i].rx_copybreak = priv->rx_copybreak; priv->ring[i].rx_copybreak = priv->rx_copybreak;
break;
case ETHTOOL_TX_COPYBREAK_BUF_SIZE:
old_tx_spare_buf_size = h->kinfo.tx_spare_buf_size;
new_tx_spare_buf_size = *(u32 *)data;
ret = hns3_set_tx_spare_buf_size(netdev, new_tx_spare_buf_size);
if (ret) {
int ret1;
netdev_warn(netdev,
"change tx spare buf size fail, revert to old value\n");
ret1 = hns3_set_tx_spare_buf_size(netdev,
old_tx_spare_buf_size);
if (ret1) {
netdev_err(netdev,
"revert to old tx spare buf size fail\n");
return ret1;
}
return ret;
}
break; break;
default: default:
ret = -EOPNOTSUPP; ret = -EOPNOTSUPP;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册