patch-2.2.16 linux/net/appletalk/ddp.c
Next file: linux/net/core/dev.c
Previous file: linux/net/appletalk/aarp.c
Back to the patch index
Back to the overall index
-  Lines: 44
-  Date:
Wed Jun  7 14:26:44 2000
-  Orig file: 
v2.2.15/linux/net/appletalk/ddp.c
-  Orig date: 
Mon Aug  9 12:04:41 1999
diff -urN v2.2.15/linux/net/appletalk/ddp.c linux/net/appletalk/ddp.c
@@ -337,6 +337,7 @@
 	int probe_net=ntohs(atif->address.s_net);
 	int probe_node=atif->address.s_node;
 	int netct, nodect;
+	struct device *dev = atif->dev;
 
 	/*
 	 * Offset the network we start probing with.
@@ -373,6 +374,13 @@
 				 * Probe a proposed address.
 				 */
 				aarp_probe_network(atif);
+				
+				/*
+				 * The atif might have been deleted while
+				 * in aarp_probe_network!
+				 */
+				if (atalk_find_dev(dev) != atif)
+					return -ENODEV;
 
 				if(!(atif->status & ATIF_PROBE_FAIL)) {
 					atif->status &= ~ATIF_PROBE;
@@ -399,6 +407,7 @@
 	int probe_net=ntohs(atif->address.s_net);	// we probe the interface's network
 	int probe_node=ATADDR_ANYNODE;				// we'll take anything
 	int netct, nodect;
+	struct device *dev = atif->dev;
 
 	/*
 	 * Offset the network we start probing with.
@@ -435,6 +444,13 @@
 				 * Tell AARP to probe a proposed address.
 				 */
 				int probe_result = aarp_proxy_probe_network(atif, proxy_addr);
+
+				/*
+				 * The atif might have been deleted while
+				 * in aarp_proxy_probe_network!
+				 */
+				if (atalk_find_dev(dev) != atif)
+					return -ENODEV;
 
 				if (probe_result == 0)
 					return 0;
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)