patch-1.3.26 linux/net/ipv4/af_inet.c
Next file: linux/net/ipv4/icmp.c
Previous file: linux/net/core/sock.c
Back to the patch index
Back to the overall index
- Lines: 207
- Date:
Mon Sep 11 21:30:09 1995
- Orig file:
v1.3.25/linux/net/ipv4/af_inet.c
- Orig date:
Sun Sep 3 12:27:05 1995
diff -u --recursive --new-file v1.3.25/linux/net/ipv4/af_inet.c linux/net/ipv4/af_inet.c
@@ -247,7 +247,7 @@
static void remove_sock(struct sock *sk1)
{
- struct sock *sk2;
+ struct sock **p;
unsigned long flags;
if (sk1->type==SOCK_PACKET)
@@ -262,26 +262,18 @@
/* We can't have this changing out from under us. */
save_flags(flags);
cli();
- sk2 = sk1->prot->sock_array[sk1->num &(SOCK_ARRAY_SIZE -1)];
- if (sk2 == sk1)
- {
- sk1->prot->inuse -= 1;
- sk1->prot->sock_array[sk1->num &(SOCK_ARRAY_SIZE -1)] = sk1->next;
- restore_flags(flags);
- return;
- }
-
- while(sk2 && sk2->next != sk1)
- {
- sk2 = sk2->next;
- }
-
- if (sk2)
+
+ p=&(sk1->prot->sock_array[sk1->num & (SOCK_ARRAY_SIZE -1)]);
+
+ while(*p!=NULL)
{
- sk1->prot->inuse -= 1;
- sk2->next = sk1->next;
- restore_flags(flags);
- return;
+ if(*p==sk1)
+ {
+ sk1->prot->inuse--;
+ *p=sk1->next;
+ break;
+ }
+ p=&((*p)->next);
}
restore_flags(flags);
}
@@ -368,7 +360,7 @@
/* And now the backlog. */
while((skb=skb_dequeue(&sk->back_log))!=NULL)
{
- /* this should never happen. */
+ /* this should [almost] never happen. */
/* printk("cleaning back_log\n");*/
kfree_skb(skb, FREE_READ);
}
@@ -387,12 +379,12 @@
* everything is gone.
*/
- if (sk->dead && sk->rmem_alloc == 0 && sk->wmem_alloc == 0)
- {
+ if (sk->dead && sk->rmem_alloc == 0 && sk->wmem_alloc == 0)
+ {
kfree_s((void *)sk,sizeof(*sk));
- }
- else
- {
+ }
+ else
+ {
/* this should never happen. */
/* actually it can if an ack has just been sent. */
sk->destroy = 1;
@@ -633,6 +625,7 @@
#endif
sk->type = sock->type;
sk->protocol = protocol;
+ sk->allocation = GFP_KERNEL;
sk->sndbuf = SK_WMEM_MAX;
sk->rcvbuf = SK_RMEM_MAX;
sk->rto = TCP_TIMEOUT_INIT; /*TCP_WRITE_TIME*/
@@ -780,6 +773,7 @@
/*
* Return 1 if we still have things to send in our buffers.
*/
+
static inline int closing(struct sock * sk)
{
switch (sk->state) {
@@ -982,13 +976,7 @@
if (sock->state == SS_CONNECTING && sk->protocol == IPPROTO_TCP && (flags & O_NONBLOCK))
{
if(sk->err!=0)
- {
- cli();
- err=sk->err;
- sk->err=0;
- sti();
- return -err;
- }
+ return inet_error(sk);
return -EALREADY; /* Connecting is currently in progress */
}
if (sock->state != SS_CONNECTING)
@@ -1007,11 +995,7 @@
if (sk->state > TCP_FIN_WAIT2 && sock->state==SS_CONNECTING)
{
sock->state=SS_UNCONNECTED;
- cli();
- err=sk->err;
- sk->err=0;
- sti();
- return -err;
+ return inet_error(sk);
}
if (sk->state != TCP_ESTABLISHED &&(flags & O_NONBLOCK))
@@ -1031,10 +1015,8 @@
if(sk->err && sk->protocol == IPPROTO_TCP)
{
sock->state = SS_UNCONNECTED;
- err = -sk->err;
- sk->err=0;
sti();
- return err; /* set by tcp_err() */
+ return inet_error(sk); /* set by tcp_err() */
}
}
sti();
@@ -1043,11 +1025,7 @@
if (sk->state != TCP_ESTABLISHED && sk->err)
{
sock->state = SS_UNCONNECTED;
- cli();
- err=sk->err;
- sk->err=0;
- sti();
- return(-err);
+ return inet_error(sk);
}
return(0);
}
@@ -1097,9 +1075,7 @@
sk2 = sk1->prot->accept(sk1,flags);
if (sk2 == NULL)
{
- err=sk1->err;
- sk1->err=0;
- return(-err);
+ return inet_error(sk1);
}
}
newsock->data = (void *)sk2;
@@ -1127,12 +1103,11 @@
if (sk2->state != TCP_ESTABLISHED && sk2->err > 0)
{
- err = -sk2->err;
- sk2->err=0;
- sk2->dead=1; /* ANK */
+ err = inet_error(sk2);
+ sk2->dead=1; /* ANK */
destroy_sock(sk2);
newsock->data = NULL;
- return(err);
+ return err;
}
newsock->state = SS_CONNECTED;
return(0);
@@ -1566,7 +1541,7 @@
int i;
- printk("Swansea University Computer Society TCP/IP for NET3.030 (Snapshot #1)\n");
+ printk("Swansea University Computer Society TCP/IP for NET3.031 (Snapshot #4)\n");
/*
* Tell SOCKET that we are alive...
@@ -1610,11 +1585,26 @@
* Set the IP module up
*/
ip_init();
-
+ /*
+ * Set the ICMP layer up
+ */
+ icmp_init(&inet_proto_ops);
+ /*
+ * Set the firewalling up
+ */
#if defined(CONFIG_IP_ACCT)||defined(CONFIG_IP_FIREWALL)|| \
defined(CONFIG_IP_MASQUERADE)
ip_fw_init();
#endif
+ /*
+ * Initialise the multicast router
+ */
+#if defined(CONFIG_IP_MROUTE)
+ ip_mr_init();
+#endif
+ /*
+ * Create all the /proc entries.
+ */
#ifdef CONFIG_INET_RARP
proc_net_register(&(struct proc_dir_entry) {
FUNET's LINUX-ADM group, [email protected]
TCL-scripts by Sam Shen, [email protected]
with Sam's (original) version of this