From: "Randy.Dunlap" <rddunlap@osdl.org>
To: netdev@oss.sgi.com
Cc: saw@saw.sw.com.sg, akpm@osdl.org
Subject: Re: [PATCH] enabling netdev boot options (2.6.0-t9)
Date: Sat, 8 Nov 2003 20:44:06 -0800 [thread overview]
Message-ID: <20031108204406.5dbbdc87.rddunlap@osdl.org> (raw)
In-Reply-To: <20031108160441.3a0a5505.rddunlap@osdl.org>
Here's an update for 2.6.0-test9. This update adds
dev_alloc_name_lock(), which takes and releases the rtnl lock
to call dev_alloc_name(), so that the caller doesn't have to do that.
More comments?
Thanks,
--
~Randy
description: enable eepro100 and 3c59x drivers to recognize
'netdev=' boot options:
use dev_alloc_name() to assign an interface name if
rtnl lock is already held (eepro100);
use [new] dev_alloc_name_lock() to assign interface
name if required lock is not already held;
then use netdev_boot_setup_check() to check for boot
options for that interface (name);
add dev_alloc_name_lock() to net/core/dev.c;
maintainer: Andrey V. Savochkin (saw@saw.sw.com.sg);
Andrew Morton (akpm@osdl.org) et al
product_versions: Linux 2.6.0-test9
diffstat:=
drivers/net/3c59x.c | 6 ++++++
drivers/net/eepro100.c | 12 +++++++-----
include/linux/netdevice.h | 1 +
net/core/dev.c | 23 +++++++++++++++++++++++
4 files changed, 37 insertions(+), 5 deletions(-)
diff -Naurp ./drivers/net/eepro100.c~netdev ./drivers/net/eepro100.c
--- ./drivers/net/eepro100.c~netdev 2003-10-25 11:44:01.000000000 -0700
+++ ./drivers/net/eepro100.c 2003-11-08 20:05:38.000000000 -0800
@@ -681,17 +681,19 @@ static int __devinit speedo_found1(struc
SET_MODULE_OWNER(dev);
SET_NETDEV_DEV(dev, &pdev->dev);
- if (dev->mem_start > 0)
+ rtnl_lock();
+
+ if (dev_alloc_name(dev, dev->name) < 0)
+ goto err_free_unlock;
+
+ if (netdev_boot_setup_check(dev) && dev->mem_start > 0) {
option = dev->mem_start;
+ }
else if (card_idx >= 0 && options[card_idx] >= 0)
option = options[card_idx];
else
option = 0;
- rtnl_lock();
- if (dev_alloc_name(dev, dev->name) < 0)
- goto err_free_unlock;
-
/* Read the station address EEPROM before doing the reset.
Nominally his should even be done before accepting the device, but
then we wouldn't have a device name with which to report the error.
diff -Naurp ./drivers/net/3c59x.c~netdev ./drivers/net/3c59x.c
--- ./drivers/net/3c59x.c~netdev 2003-10-25 11:42:42.000000000 -0700
+++ ./drivers/net/3c59x.c 2003-11-08 20:13:39.000000000 -0800
@@ -1110,6 +1110,12 @@ static int __devinit vortex_probe1(struc
SET_NETDEV_DEV(dev, gendev);
vp = dev->priv;
+ retval = dev_alloc_name_lock(dev, dev->name);
+ if (retval < 0)
+ goto free_region;
+
+ netdev_boot_setup_check(dev);
+
option = global_options;
/* The lower four bits are the media type. */
diff -Naurp ./net/core/dev.c~netdev ./net/core/dev.c
--- ./net/core/dev.c~netdev 2003-10-25 11:43:39.000000000 -0700
+++ ./net/core/dev.c 2003-11-08 20:15:00.000000000 -0800
@@ -635,6 +635,29 @@ int dev_alloc_name(struct net_device *de
}
/**
+ * dev_alloc_name_lock - allocate a name for a device,
+ * with required locking
+ * @dev: device
+ * @name: name format string
+ *
+ * Passed a format string - eg "lt%d" it will try and find a suitable
+ * id. Not efficient for many devices, not called a lot.
+ * This function takes the rtnl lock while allocating the name and
+ * adding the device in order to avoid duplicates.
+ * Returns the number of the unit assigned or a negative errno code.
+ */
+
+int dev_alloc_name_lock(struct net_device *dev, const char *name)
+{
+ int ret;
+
+ rtnl_lock();
+ ret = dev_alloc_name(dev, name);
+ rtnl_unlock();
+ return ret;
+}
+
+/**
* dev_alloc - allocate a network device and name
* @name: name format string
* @err: error return pointer
diff -Naurp ./include/linux/netdevice.h~netdev ./include/linux/netdevice.h
--- ./include/linux/netdevice.h~netdev 2003-10-25 11:44:45.000000000 -0700
+++ ./include/linux/netdevice.h 2003-11-08 20:01:33.000000000 -0800
@@ -518,6 +518,7 @@ static inline __deprecated struct net_de
return __dev_alloc(name, err);
}
extern int dev_alloc_name(struct net_device *dev, const char *name);
+extern int dev_alloc_name_lock(struct net_device *dev, const char *name);
extern int dev_open(struct net_device *dev);
extern int dev_close(struct net_device *dev);
extern int dev_queue_xmit(struct sk_buff *skb);
next prev parent reply other threads:[~2003-11-09 4:44 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2003-11-09 0:04 [PATCH] enabling netdev boot options (2.6.0-t9) Randy.Dunlap
2003-11-09 4:44 ` Randy.Dunlap [this message]
2003-11-09 6:06 ` Andrew Morton
2003-11-09 10:55 ` Rask Ingemann Lambertsen
2003-11-09 23:26 ` Randy.Dunlap
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20031108204406.5dbbdc87.rddunlap@osdl.org \
--to=rddunlap@osdl.org \
--cc=akpm@osdl.org \
--cc=netdev@oss.sgi.com \
--cc=saw@saw.sw.com.sg \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).