patch-1.3.22 linux/net/ipv4/af_inet.c
Next file: linux/net/ipv4/arp.c
Previous file: linux/net/ipv4/README.TCP
Back to the patch index
Back to the overall index
- Lines: 53
- Date:
Fri Sep 1 14:31:57 1995
- Orig file:
v1.3.21/linux/net/ipv4/af_inet.c
- Orig date:
Mon Aug 28 14:52:25 1995
diff -u --recursive --new-file v1.3.21/linux/net/ipv4/af_inet.c linux/net/ipv4/af_inet.c
@@ -43,6 +43,7 @@
* Alan Cox : New buffering now used smartly.
* Alan Cox : BSD rather than common sense interpretation of
* listen.
+ * Germano Caronni : Assorted small races.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
@@ -726,6 +727,10 @@
sock->data =(void *) sk;
sk->dummy_th.doff = sizeof(sk->dummy_th)/4;
sk->ip_ttl=64;
+ if(sk->type==SOCK_RAW && protocol==IPPROTO_RAW)
+ sk->ip_hdrincl=1;
+ else
+ sk->ip_hdrincl=0;
#ifdef CONFIG_IP_MULTICAST
sk->ip_mc_loop=1;
sk->ip_mc_ttl=1;
@@ -978,8 +983,10 @@
{
if(sk->err!=0)
{
+ cli();
err=sk->err;
sk->err=0;
+ sti();
return -err;
}
return -EALREADY; /* Connecting is currently in progress */
@@ -1023,10 +1030,10 @@
icmp error packets wanting to close a tcp or udp socket. */
if(sk->err && sk->protocol == IPPROTO_TCP)
{
- sti();
sock->state = SS_UNCONNECTED;
err = -sk->err;
sk->err=0;
+ sti();
return err; /* set by tcp_err() */
}
}
@@ -1036,8 +1043,10 @@
if (sk->state != TCP_ESTABLISHED && sk->err)
{
sock->state = SS_UNCONNECTED;
+ cli();
err=sk->err;
sk->err=0;
+ sti();
return(-err);
}
return(0);
FUNET's LINUX-ADM group, [email protected]
TCL-scripts by Sam Shen, [email protected]
with Sam's (original) version of this