network - Major netmsg retooling, part 2
[dragonfly.git] / sys / netproto / ipx / ipx_proto.c
1 /*
2  * Copyright (c) 1995, Mike Mitchell
3  * Copyright (c) 1984, 1985, 1986, 1987, 1993
4  *      The Regents of the University of California.  All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  *    notice, this list of conditions and the following disclaimer in the
13  *    documentation and/or other materials provided with the distribution.
14  * 3. All advertising materials mentioning features or use of this software
15  *    must display the following acknowledgement:
16  *      This product includes software developed by the University of
17  *      California, Berkeley and its contributors.
18  * 4. Neither the name of the University nor the names of its contributors
19  *    may be used to endorse or promote products derived from this software
20  *    without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
23  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
26  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
28  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32  * SUCH DAMAGE.
33  *
34  *      @(#)ipx_proto.c
35  *
36  * $FreeBSD: src/sys/netipx/ipx_proto.c,v 1.15 1999/08/28 00:49:41 peter Exp $
37  * $DragonFly: src/sys/netproto/ipx/ipx_proto.c,v 1.8 2008/11/01 04:22:15 sephe Exp $
38  */
39
40 #include "opt_ipx.h"
41
42 #include <sys/param.h>
43 #include <sys/socket.h>
44 #include <sys/protosw.h>
45 #include <sys/domain.h>
46 #include <sys/kernel.h>
47 #include <sys/queue.h>
48 #include <sys/sysctl.h>
49
50 #include <net/radix.h>
51
52 #include "ipx.h"
53 #include "ipx_var.h"
54 #include "spx.h"
55
56 static  struct domain ipxdomain;
57 static  struct pr_usrreqs nousrreqs;
58
59 /*
60  * IPX protocol family: IPX, ERR, PXP, SPX, ROUTE.
61  */
62
63 static struct protosw ipxsw[] = {
64     {
65         .pr_type = 0,
66         .pr_domain = &ipxdomain,
67         .pr_protocol = 0,
68         .pr_flags = 0,
69
70         .pr_init = ipx_init,
71         .pr_usrreqs = &nousrreqs
72     },
73     {
74         .pr_type = SOCK_DGRAM,
75         .pr_domain = &ipxdomain,
76         .pr_protocol = 0,
77         .pr_flags = PR_ATOMIC|PR_ADDR,
78
79         .pr_input = NULL,
80         .pr_output = NULL,
81         .pr_ctlinput = ipx_ctlinput,
82         .pr_ctloutput = ipx_ctloutput,
83
84         .pr_ctlport = cpu0_ctlport,
85         .pr_usrreqs = &ipx_usrreqs
86     },
87     {
88         .pr_type = SOCK_STREAM,
89         .pr_domain = &ipxdomain,
90         .pr_protocol = IPXPROTO_SPX,
91         .pr_flags = PR_CONNREQUIRED|PR_WANTRCVD,
92
93         .pr_input = NULL,
94         .pr_output = NULL,
95         .pr_ctlinput = spx_ctlinput,
96         .pr_ctloutput = spx_ctloutput,
97         .pr_ctlport = cpu0_ctlport,
98
99         .pr_init = spx_init,
100         .pr_fasttimo = spx_fasttimo,
101         .pr_slowtimo = spx_slowtimo,
102         .pr_drain = NULL,
103         .pr_usrreqs = &spx_usrreqs
104     },
105     {
106         .pr_type = SOCK_SEQPACKET,
107         .pr_domain = &ipxdomain,
108         .pr_protocol = IPXPROTO_SPX,
109         .pr_flags = PR_CONNREQUIRED|PR_WANTRCVD|PR_ATOMIC,
110
111         .pr_input = NULL,
112         .pr_output = NULL,
113         .pr_ctlinput = spx_ctlinput,
114         .pr_ctloutput = spx_ctloutput,
115
116         .pr_ctlport = cpu0_ctlport,
117         .pr_usrreqs = &spx_usrreq_sps
118     },
119     {
120         .pr_type = SOCK_RAW,
121         .pr_domain = &ipxdomain,
122         .pr_protocol = IPXPROTO_RAW,
123         .pr_flags = PR_ATOMIC|PR_ADDR,
124
125         .pr_input = NULL,
126         .pr_output = NULL,
127         .pr_ctlinput = NULL,
128         .pr_ctloutput = ipx_ctloutput,
129
130         .pr_usrreqs = &ripx_usrreqs
131     },
132 #ifdef IPTUNNEL
133 #if 0
134     {
135         .pr_type = SOCK_RAW,
136         .pr_domain = &ipxdomain,
137         .pr_protocol = IPPROTO_IPX,
138         .pr_flags = PR_ATOMIC|PR_ADDR,
139
140         .pr_input = iptun_input,
141         .pr_output = rip_output,
142         .pr_ctlinput = iptun_ctlinput,
143         .pr_ctloutput = 0,
144
145         .pr_ctlport = cpu0_ctlport,
146         .pr_usrreqs = &rip_usrreqs
147     },
148 #endif
149 #endif
150 };
151
152 static struct   domain ipxdomain =
153     { AF_IPX, "network systems", 0, 0, 0, 
154       ipxsw, &ipxsw[sizeof(ipxsw)/sizeof(ipxsw[0])], SLIST_ENTRY_INITIALIZER,
155       rn_inithead, 16, sizeof(struct sockaddr_ipx)};
156
157 DOMAIN_SET(ipx);
158 SYSCTL_NODE(_net,       PF_IPX,         ipx,    CTLFLAG_RW, 0,
159         "IPX/SPX");
160
161 SYSCTL_NODE(_net_ipx,   IPXPROTO_RAW,   ipx,    CTLFLAG_RW, 0, "IPX");
162 SYSCTL_NODE(_net_ipx,   IPXPROTO_SPX,   spx,    CTLFLAG_RW, 0, "SPX");