aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBen Dooks <ben-linux@fluff.org>2008-02-04 19:02:06 -0500
committerJeff Garzik <jeff@garzik.org>2008-02-11 11:06:25 -0500
commit7da998591798ea52938d8482b52ae3f854f14359 (patch)
tree263e3e0ce48f4d0d5744d3b4d74ec4d3bc5608fd
parentfcfa81aa3e8d885356139122fcb281487b983468 (diff)
DM9000: Add initial ethtool support
Add support for ethtool operations for the DM9000. Signed-off-by: Ben Dooks <ben-linux@fluff.org> Signed-off-by: Jeff Garzik <jeff@garzik.org>
-rw-r--r--drivers/net/dm9000.c69
1 files changed, 68 insertions, 1 deletions
diff --git a/drivers/net/dm9000.c b/drivers/net/dm9000.c
index d42cb734c5ea..709fd674ec38 100644
--- a/drivers/net/dm9000.c
+++ b/drivers/net/dm9000.c
@@ -63,6 +63,7 @@
63#include <linux/spinlock.h> 63#include <linux/spinlock.h>
64#include <linux/crc32.h> 64#include <linux/crc32.h>
65#include <linux/mii.h> 65#include <linux/mii.h>
66#include <linux/ethtool.h>
66#include <linux/dm9000.h> 67#include <linux/dm9000.h>
67#include <linux/delay.h> 68#include <linux/delay.h>
68#include <linux/platform_device.h> 69#include <linux/platform_device.h>
@@ -80,6 +81,7 @@
80 81
81#define CARDNAME "dm9000" 82#define CARDNAME "dm9000"
82#define PFX CARDNAME ": " 83#define PFX CARDNAME ": "
84#define DRV_VERSION "1.30"
83 85
84#ifdef CONFIG_BLACKFIN 86#ifdef CONFIG_BLACKFIN
85#define readsb insb 87#define readsb insb
@@ -145,6 +147,11 @@ typedef struct board_info {
145 } \ 147 } \
146} while (0) 148} while (0)
147 149
150static inline board_info_t *to_dm9000_board(struct net_device *dev)
151{
152 return dev->priv;
153}
154
148/* function declaration ------------------------------------- */ 155/* function declaration ------------------------------------- */
149static int dm9000_probe(struct platform_device *); 156static int dm9000_probe(struct platform_device *);
150static int dm9000_open(struct net_device *); 157static int dm9000_open(struct net_device *);
@@ -342,6 +349,64 @@ static void dm9000_poll_controller(struct net_device *dev)
342} 349}
343#endif 350#endif
344 351
352/* ethtool ops */
353
354static void dm9000_get_drvinfo(struct net_device *dev,
355 struct ethtool_drvinfo *info)
356{
357 board_info_t *dm = to_dm9000_board(dev);
358
359 strcpy(info->driver, CARDNAME);
360 strcpy(info->version, DRV_VERSION);
361 strcpy(info->bus_info, to_platform_device(dm->dev)->name);
362}
363
364static int dm9000_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
365{
366 board_info_t *dm = to_dm9000_board(dev);
367 unsigned long flags;
368
369 spin_lock_irqsave(&dm->lock, flags);
370 mii_ethtool_gset(&dm->mii, cmd);
371 spin_lock_irqsave(&dm->lock, flags);
372
373 return 0;
374}
375
376static int dm9000_set_settings(struct net_device *dev, struct ethtool_cmd *cmd)
377{
378 board_info_t *dm = to_dm9000_board(dev);
379 unsigned long flags;
380 int rc;
381
382 spin_lock_irqsave(&dm->lock, flags);
383 rc = mii_ethtool_sset(&dm->mii, cmd);
384 spin_lock_irqsave(&dm->lock, flags);
385
386 return rc;
387}
388
389static int dm9000_nway_reset(struct net_device *dev)
390{
391 board_info_t *dm = to_dm9000_board(dev);
392 return mii_nway_restart(&dm->mii);
393}
394
395static u32 dm9000_get_link(struct net_device *dev)
396{
397 board_info_t *dm = to_dm9000_board(dev);
398 return mii_link_ok(&dm->mii);
399}
400
401static const struct ethtool_ops dm9000_ethtool_ops = {
402 .get_drvinfo = dm9000_get_drvinfo,
403 .get_settings = dm9000_get_settings,
404 .set_settings = dm9000_set_settings,
405 .nway_reset = dm9000_nway_reset,
406 .get_link = dm9000_get_link,
407};
408
409
345/* dm9000_release_board 410/* dm9000_release_board
346 * 411 *
347 * release a board, and any mapped resources 412 * release a board, and any mapped resources
@@ -546,6 +611,8 @@ dm9000_probe(struct platform_device *pdev)
546 ndev->watchdog_timeo = msecs_to_jiffies(watchdog); 611 ndev->watchdog_timeo = msecs_to_jiffies(watchdog);
547 ndev->stop = &dm9000_stop; 612 ndev->stop = &dm9000_stop;
548 ndev->set_multicast_list = &dm9000_hash_table; 613 ndev->set_multicast_list = &dm9000_hash_table;
614 ndev->ethtool_ops = &dm9000_ethtool_ops;
615
549#ifdef CONFIG_NET_POLL_CONTROLLER 616#ifdef CONFIG_NET_POLL_CONTROLLER
550 ndev->poll_controller = &dm9000_poll_controller; 617 ndev->poll_controller = &dm9000_poll_controller;
551#endif 618#endif
@@ -1167,7 +1234,7 @@ static struct platform_driver dm9000_driver = {
1167static int __init 1234static int __init
1168dm9000_init(void) 1235dm9000_init(void)
1169{ 1236{
1170 printk(KERN_INFO "%s Ethernet Driver\n", CARDNAME); 1237 printk(KERN_INFO "%s Ethernet Driver, V%s\n", CARDNAME, DRV_VERSION);
1171 1238
1172 return platform_driver_register(&dm9000_driver); /* search board and register */ 1239 return platform_driver_register(&dm9000_driver); /* search board and register */
1173} 1240}