Blame view

kernel/linux-imx6_3.14.28/fs/afs/netdevices.c 1.45 KB
6b13f685e   김민수   BSP 최초 추가
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
  /* 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>
  #include <net/net_namespace.h>
  #include "internal.h"
  
  /*
   * 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)
  {
  	struct net_device *dev;
  	int ret = -ENODEV;
  
  	BUG_ON(maclen != ETH_ALEN);
  
  	rtnl_lock();
  	dev = __dev_getfirstbyhwtype(&init_net, ARPHRD_ETHER);
  	if (dev) {
  		memcpy(mac, dev->dev_addr, maclen);
  		ret = 0;
  	}
  	rtnl_unlock();
  	return ret;
  }
  
  /*
   * 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
   */
  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;
  
  	ASSERT(maxbufs > 0);
  
  	rtnl_lock();
  	for_each_netdev(&init_net, dev) {
  		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++;
  			if (n >= maxbufs)
  				goto out;
  		} endfor_ifa(idev);
  	}
  out:
  	rtnl_unlock();
  	return n;
  }