Message ID | 20241022203240.391648-1-rosenp@gmail.com (mailing list archive) |
---|---|
State | Accepted |
Commit | 89abb6b3bd7b01f2ce5221189d84e938734f7f6e |
Delegated to: | Netdev Maintainers |
Headers | show |
Series | [net-next] ibmvnic: use ethtool string helpers | expand |
On 10/22/24 15:32, Rosen Penev wrote: > They are the prefered way to copy ethtool strings. > > Avoids manually incrementing the data pointer. > > Signed-off-by: Rosen Penev <rosenp@gmail.com> > --- > drivers/net/ethernet/ibm/ibmvnic.c | 30 +++++++++--------------------- > 1 file changed, 9 insertions(+), 21 deletions(-) > > diff --git a/drivers/net/ethernet/ibm/ibmvnic.c b/drivers/net/ethernet/ibm/ibmvnic.c > index cca2ed6ad289..e95ae0d39948 100644 > --- a/drivers/net/ethernet/ibm/ibmvnic.c > +++ b/drivers/net/ethernet/ibm/ibmvnic.c > @@ -3808,32 +3808,20 @@ static void ibmvnic_get_strings(struct net_device *dev, u32 stringset, u8 *data) > if (stringset != ETH_SS_STATS) > return; > > - for (i = 0; i < ARRAY_SIZE(ibmvnic_stats); i++, data += ETH_GSTRING_LEN) > - memcpy(data, ibmvnic_stats[i].name, ETH_GSTRING_LEN); > + for (i = 0; i < ARRAY_SIZE(ibmvnic_stats); i++) > + ethtool_puts(&data, ibmvnic_stats[i].name); > > for (i = 0; i < adapter->req_tx_queues; i++) { > - snprintf(data, ETH_GSTRING_LEN, "tx%d_batched_packets", i); > - data += ETH_GSTRING_LEN; > - > - snprintf(data, ETH_GSTRING_LEN, "tx%d_direct_packets", i); > - data += ETH_GSTRING_LEN; > - > - snprintf(data, ETH_GSTRING_LEN, "tx%d_bytes", i); > - data += ETH_GSTRING_LEN; > - > - snprintf(data, ETH_GSTRING_LEN, "tx%d_dropped_packets", i); > - data += ETH_GSTRING_LEN; > + ethtool_sprintf(&data, "tx%d_batched_packets", i); > + ethtool_sprintf(&data, "tx%d_direct_packets", i); > + ethtool_sprintf(&data, "tx%d_bytes", i); > + ethtool_sprintf(&data, "tx%d_dropped_packets", i); > } > > for (i = 0; i < adapter->req_rx_queues; i++) { > - snprintf(data, ETH_GSTRING_LEN, "rx%d_packets", i); > - data += ETH_GSTRING_LEN; > - > - snprintf(data, ETH_GSTRING_LEN, "rx%d_bytes", i); > - data += ETH_GSTRING_LEN; > - > - snprintf(data, ETH_GSTRING_LEN, "rx%d_interrupts", i); > - data += ETH_GSTRING_LEN; > + ethtool_sprintf(&data, "rx%d_packets", i); > + ethtool_sprintf(&data, "rx%d_bytes", i); > + ethtool_sprintf(&data, "rx%d_interrupts", i); > } > } > Tested-by: Nick Child <nnac123@linux.ibm.com>
On Tue, Oct 22, 2024 at 01:32:40PM -0700, Rosen Penev wrote: > They are the prefered way to copy ethtool strings. > > Avoids manually incrementing the data pointer. > > Signed-off-by: Rosen Penev <rosenp@gmail.com> Reviewed-by: Simon Horman <horms@kernel.org>
Hello: This patch was applied to netdev/net-next.git (main) by Jakub Kicinski <kuba@kernel.org>: On Tue, 22 Oct 2024 13:32:40 -0700 you wrote: > They are the prefered way to copy ethtool strings. > > Avoids manually incrementing the data pointer. > > Signed-off-by: Rosen Penev <rosenp@gmail.com> > --- > drivers/net/ethernet/ibm/ibmvnic.c | 30 +++++++++--------------------- > 1 file changed, 9 insertions(+), 21 deletions(-) Here is the summary with links: - [net-next] ibmvnic: use ethtool string helpers https://git.kernel.org/netdev/net-next/c/89abb6b3bd7b You are awesome, thank you!
diff --git a/drivers/net/ethernet/ibm/ibmvnic.c b/drivers/net/ethernet/ibm/ibmvnic.c index cca2ed6ad289..e95ae0d39948 100644 --- a/drivers/net/ethernet/ibm/ibmvnic.c +++ b/drivers/net/ethernet/ibm/ibmvnic.c @@ -3808,32 +3808,20 @@ static void ibmvnic_get_strings(struct net_device *dev, u32 stringset, u8 *data) if (stringset != ETH_SS_STATS) return; - for (i = 0; i < ARRAY_SIZE(ibmvnic_stats); i++, data += ETH_GSTRING_LEN) - memcpy(data, ibmvnic_stats[i].name, ETH_GSTRING_LEN); + for (i = 0; i < ARRAY_SIZE(ibmvnic_stats); i++) + ethtool_puts(&data, ibmvnic_stats[i].name); for (i = 0; i < adapter->req_tx_queues; i++) { - snprintf(data, ETH_GSTRING_LEN, "tx%d_batched_packets", i); - data += ETH_GSTRING_LEN; - - snprintf(data, ETH_GSTRING_LEN, "tx%d_direct_packets", i); - data += ETH_GSTRING_LEN; - - snprintf(data, ETH_GSTRING_LEN, "tx%d_bytes", i); - data += ETH_GSTRING_LEN; - - snprintf(data, ETH_GSTRING_LEN, "tx%d_dropped_packets", i); - data += ETH_GSTRING_LEN; + ethtool_sprintf(&data, "tx%d_batched_packets", i); + ethtool_sprintf(&data, "tx%d_direct_packets", i); + ethtool_sprintf(&data, "tx%d_bytes", i); + ethtool_sprintf(&data, "tx%d_dropped_packets", i); } for (i = 0; i < adapter->req_rx_queues; i++) { - snprintf(data, ETH_GSTRING_LEN, "rx%d_packets", i); - data += ETH_GSTRING_LEN; - - snprintf(data, ETH_GSTRING_LEN, "rx%d_bytes", i); - data += ETH_GSTRING_LEN; - - snprintf(data, ETH_GSTRING_LEN, "rx%d_interrupts", i); - data += ETH_GSTRING_LEN; + ethtool_sprintf(&data, "rx%d_packets", i); + ethtool_sprintf(&data, "rx%d_bytes", i); + ethtool_sprintf(&data, "rx%d_interrupts", i); } }
They are the prefered way to copy ethtool strings. Avoids manually incrementing the data pointer. Signed-off-by: Rosen Penev <rosenp@gmail.com> --- drivers/net/ethernet/ibm/ibmvnic.c | 30 +++++++++--------------------- 1 file changed, 9 insertions(+), 21 deletions(-)