| version 1.42, 1999/01/30 21:43:16 |
version 1.42.6.1, 1999/06/28 06:37:01 |
|
|
| |
|
| #include <machine/stdarg.h> |
#include <machine/stdarg.h> |
| |
|
| |
#ifdef IPSEC |
| |
#include <netinet6/ipsec.h> |
| |
#endif /*IPSEC*/ |
| |
|
| struct inpcbtable rawcbtable; |
struct inpcbtable rawcbtable; |
| |
|
| int rip_bind __P((struct inpcb *, struct mbuf *)); |
int rip_bind __P((struct inpcb *, struct mbuf *)); |
|
|
| in_pcbinit(&rawcbtable, 1, 1); |
in_pcbinit(&rawcbtable, 1, 1); |
| } |
} |
| |
|
| |
static struct sockaddr_in ripsrc = { sizeof(ripsrc), AF_INET }; |
| |
|
| /* |
/* |
| * Setup generic address and protocol structures |
* Setup generic address and protocol structures |
| * for raw_input routine, then pass them along with |
* for raw_input routine, then pass them along with |
| Line 100 rip_input(m, va_alist) |
|
| Line 106 rip_input(m, va_alist) |
|
| va_dcl |
va_dcl |
| #endif |
#endif |
| { |
{ |
| |
int off, proto; |
| register struct ip *ip = mtod(m, struct ip *); |
register struct ip *ip = mtod(m, struct ip *); |
| register struct inpcb *inp; |
register struct inpcb *inp; |
| struct inpcb *last = 0; |
struct inpcb *last = 0; |
| struct mbuf *opts = 0; |
struct mbuf *opts = 0; |
| struct sockaddr_in ripsrc; |
struct sockaddr_in ripsrc; |
| |
va_list ap; |
| |
|
| |
va_start(ap, m); |
| |
off = va_arg(ap, int); |
| |
proto = va_arg(ap, int); |
| |
va_end(ap); |
| |
|
| ripsrc.sin_family = AF_INET; |
ripsrc.sin_family = AF_INET; |
| ripsrc.sin_len = sizeof(struct sockaddr_in); |
ripsrc.sin_len = sizeof(struct sockaddr_in); |
| Line 121 rip_input(m, va_alist) |
|
| Line 134 rip_input(m, va_alist) |
|
| for (inp = rawcbtable.inpt_queue.cqh_first; |
for (inp = rawcbtable.inpt_queue.cqh_first; |
| inp != (struct inpcb *)&rawcbtable.inpt_queue; |
inp != (struct inpcb *)&rawcbtable.inpt_queue; |
| inp = inp->inp_queue.cqe_next) { |
inp = inp->inp_queue.cqe_next) { |
| if (inp->inp_ip.ip_p && inp->inp_ip.ip_p != ip->ip_p) |
if (inp->inp_ip.ip_p && inp->inp_ip.ip_p != proto) |
| continue; |
continue; |
| if (!in_nullhost(inp->inp_laddr) && |
if (!in_nullhost(inp->inp_laddr) && |
| !in_hosteq(inp->inp_laddr, ip->ip_dst)) |
!in_hosteq(inp->inp_laddr, ip->ip_dst)) |
| Line 164 rip_input(m, va_alist) |
|
| Line 177 rip_input(m, va_alist) |
|
| ipstat.ips_noproto++; |
ipstat.ips_noproto++; |
| ipstat.ips_delivered--; |
ipstat.ips_delivered--; |
| } |
} |
| |
return; |
| } |
} |
| |
|
| /* |
/* |
| Line 229 rip_output(m, va_alist) |
|
| Line 243 rip_output(m, va_alist) |
|
| flags |= IP_RAWOUTPUT; |
flags |= IP_RAWOUTPUT; |
| ipstat.ips_rawout++; |
ipstat.ips_rawout++; |
| } |
} |
| |
#ifdef IPSEC |
| |
m->m_pkthdr.rcvif = (struct ifnet *)inp->inp_socket; /*XXX*/ |
| |
#endif /*IPSEC*/ |
| return (ip_output(m, opts, &inp->inp_route, flags, inp->inp_moptions, &inp->inp_errormtu)); |
return (ip_output(m, opts, &inp->inp_route, flags, inp->inp_moptions, &inp->inp_errormtu)); |
| } |
} |
| |
|
| Line 409 rip_usrreq(so, req, m, nam, control, p) |
|
| Line 426 rip_usrreq(so, req, m, nam, control, p) |
|
| break; |
break; |
| inp = sotoinpcb(so); |
inp = sotoinpcb(so); |
| inp->inp_ip.ip_p = (long)nam; |
inp->inp_ip.ip_p = (long)nam; |
| |
#ifdef IPSEC |
| |
error = ipsec_init_policy(&inp->inp_sp); |
| |
#endif /*IPSEC*/ |
| break; |
break; |
| |
|
| case PRU_DETACH: |
case PRU_DETACH: |