[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <561B0C11.9030800@hisilicon.com>
Date: Mon, 12 Oct 2015 09:25:37 +0800
From: huangdaode <huangdaode@...ilicon.com>
To: Joe Perches <joe@...ches.com>
CC: Arnd Bergmann <arnd@...db.de>, <netdev@...r.kernel.org>,
<davem@...emloft.net>, Kenneth Lee <liguozhu@...wei.com>,
Yisen Zhuang <Yisen.Zhuang@...wei.com>
Subject: Re: [PATCH] net: nhs: fix 32-bit build warning
On 2015/10/12 4:13, Joe Perches wrote:
> On Tue, 2015-10-06 at 23:53 +0200, Arnd Bergmann wrote:
>> diff --git a/drivers/net/ethernet/hisilicon/hns/hnae.c b/drivers/net/ethernet/hisilicon/hns/hnae.c
> []
>> @@ -448,12 +448,12 @@ static ssize_t handles_show(struct device *dev,
>> s += sprintf(buf + s, "handle %d (eport_id=%u from %s):\n",
>> i++, h->eport_id, h->dev->name);
>> for (j = 0; j < h->q_num; j++) {
>> - s += sprintf(buf + s, "\tqueue[%d] on 0x%llx\n",
>> - j, (u64)h->qs[i]->io_base);
>> -#define HANDEL_TX_MSG "\t\ttx_ring on 0x%llx:%u,%u,%u,%u,%u,%llu,%llu\n"
>> + s += sprintf(buf + s, "\tqueue[%d] on %p\n",
>> + j, h->qs[i]->io_base);
>> +#define HANDEL_TX_MSG "\t\ttx_ring on %p:%u,%u,%u,%u,%u,%llu,%llu\n"
>> s += sprintf(buf + s,
>> HANDEL_TX_MSG,
> Maybe one day remove the misspelled and
> used once HANDEL_TX_MSG macro too.
>
> Another possibility is to use a generally
> smaller object code style like:
>
> char *s = buf;
> ...
> s += sprintf(s, ...)
> ...
> return s - buf;
>
> instead of
>
> ssize_t s = 0;
> ...
> s += sprintf(buf + s, ...)
> ...
> return s;
> ---
> drivers/net/ethernet/hisilicon/hns/hnae.c | 35 +++++++++++++++----------------
> 1 file changed, 17 insertions(+), 18 deletions(-)
>
> diff --git a/drivers/net/ethernet/hisilicon/hns/hnae.c b/drivers/net/ethernet/hisilicon/hns/hnae.c
> index f52e99a..d2af46f 100644
> --- a/drivers/net/ethernet/hisilicon/hns/hnae.c
> +++ b/drivers/net/ethernet/hisilicon/hns/hnae.c
> @@ -439,40 +439,39 @@ EXPORT_SYMBOL(hnae_ae_unregister);
> static ssize_t handles_show(struct device *dev,
> struct device_attribute *attr, char *buf)
> {
> - ssize_t s = 0;
> + char *s = buf;
> struct hnae_ae_dev *hdev = cls_to_ae_dev(dev);
> struct hnae_handle *h;
> int i = 0, j;
>
> list_for_each_entry_rcu(h, &hdev->handle_list, node) {
> - s += sprintf(buf + s, "handle %d (eport_id=%u from %s):\n",
> - i++, h->eport_id, h->dev->name);
> + s += sprintf(s, "handle %d (eport_id=%u from %s):\n",
> + i++, h->eport_id, h->dev->name);
> for (j = 0; j < h->q_num; j++) {
> - s += sprintf(buf + s, "\tqueue[%d] on %p\n",
> + s += sprintf(s, "\tqueue[%d] on %p\n",
> j, h->qs[i]->io_base);
> -#define HANDEL_TX_MSG "\t\ttx_ring on %p:%u,%u,%u,%u,%u,%llu,%llu\n"
> - s += sprintf(buf + s,
> - HANDEL_TX_MSG,
> + s += sprintf(s,
> + "\t\ttx_ring on %p:%u,%u,%u,%u,%u,%llu,%llu\n",
> h->qs[i]->tx_ring.io_base,
> h->qs[i]->tx_ring.buf_size,
> h->qs[i]->tx_ring.desc_num,
> h->qs[i]->tx_ring.max_desc_num_per_pkt,
> h->qs[i]->tx_ring.max_raw_data_sz_per_desc,
> h->qs[i]->tx_ring.max_pkt_size,
> - h->qs[i]->tx_ring.stats.sw_err_cnt,
> - h->qs[i]->tx_ring.stats.io_err_cnt);
> - s += sprintf(buf + s,
> - "\t\trx_ring on %p:%u,%u,%llu,%llu,%llu\n",
> - h->qs[i]->rx_ring.io_base,
> - h->qs[i]->rx_ring.buf_size,
> - h->qs[i]->rx_ring.desc_num,
> - h->qs[i]->rx_ring.stats.sw_err_cnt,
> - h->qs[i]->rx_ring.stats.io_err_cnt,
> - h->qs[i]->rx_ring.stats.seg_pkt_cnt);
> + h->qs[i]->tx_ring.stats.sw_err_cnt,
> + h->qs[i]->tx_ring.stats.io_err_cnt);
> + s += sprintf(s,
> + "\t\trx_ring on %p:%u,%u,%llu,%llu,%llu\n",
> + h->qs[i]->rx_ring.io_base,
> + h->qs[i]->rx_ring.buf_size,
> + h->qs[i]->rx_ring.desc_num,
> + h->qs[i]->rx_ring.stats.sw_err_cnt,
> + h->qs[i]->rx_ring.stats.io_err_cnt,
> + h->qs[i]->rx_ring.stats.seg_pkt_cnt);
> }
> }
>
> - return s;
> + return s - buf;
> }
>
> static DEVICE_ATTR_RO(handles);
>
>
>
> .
>
thanks Joe
your suggestion is good, will send out a patch to fix it.
--
Best Regards
Daode Huang
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists