On Wed, 2007-11-14 at 15:31 -0800, David Miller wrote:
> From: Ulrich Drepper <[EMAIL PROTECTED]>
> Date: Wed, 14 Nov 2007 12:59:52 -0800
> 
> > Just FYI, with the current getaddrinfo code it is even more critical to
> > get to a point where I can cache network interface information and query
> > the kernel whether it changed.  We now have to read the RTM_GETADDR
> > tables for every lookup.  It was more limited with the old, incomplete
> > implementation.
> > 
> > Even if it's something as simple as a RTM_SEQUENCE request which returns
> > a number that is bumped at every interface change.
> 
> This sounds like a useful feature.  Essentially you want a generation
> ID that increments every time a configuration change is made?
> 
> Most daemons handle this by listening for events on the netlink
> socket, but I understand how that might not be practical for
> glibc.
> 
> > Related: I need to know about the device type (the ARPHRD_* values) to
> > determine whether a device is for a native transport or a tunnel.  What
> > I currently do is:
> > 
> > - - at the beginning I get information about all interfaces using
> > RTM_GETADDR
> > 
> > - - them later I have to find the device type by
> > 
> >   + reading the RTM_GETLINK data to get to the device name
> > 
> >   + then using the name and ioctl(SIOCGIFHWADDR) I get the device type
> > 
> > 
> > It would be so much nicer if the device type would be part of the
> > RTM_GETADDR data, or at least the RTM_GETLINK data.
> 
> It's part of the link information, Look in ifinfomsg->ifi_type
> 
> In general be suspicious if it seems netlink isn't providing
> the same information available via the old ioctls :-)

Sorry for late little offtopic question: Exists any simple way how to
differentiate virtual network devices from real devices (e.g. vlans,
bridges)?

They have the same ifinfomsg->ifi_type as real devices (ARPHRD_ETHER). I
know to differentiate vlans via IFLA_LINK attribute. But how to
differentiate bridges from real devices I didn't determine.
Thanks for any answer.

regards,

milan kocian



--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to