Commit 6f52bc1d authored by Andrew Morton's avatar Andrew Morton Committed by David S. Miller

[NET]: Add new sysfs attribute 'carrier' for net devices.

From: Jesper Juhl <juhl-lkml@dif.dk>

The patch adds a new sysfs attribute called carrier for net devices that
exposes the result of netif_carrier_ok().  This allows a user to quickly
and easily determine if a given netdevice has carrier or not.  Reading
/sys/class/net/<interface>/carrier yields a '1' when there is a carrier and
a '0' when there is not.
Signed-off-by: default avatarJesper Juhl <juhl-lkml@dif.dk>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent d567c1d3
...@@ -126,8 +126,18 @@ static ssize_t show_broadcast(struct class_device *dev, char *buf) ...@@ -126,8 +126,18 @@ static ssize_t show_broadcast(struct class_device *dev, char *buf)
return -EINVAL; return -EINVAL;
} }
static ssize_t show_carrier(struct class_device *dev, char *buf)
{
struct net_device *netdev = to_net_dev(dev);
if (netif_running(netdev)) {
return sprintf(buf, fmt_dec, !!netif_carrier_ok(netdev));
}
return -EINVAL;
}
static CLASS_DEVICE_ATTR(address, S_IRUGO, show_address, NULL); static CLASS_DEVICE_ATTR(address, S_IRUGO, show_address, NULL);
static CLASS_DEVICE_ATTR(broadcast, S_IRUGO, show_broadcast, NULL); static CLASS_DEVICE_ATTR(broadcast, S_IRUGO, show_broadcast, NULL);
static CLASS_DEVICE_ATTR(carrier, S_IRUGO, show_carrier, NULL);
/* read-write attributes */ /* read-write attributes */
NETDEVICE_SHOW(mtu, fmt_dec); NETDEVICE_SHOW(mtu, fmt_dec);
...@@ -186,6 +196,7 @@ static struct class_device_attribute *net_class_attributes[] = { ...@@ -186,6 +196,7 @@ static struct class_device_attribute *net_class_attributes[] = {
&class_device_attr_type, &class_device_attr_type,
&class_device_attr_address, &class_device_attr_address,
&class_device_attr_broadcast, &class_device_attr_broadcast,
&class_device_attr_carrier,
NULL NULL
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment