Re: Fwd: Re: [PATCH net-next v2 1/2] hisilicon net: removes the once HANDEL_TX_MSG macro

From: Kenneth Lee
Date: Tue Oct 13 2015 - 09:27:31 EST


On Tue, Oct 13, 2015 at 03:06:21PM +0800, huangdaode wrote:
> Date: Tue, 13 Oct 2015 15:06:21 +0800
> From: huangdaode <huangdaode@xxxxxxxxxxxxx>
> To: Kenneth Lee <kenneth_lee_2012@xxxxxxx>
> Subject: Fwd: Re: [PATCH net-next v2 1/2] hisilicon net: removes the once
> HANDEL_TX_MSG macro
> Message-ID: <561CAD6D.2060105@xxxxxxxxxxxxx>
>
> -------- Forwarded Message --------
>
> Subject: Re: [PATCH net-next v2 1/2] hisilicon net: removes the once
> HANDEL_TX_MSG macro
> Date: Mon, 12 Oct 2015 13:59:39 +0200
> From: Arnd Bergmann <arnd@xxxxxxxx>
> To: huangdaode <huangdaode@xxxxxxxxxxxxx>
> CC: davem@xxxxxxxxxxxxx, joe@xxxxxxxxxxx, liguozhu@xxxxxxxxxxxxx,
> Yisen.Zhuang@xxxxxxxxxx, netdev@xxxxxxxxxxxxxxx,
> linuxarm@xxxxxxxxxx, salil.mehta@xxxxxxxxxx,
> kenneth-lee-2012@xxxxxxxxxxx, xuwei5@xxxxxxxxxxxxx,
> lisheng011@xxxxxxxxxx, linux-kernel@xxxxxxxxxxxxxxx
>
> On Monday 12 October 2015 11:23:44 huangdaode wrote:
> > + 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);
>
> There is actually a more significant problem with this code, which I
> failed to notice when doing the original bugfix:
>
> You have a sysfs interface here that exports internal data of the
> device that should not be visible like this. One problem is that
> the io_base is a kernel pointer that must not be visible to non-root
> users (so we don't easily create an attack surface for exploits).
> Another problem is that the format is not documented in Documentation/ABI/
> and that you have multiple values in one sysfs file here.
>
> It would probably be better to completely remove that sysfs interface, and
> to use the ethtool netlink interface to export them.
>
> Arnd
>
> .

Hi, Arnd,

Thank you for the comment. Yes, the io_base is a security problem, we
will fix it in coming patch soon.

But can we keep the sysfs? The interface from hnae is not used only by
ethernet driver but also by Open Data Plane driver. If we more it to
upper layers. Both drivers will have the same logic.

So how about we just add documents to Documention/ABI?

Thanks
--
-Kenneth Lee (Hisilicon)


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/