2007-05-03 03:28:49 -07:00
/* AFS network device helpers
*
* Copyright ( c ) 2007 Patrick McHardy < kaber @ trash . net >
*/
# include <linux/string.h>
# include <linux/rtnetlink.h>
# include <linux/inetdevice.h>
# include <linux/netdevice.h>
# include <linux/if_arp.h>
2007-09-17 11:56:21 -07:00
# include <net/net_namespace.h>
2007-05-03 03:28:49 -07:00
# include "internal.h"
2007-05-03 03:29:41 -07:00
/*
* get a MAC address from a random ethernet interface that has a real one
* - the buffer will normally be 6 bytes in size
*/
int afs_get_MAC_address ( u8 * mac , size_t maclen )
2007-05-03 03:28:49 -07:00
{
struct net_device * dev ;
int ret = - ENODEV ;
2009-04-09 17:10:28 +01:00
BUG_ON ( maclen ! = ETH_ALEN ) ;
2007-05-03 03:29:41 -07:00
2007-05-03 03:28:49 -07:00
rtnl_lock ( ) ;
2007-09-17 11:56:21 -07:00
dev = __dev_getfirstbyhwtype ( & init_net , ARPHRD_ETHER ) ;
2007-05-03 03:28:49 -07:00
if ( dev ) {
2007-05-03 03:29:41 -07:00
memcpy ( mac , dev - > dev_addr , maclen ) ;
2007-05-03 03:28:49 -07:00
ret = 0 ;
}
rtnl_unlock ( ) ;
return ret ;
}
2007-05-03 03:29:41 -07:00
/*
* get a list of this system ' s interface IPv4 addresses , netmasks and MTUs
* - maxbufs must be at least 1
* - returns the number of interface records in the buffer
*/
2007-05-03 03:28:49 -07:00
int afs_get_ipv4_interfaces ( struct afs_interface * bufs , size_t maxbufs ,
bool wantloopback )
{
struct net_device * dev ;
struct in_device * idev ;
int n = 0 ;
2007-05-03 03:29:41 -07:00
ASSERT ( maxbufs > 0 ) ;
2007-05-03 03:28:49 -07:00
rtnl_lock ( ) ;
2007-09-17 11:56:21 -07:00
for_each_netdev ( & init_net , dev ) {
2007-05-03 03:28:49 -07:00
if ( dev - > type = = ARPHRD_LOOPBACK & & ! wantloopback )
continue ;
idev = __in_dev_get_rtnl ( dev ) ;
if ( ! idev )
continue ;
for_primary_ifa ( idev ) {
bufs [ n ] . address . s_addr = ifa - > ifa_address ;
bufs [ n ] . netmask . s_addr = ifa - > ifa_mask ;
bufs [ n ] . mtu = dev - > mtu ;
n + + ;
2007-05-03 03:29:41 -07:00
if ( n > = maxbufs )
goto out ;
} endfor_ifa ( idev ) ;
2007-05-03 03:28:49 -07:00
}
out :
rtnl_unlock ( ) ;
return n ;
}