freebsd-dev/sys/netatm/atm_proto.c
harti 1fd91a3dc1 Create a subtree 'harp' of the net sysctl tree. This uses a fixed
OID as the other protocol family sub-trees do, that is equal to the
protocol family identifier. Make the ATM layer debugging flags
available under this tree.

Submitted by:	Vincent Jardin <vjardin@wanadoo.fr>
MFC after:	2 weeks
2003-07-24 10:33:01 +00:00

207 lines
4.1 KiB
C

/*
* ===================================
* HARP | Host ATM Research Platform
* ===================================
*
*
* This Host ATM Research Platform ("HARP") file (the "Software") is
* made available by Network Computing Services, Inc. ("NetworkCS")
* "AS IS". NetworkCS does not provide maintenance, improvements or
* support of any kind.
*
* NETWORKCS MAKES NO WARRANTIES OR REPRESENTATIONS, EXPRESS OR IMPLIED,
* INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY
* AND FITNESS FOR A PARTICULAR PURPOSE, AS TO ANY ELEMENT OF THE
* SOFTWARE OR ANY SUPPORT PROVIDED IN CONNECTION WITH THIS SOFTWARE.
* In no event shall NetworkCS be responsible for any damages, including
* but not limited to consequential damages, arising from or relating to
* any use of the Software or related support.
*
* Copyright 1994-1998 Network Computing Services, Inc.
*
* Copies of this Software may be made, however, the above copyright
* notice must be reproduced on all copies.
*/
/*
* Core ATM Services
* -----------------
*
* ATM socket protocol family support definitions
*/
#include <sys/cdefs.h>
__FBSDID("$FreeBSD$");
#include <sys/param.h>
#include <sys/kernel.h>
#include <sys/domain.h>
#include <sys/protosw.h>
#include <sys/socket.h>
#include <sys/sysctl.h>
#include <net/if.h>
#include <netatm/port.h>
#include <netatm/queue.h>
#include <netatm/atm.h>
#include <netatm/atm_sys.h>
#include <netatm/atm_sap.h>
#include <netatm/atm_cm.h>
#include <netatm/atm_if.h>
#include <netatm/atm_stack.h>
#include <netatm/atm_pcb.h>
#include <netatm/atm_var.h>
struct protosw atmsw[] = {
{ SOCK_DGRAM, /* ioctl()-only */
&atmdomain,
0,
0,
0, /* pr_input */
0, /* pr_output */
0, /* pr_ctlinput */
0, /* pr_ctloutput */
0, /* pr_ousrreq */
0, /* pr_init */
0, /* pr_fasttimo */
0, /* pr_slowtimo */
0, /* pr_drain */
&atm_dgram_usrreqs, /* pr_usrreqs */
},
{ SOCK_SEQPACKET, /* AAL-5 */
&atmdomain,
ATM_PROTO_AAL5,
PR_ATOMIC|PR_CONNREQUIRED,
0, /* pr_input */
0, /* pr_output */
0, /* pr_ctlinput */
atm_aal5_ctloutput, /* pr_ctloutput */
0, /* pr_ousrreq */
0, /* pr_init */
0, /* pr_fasttimo */
0, /* pr_slowtimo */
0, /* pr_drain */
&atm_aal5_usrreqs, /* pr_usrreqs */
},
#ifdef XXX
{ SOCK_SEQPACKET, /* SSCOP */
&atmdomain,
ATM_PROTO_SSCOP,
PR_ATOMIC|PR_CONNREQUIRED|PR_WANTRCVD,
x, /* pr_input */
x, /* pr_output */
x, /* pr_ctlinput */
x, /* pr_ctloutput */
0, /* pr_ousrreq */
0, /* pr_init */
0, /* pr_fasttimo */
0, /* pr_slowtimo */
x, /* pr_drain */
x, /* pr_usrreqs */
},
#endif
};
struct domain atmdomain = {
AF_ATM,
"atm",
atm_initialize,
0,
0,
atmsw,
&atmsw[sizeof(atmsw) / sizeof(atmsw[0])]
};
DOMAIN_SET(atm);
SYSCTL_NODE(_net, PF_ATM, harp, CTLFLAG_RW, 0, "HARP/ATM family");
SYSCTL_NODE(_net_harp, OID_AUTO, atm, CTLFLAG_RW, 0, "ATM layer");
/*
* Protocol request not supported
*
* Arguments:
* so pointer to socket
*
* Returns:
* errno error - operation not supported
*
*/
int
atm_proto_notsupp1(so)
struct socket *so;
{
return (EOPNOTSUPP);
}
/*
* Protocol request not supported
*
* Arguments:
* so pointer to socket
* addr pointer to protocol address
* p pointer to process
*
* Returns:
* errno error - operation not supported
*
*/
int
atm_proto_notsupp2(so, addr, td)
struct socket *so;
struct sockaddr *addr;
struct thread *td;
{
return (EOPNOTSUPP);
}
/*
* Protocol request not supported
*
* Arguments:
* so pointer to socket
* addr pointer to pointer to protocol address
*
* Returns:
* errno error - operation not supported
*
*/
int
atm_proto_notsupp3(so, addr)
struct socket *so;
struct sockaddr **addr;
{
return (EOPNOTSUPP);
}
/*
* Protocol request not supported
*
* Arguments:
* so pointer to socket
* i integer
* m pointer to kernel buffer
* addr pointer to protocol address
* m2 pointer to kernel buffer
* p pointer to process
*
* Returns:
* errno error - operation not supported
*
*/
int
atm_proto_notsupp4(so, i, m, addr, m2, td)
struct socket *so;
int i;
KBuffer *m;
struct sockaddr *addr;
KBuffer *m2;
struct thread *td;
{
return (EOPNOTSUPP);
}