diff options
author | Thorsten Lockert <tholo@cvs.openbsd.org> | 1996-03-14 08:28:59 +0000 |
---|---|---|
committer | Thorsten Lockert <tholo@cvs.openbsd.org> | 1996-03-14 08:28:59 +0000 |
commit | 05874cbb7075e381d04386c2ee1bcf4d6c1fdcb9 (patch) | |
tree | 301bec6d14786b30205914feed472bca92e31891 | |
parent | 1b093bbb4844836d5983d03bfa5a05a6e55dc702 (diff) |
From Lite2; improve handling of socket options on raw datagrams and multi-
cast routing commands
-rw-r--r-- | sys/netinet/raw_ip.c | 55 |
1 files changed, 35 insertions, 20 deletions
diff --git a/sys/netinet/raw_ip.c b/sys/netinet/raw_ip.c index 38562c2a2ae..014839e4821 100644 --- a/sys/netinet/raw_ip.c +++ b/sys/netinet/raw_ip.c @@ -1,4 +1,4 @@ -/* $OpenBSD: raw_ip.c,v 1.4 1996/03/04 08:21:52 niklas Exp $ */ +/* $OpenBSD: raw_ip.c,v 1.5 1996/03/14 08:28:58 tholo Exp $ */ /* $NetBSD: raw_ip.c,v 1.25 1996/02/18 18:58:33 christos Exp $ */ /* @@ -205,35 +205,33 @@ rip_ctloutput(op, so, level, optname, m) struct mbuf **m; { register struct inpcb *inp = sotoinpcb(so); -#ifdef MROUTING - int error; -#endif + register int error; if (level != IPPROTO_IP) { - if (m != 0 && *m != 0) - (void)m_free(*m); + if (op == PRCO_SETOPT && *m) + (void) m_free(*m); return (EINVAL); } switch (optname) { case IP_HDRINCL: - if (op == PRCO_SETOPT || op == PRCO_GETOPT) { - if (m == 0 || *m == 0 || (*m)->m_len < sizeof (int)) - return (EINVAL); - if (op == PRCO_SETOPT) { - if (*mtod(*m, int *)) - inp->inp_flags |= INP_HDRINCL; - else - inp->inp_flags &= ~INP_HDRINCL; + error = 0; + if (op == PRCO_SETOPT) { + if (*m == 0 || (*m)->m_len < sizeof (int)) + error = EINVAL; + else if (*mtod(*m, int *)) + inp->inp_flags |= INP_HDRINCL; + else + inp->inp_flags &= ~INP_HDRINCL; + if (*m) (void)m_free(*m); - } else { - (*m)->m_len = sizeof (int); - *mtod(*m, int *) = inp->inp_flags & INP_HDRINCL; - } - return (0); + } else { + *m = m_get(M_WAIT, M_SOOPTS); + (*m)->m_len = sizeof(int); + *mtod(*m, int *) = inp->inp_flags & INP_HDRINCL; } - break; + return (error); case MRT_INIT: case MRT_DONE: @@ -261,6 +259,23 @@ rip_ctloutput(op, so, level, optname, m) m_free(*m); return (EOPNOTSUPP); #endif + + default: + if (optname >= MRT_INIT) { +#ifdef MROUTING + if (op == PRCO_SETOPT) { + error = ip_mrouter_cmd(optname, so, *m); + if (*m) + (void)m_free(*m); + } else + error = EINVAL; + return (error); +#else + if (op == PRCO_SETOPT && *m) + (void)m_free(*m); + return (EOPNOTSUPP); +#endif + } } return (ip_ctloutput(op, so, level, optname, m)); } |