[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <51B1F56D.5000007@intel.com>
Date: Fri, 07 Jun 2013 07:59:57 -0700
From: John Fastabend <john.r.fastabend@...el.com>
To: Narendra_K@...l.com
CC: stephen@...workplumber.org, netdev@...r.kernel.org,
Ben Hutchings <bhutchings@...arflare.com>
Subject: Re: Generic interface to make physical port number used by a netdevice
available to user space
On 5/31/2013 5:13 AM, Narendra_K@...l.com wrote:
> On Mon, May 27, 2013 at 06:39:00PM +0530, Narendra_K@...l.com wrote:
>>
>>> -----Original Message-----
>>> From: Stephen Hemminger [mailto:stephen@...workplumber.org]
>>> Sent: Thursday, May 23, 2013 10:04 PM
>>> To: K, Narendra
>>> Cc: netdev@...r.kernel.org
>>> One idea would be to reuse the mostly outdated if_port field.
>>> As far as I can see only drivers using it are legacy drivers which support
>> AUI vs.
>>> TP back in the old bad days of BNC Ethernet.
>>
>> Hi Stephen, thank you.
>>
>> I think if_port or dev_id would be fine. The difference seems to be that
>> dev_id is already exported to sysfs.
>>
>
> I think the following options could be explored -
>
> 1. dev_id:
> Do not initialize it to -1, but use it to indicate physical port number
> used by netdevice.
>
> It is currently being used for indicating physical port number and
> is also being used to differentiate OS instances as noted here.
> http://marc.info/?l=linux-netdev&m=136992115300526&w=2
>
My opinion would be to use dev_id as the comment in netdevice.h suggests
it can be used for this. I'm not sure the addrconf.c bits are still
valid.
If need be you could fix the check in addrconf to check for not -1.
> 2. if_port:
>
> Reuse if_port to indicate physical port number used by a netdevice as
> suggested.
>
Sure you could use this as well but I got more hits with drivers using
this to indicate the media type. I'm guessing this would break KABI for
someone somewhere, but maybe there is a way to work around it. dev_id
seems like an easier problem to me.
> A quick look at the sources seems to indicate that it is also
> being used to indicate the physical port number and data transfer mode.
>
> Used to indicate physical port number by
> -drivers/net/ethernet/chelsio/cxgb/cxgb2.c
> -drivers/net/ethernet/tehuti/tehuti.c
>
> Used to indicate data transfer mode by
> -drivers/net/ethernet/realtek/atp.c
>
> Also, 'if_port' seems to be available to userspace via
> -netlink (by rtnl_dump_ifinfo in net/core/rtnetlink.c)
> -SIOCGIFMAP ioctl
>
> 3. Add a new field 'physport' to 'struct net_device' and export it to sysfs.
Probably not we already have two fields that seem ill-defined no reason
to add another to the confusion. If you absolutely can't make dev_id or
if_port coherent then maybe but I really think one of the above two will
work.
>
> It would be great to know your thoughts on which of the above would be
> preferable.
>
--
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