Re: netpoll_setup questions

From: Matt Mackall
Date: Wed Oct 27 2004 - 15:15:44 EST


On Wed, Oct 27, 2004 at 02:58:04PM -0400, Jeff Moyer wrote:
> ==> Regarding Re: netpoll_setup questions; Matt Mackall <mpm@xxxxxxxxxxx> adds:
>
> mpm> On Wed, Oct 27, 2004 at 11:50:05AM -0400, Jeff Moyer wrote:
> >> Hi, Matt,
> >>
> >> The section of code in the body of this if statement:
> >>
> >> if (!(ndev->flags & IFF_UP)) {
> >>
> >> is a bit broken. First, upon discussion with jgarzik, it seems we
> >> should not check for IFF_UP, but instead do netif_running.
>
> mpm> Well I cribbed it from the nfsroot code, which is perhaps not up on
> mpm> fashion.
>
> Hmm, I can't seem to find the relevant code. Where is it?

net/ipv4/ipconfig.c, IIRC.

> mpm> I don't expect it does. Usually we have our own IP address from the
> mpm> command line, but if we don't, we will check if there's an in_dev
> mpm> connected to the device and if so, look up the device's IP. This is
> mpm> useful for the modular case where the network is up before we start
> mpm> and we have a handy default for local IP.
>
> Right, but the case in question is the one where we don't have a local IP
> specified:

Yeah..

> if (!np->local_ip) {

"but if we don't"

> rcu_read_lock();
> in_dev = __in_dev_get(ndev);
>
> if (!in_dev) {

"we will check if there's an in_dev"

> rcu_read_unlock();
> printk(KERN_ERR "%s: no IP address for %s, aborting\n",
> np->name, np->dev_name);
> goto release;
> }
>
> np->local_ip = ntohl(in_dev->ifa_list->ifa_local);

"if so, look up the device's IP"

> rcu_read_unlock();
> printk(KERN_INFO "%s: local IP %d.%d.%d.%d\n",
> np->name, HIPQUAD(np->local_ip));
> }
>
>
> >> And, in the case where it doesn't, you will get an oops further on when
> >> dereferencing the ifa_list.
>
> mpm> Does this actually happen? I'm checking in_dev for null already, but
> mpm> perhaps I need to check ifa_list as well.
>
> Yes, that should do it.

Again, does the oops actually happen? I'd expect I'd have seen it by
now if this were really a problem, but I don't mind adding another check.

> Here is a patch which should work. I'll test today.
>
> -Jeff
>
> --- linux-2.6.9/net/core/netpoll.c~ 2004-10-21 17:49:10.000000000 -0400
> +++ linux-2.6.9/net/core/netpoll.c 2004-10-27 14:53:57.492149880 -0400
> @@ -571,7 +571,7 @@ int netpoll_setup(struct netpoll *np)
> goto release;
> }
>
> - if (!(ndev->flags & IFF_UP)) {
> + if (!netif_running(ndev)) {
> unsigned short oflags;
> unsigned long atmost, atleast;
>
> @@ -617,7 +617,7 @@ int netpoll_setup(struct netpoll *np)
> rcu_read_lock();
> in_dev = __in_dev_get(ndev);
>
> - if (!in_dev) {
> + if (!in_dev || !in_dev->ifa_list) {
> rcu_read_unlock();
> printk(KERN_ERR "%s: no IP address for %s, aborting\n",
> np->name, np->dev_name);

Looks good to me.

--
Mathematics is the supreme nostalgia of our time.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/