net: Add DEVTYPE support for Ethernet based devices
authorMarcel Holtmann <marcel@holtmann.org>
Mon, 31 Aug 2009 21:08:19 +0000 (21:08 +0000)
committerDavid S. Miller <davem@davemloft.net>
Fri, 11 Sep 2009 19:54:55 +0000 (12:54 -0700)
commit384912ed194e43c03ad1cdaa09b0b1e488c34d46
treebdaae15252819543cff0900941238d2b99bb2300
parentf510c35de0e63e1066db83d2fdce99e6dbde0c80
net: Add DEVTYPE support for Ethernet based devices

The Ethernet framing is used for a lot of devices these days. Most
prominent are WiFi and WiMAX based devices. However for userspace
application it is important to classify these devices correctly and
not only see them as Ethernet devices. The daemons like HAL, DeviceKit
or even NetworkManager with udev support tries to do the classification
in userspace with a lot trickery and extra system calls. This is not
good and actually reaches its limitations. Especially since the kernel
does know the type of the Ethernet device it is pretty stupid.

To solve this problem the underlying device type needs to be set and
then the value will be exported as DEVTYPE via uevents and available
within udev.

  # cat /sys/class/net/wlan0/uevent
  DEVTYPE=wlan
  INTERFACE=wlan0
  IFINDEX=5

This is similar to subsystems like USB and SCSI that distinguish
between hosts, devices, disks, partitions etc.

The new SET_NETDEV_DEVTYPE() is a convenience helper to set the actual
device type. All device types are free form, but for convenience the
same strings as used with RFKILL are choosen.

Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/usb/hso.c
drivers/net/wimax/i2400m/sdio.c
drivers/net/wimax/i2400m/usb.c
include/linux/netdevice.h
net/bluetooth/bnep/core.c
net/bridge/br_if.c
net/mac80211/iface.c