OpenVZ Forum


Home » Mailing lists » Devel » [PATCH] Remove notifier block from chain when register_netdevice_notifier fails
[PATCH] Remove notifier block from chain when register_netdevice_notifier fails [message #23218] Wed, 14 November 2007 12:08 Go to previous message
Pavel Emelianov is currently offline  Pavel Emelianov
Messages: 1149
Registered: September 2006
Senior Member
Commit fcc5a03ac42564e9e255c1134dda47442289e466 makes the
register_netdevice_notifier() handle the error from the
NETDEV_REGISTER event, sent to the registering block. 

The bad news is that in this case the notifier block is 
not removed from the list, but the error is returned to the 
caller. In case the caller is in module init function and 
handles this error this can abort the module loading. The
notifier block will be then removed from the kernel, but 
will be left in the list. Oops :(

I think that the notifier block should be removed from the
chain in case of error, regardless whether this error is 
handled by the caller or not. In the worst case (the error 
is _not_ handled) module will not receive the events any 
longer.

Signed-off-by: Pavel Emelyanov <xemul@openvz.org>

---

diff --git a/net/core/dev.c b/net/core/dev.c
index dd40b35..86d6261 100644
--- a/net/core/dev.c
+++ b/net/core/dev.c
@@ -1171,6 +1171,8 @@ rollback:
 			nb->notifier_call(nb, NETDEV_UNREGISTER, dev);
 		}
 	}
+
+	raw_notifier_chain_unregister(&netdev_chain, nb);
 	goto unlock;
 }
 
Read Message
Read Message
Read Message
Read Message
Read Message
Previous Topic: netns compilation
Next Topic: [PATCH] Use sockfd_lookup_light in the rest of the net/socket.c
Goto Forum:
  


Current Time: Fri Sep 29 09:51:17 GMT 2023

Total time taken to generate the page: 0.03334 seconds