patch-2.4.20 linux-2.4.20/drivers/net/pcmcia/xirc2ps_cs.c
Next file: linux-2.4.20/drivers/net/pcmcia/xircom_cb.c
Previous file: linux-2.4.20/drivers/net/pcmcia/wavelan_cs.h
Back to the patch index
Back to the overall index
- Lines: 57
- Date:
Thu Nov 28 15:53:14 2002
- Orig file:
linux-2.4.19/drivers/net/pcmcia/xirc2ps_cs.c
- Orig date:
Tue Nov 13 09:02:30 2001
diff -urN linux-2.4.19/drivers/net/pcmcia/xirc2ps_cs.c linux-2.4.20/drivers/net/pcmcia/xirc2ps_cs.c
@@ -74,9 +74,11 @@
#include <linux/interrupt.h>
#include <linux/in.h>
#include <linux/delay.h>
+#include <linux/ethtool.h>
#include <asm/io.h>
#include <asm/system.h>
#include <asm/bitops.h>
+#include <asm/uaccess.h>
#include <linux/netdevice.h>
#include <linux/etherdevice.h>
@@ -1715,6 +1717,26 @@
return 0;
}
+static int netdev_ethtool_ioctl(struct net_device *dev, void *useraddr)
+{
+ u32 ethcmd;
+
+ if (copy_from_user(ðcmd, useraddr, sizeof(ethcmd)))
+ return -EFAULT;
+
+ switch (ethcmd) {
+ case ETHTOOL_GDRVINFO: {
+ struct ethtool_drvinfo info = {ETHTOOL_GDRVINFO};
+ strncpy(info.driver, "xirc2ps_cs", sizeof(info.driver)-1);
+ if (copy_to_user(useraddr, &info, sizeof(info)))
+ return -EFAULT;
+ return 0;
+ }
+ }
+
+ return -EOPNOTSUPP;
+}
+
static int
do_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
{
@@ -1730,6 +1752,8 @@
return -EOPNOTSUPP;
switch(cmd) {
+ case SIOCETHTOOL:
+ return netdev_ethtool_ioctl(dev, (void *) rq->ifr_data);
case SIOCDEVPRIVATE: /* Get the address of the PHY in use. */
data[0] = 0; /* we have only this address */
/* fall trough */
@@ -2096,7 +2120,7 @@
MAYBE_SET(irq_list[1], 7);
MAYBE_SET(irq_list[2], 8);
MAYBE_SET(irq_list[3], 9);
-#undef MAYBE_SET(X,Y)
+#undef MAYBE_SET
return 0;
}
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)