xref: /illumos-gate/usr/src/uts/common/sys/idm/idm_so.h (revision abddfefb3168362a915cd681eb5a6498ec6c9e09)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License (the "License").
6  * You may not use this file except in compliance with the License.
7  *
8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9  * or http://www.opensolaris.org/os/licensing.
10  * See the License for the specific language governing permissions
11  * and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL HEADER in each
14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15  * If applicable, add the following below this CDDL HEADER, with the
16  * fields enclosed by brackets "[]" replaced with your own identifying
17  * information: Portions Copyright [yyyy] [name of copyright owner]
18  *
19  * CDDL HEADER END
20  */
21 /*
22  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
23  * Use is subject to license terms.
24  */
25 
26 #ifndef _IDM_SO_H
27 #define	_IDM_SO_H
28 
29 #ifdef	__cplusplus
30 extern "C" {
31 #endif
32 
33 #include <sys/idm/idm_transport.h>
34 #include <sys/ksocket.h>
35 
36 /*
37  * Define TCP window size (send and receive buffer sizes)
38  */
39 
40 #define	IDM_RCVBUF_SIZE		(256 * 1024)
41 #define	IDM_SNDBUF_SIZE		(256 * 1024)
42 
43 /*
44  * Lower and upper bounds to use the 128k buffer cache.  Below the lower bound
45  * allocations will use the built-in Solaris buffer caches.  We don't expect
46  * to see allocations above the upper bound because SBD currently allocates
47  * 128k buffers.
48  */
49 
50 #define	IDM_SO_BUF_CACHE_LB	(32 * 1024)
51 #define	IDM_SO_BUF_CACHE_UB	(128 * 1024)
52 
53 /* sockets-specific portion of idm_svc_t */
54 typedef struct idm_so_svc_s {
55 	ksocket_t		is_so;
56 	kthread_t		*is_thread;
57 	kt_did_t		is_thread_did;
58 	boolean_t		is_thread_running;
59 } idm_so_svc_t;
60 
61 /* sockets-specific portion of idm_conn_t */
62 typedef struct idm_so_conn_s {
63 	ksocket_t		ic_so;
64 
65 	kthread_t		*ic_tx_thread;
66 	kt_did_t		ic_tx_thread_did;
67 	boolean_t		ic_tx_thread_running;
68 	kmutex_t		ic_tx_mutex;
69 	kcondvar_t		ic_tx_cv;
70 	list_t			ic_tx_list;	/* List of PDUs for transmit */
71 
72 	kthread_t		*ic_rx_thread;
73 	kt_did_t		ic_rx_thread_did;
74 	boolean_t		ic_rx_thread_running;
75 } idm_so_conn_t;
76 
77 void idm_so_init(idm_transport_t *it);
78 void idm_so_fini();
79 
80 /* Socket functions */
81 
82 ksocket_t
83 idm_socreate(int domain, int type, int protocol);
84 
85 void idm_soshutdown(ksocket_t so);
86 
87 void idm_sodestroy(ksocket_t so);
88 
89 int idm_ss_compare(const struct sockaddr_storage *cmp_ss1,
90     const struct sockaddr_storage *cmp_ss2,
91     boolean_t v4_mapped_as_v4);
92 
93 int idm_get_ipaddr(idm_addr_list_t **);
94 
95 int idm_sorecv(ksocket_t so, void *msg, size_t len);
96 
97 int idm_sosendto(ksocket_t so, void *buff, size_t len,
98     struct sockaddr *name, socklen_t namelen);
99 
100 int idm_iov_sosend(ksocket_t so, iovec_t *iop, int iovlen,
101     size_t total_len);
102 
103 int idm_iov_sorecv(ksocket_t so, iovec_t *iop, int iovlen,
104     size_t total_len);
105 
106 void idm_sotx_thread(void *arg);
107 void idm_sorx_thread(void *arg);
108 
109 
110 int idm_sotx_pdu_constructor(void *hdl, void *arg, int flags);
111 
112 void idm_sotx_pdu_destructor(void *pdu_void, void *arg);
113 
114 int idm_sorx_pdu_constructor(void *hdl, void *arg, int flags);
115 
116 void idm_sorx_pdu_destructor(void *pdu_void, void *arg);
117 
118 void idm_so_svc_port_watcher(void *arg);
119 
120 
121 #ifdef	__cplusplus
122 }
123 #endif
124 
125 #endif /* _IDM_SO_H */
126