From: Michael Brown Date: Thu, 29 Aug 2013 13:10:16 +0000 (+0100) Subject: [netdevice] Add concept of a network device index X-Git-Tag: v1.20.1~1422 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=d5f69e93887cb9ad505b7ed6394891652f393885;p=thirdparty%2Fipxe.git [netdevice] Add concept of a network device index IPv6 link-local socket addresses require some way to specify a local network device. We cannot simply use a pointer to the network device, since a struct sockaddr_in6 may be long-lived and has no way to hold a reference to the network device. Using a network device index allows a socket address to cleanly refer to a network device without worrying about whether or not that device continues to exist. Signed-off-by: Michael Brown --- diff --git a/src/include/ipxe/netdevice.h b/src/include/ipxe/netdevice.h index d0e628a43..7288ad86d 100644 --- a/src/include/ipxe/netdevice.h +++ b/src/include/ipxe/netdevice.h @@ -300,6 +300,8 @@ struct net_device { struct list_head list; /** List of open network devices */ struct list_head open_list; + /** Index of this network device */ + unsigned int index; /** Name of this network device */ char name[12]; /** Underlying hardware device */ diff --git a/src/net/netdevice.c b/src/net/netdevice.c index 5af9c6dc8..283632f62 100644 --- a/src/net/netdevice.c +++ b/src/net/netdevice.c @@ -498,10 +498,11 @@ int register_netdev ( struct net_device *netdev ) { uint32_t seed; int rc; - /* Create device name */ + /* Record device index and create device name */ + netdev->index = ifindex++; if ( netdev->name[0] == '\0' ) { snprintf ( netdev->name, sizeof ( netdev->name ), "net%d", - ifindex++ ); + netdev->index ); } /* Set initial link-layer address, if not already set */