1*0Sstevel@tonic-gate /*
2*0Sstevel@tonic-gate * CDDL HEADER START
3*0Sstevel@tonic-gate *
4*0Sstevel@tonic-gate * The contents of this file are subject to the terms of the
5*0Sstevel@tonic-gate * Common Development and Distribution License, Version 1.0 only
6*0Sstevel@tonic-gate * (the "License"). You may not use this file except in compliance
7*0Sstevel@tonic-gate * with the License.
8*0Sstevel@tonic-gate *
9*0Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10*0Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing.
11*0Sstevel@tonic-gate * See the License for the specific language governing permissions
12*0Sstevel@tonic-gate * and limitations under the License.
13*0Sstevel@tonic-gate *
14*0Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each
15*0Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16*0Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the
17*0Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying
18*0Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner]
19*0Sstevel@tonic-gate *
20*0Sstevel@tonic-gate * CDDL HEADER END
21*0Sstevel@tonic-gate */
22*0Sstevel@tonic-gate /*
23*0Sstevel@tonic-gate * Copyright (c) 2002-2003, Network Appliance, Inc. All rights reserved.
24*0Sstevel@tonic-gate */
25*0Sstevel@tonic-gate
26*0Sstevel@tonic-gate /*
27*0Sstevel@tonic-gate * Copyright 2004 Sun Microsystems, Inc. All rights reserved.
28*0Sstevel@tonic-gate * Use is subject to license terms.
29*0Sstevel@tonic-gate */
30*0Sstevel@tonic-gate
31*0Sstevel@tonic-gate #pragma ident "%Z%%M% %I% %E% SMI"
32*0Sstevel@tonic-gate
33*0Sstevel@tonic-gate
34*0Sstevel@tonic-gate /*
35*0Sstevel@tonic-gate *
36*0Sstevel@tonic-gate * MODULE: udat_api.c
37*0Sstevel@tonic-gate *
38*0Sstevel@tonic-gate * PURPOSE: DAT Provider and Consumer registry functions.
39*0Sstevel@tonic-gate *
40*0Sstevel@tonic-gate */
41*0Sstevel@tonic-gate
42*0Sstevel@tonic-gate #include "dat_osd.h"
43*0Sstevel@tonic-gate #include <dat/dat_registry.h>
44*0Sstevel@tonic-gate
dat_lmr_create(IN DAT_IA_HANDLE ia_handle,IN DAT_MEM_TYPE mem_type,IN DAT_REGION_DESCRIPTION region_description,IN DAT_VLEN length,IN DAT_PZ_HANDLE pz_handle,IN DAT_MEM_PRIV_FLAGS privileges,OUT DAT_LMR_HANDLE * lmr_handle,OUT DAT_LMR_CONTEXT * lmr_context,OUT DAT_RMR_CONTEXT * rmr_context,OUT DAT_VLEN * registered_length,OUT DAT_VADDR * registered_address)45*0Sstevel@tonic-gate DAT_RETURN dat_lmr_create(
46*0Sstevel@tonic-gate IN DAT_IA_HANDLE ia_handle,
47*0Sstevel@tonic-gate IN DAT_MEM_TYPE mem_type,
48*0Sstevel@tonic-gate IN DAT_REGION_DESCRIPTION region_description,
49*0Sstevel@tonic-gate IN DAT_VLEN length,
50*0Sstevel@tonic-gate IN DAT_PZ_HANDLE pz_handle,
51*0Sstevel@tonic-gate IN DAT_MEM_PRIV_FLAGS privileges,
52*0Sstevel@tonic-gate OUT DAT_LMR_HANDLE *lmr_handle,
53*0Sstevel@tonic-gate OUT DAT_LMR_CONTEXT *lmr_context,
54*0Sstevel@tonic-gate OUT DAT_RMR_CONTEXT *rmr_context,
55*0Sstevel@tonic-gate OUT DAT_VLEN *registered_length,
56*0Sstevel@tonic-gate OUT DAT_VADDR *registered_address)
57*0Sstevel@tonic-gate {
58*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(ia_handle)) {
59*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE_IA));
60*0Sstevel@tonic-gate }
61*0Sstevel@tonic-gate return DAT_LMR_CREATE(ia_handle,
62*0Sstevel@tonic-gate mem_type,
63*0Sstevel@tonic-gate region_description,
64*0Sstevel@tonic-gate length,
65*0Sstevel@tonic-gate pz_handle,
66*0Sstevel@tonic-gate privileges,
67*0Sstevel@tonic-gate lmr_handle,
68*0Sstevel@tonic-gate lmr_context,
69*0Sstevel@tonic-gate rmr_context,
70*0Sstevel@tonic-gate registered_length,
71*0Sstevel@tonic-gate registered_address);
72*0Sstevel@tonic-gate }
73*0Sstevel@tonic-gate
74*0Sstevel@tonic-gate
dat_evd_create(IN DAT_IA_HANDLE ia_handle,IN DAT_COUNT evd_min_qlen,IN DAT_CNO_HANDLE cno_handle,IN DAT_EVD_FLAGS evd_flags,OUT DAT_EVD_HANDLE * evd_handle)75*0Sstevel@tonic-gate DAT_RETURN dat_evd_create(
76*0Sstevel@tonic-gate IN DAT_IA_HANDLE ia_handle,
77*0Sstevel@tonic-gate IN DAT_COUNT evd_min_qlen,
78*0Sstevel@tonic-gate IN DAT_CNO_HANDLE cno_handle,
79*0Sstevel@tonic-gate IN DAT_EVD_FLAGS evd_flags,
80*0Sstevel@tonic-gate OUT DAT_EVD_HANDLE *evd_handle)
81*0Sstevel@tonic-gate {
82*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(ia_handle)) {
83*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE_IA));
84*0Sstevel@tonic-gate }
85*0Sstevel@tonic-gate return DAT_EVD_CREATE(ia_handle,
86*0Sstevel@tonic-gate evd_min_qlen,
87*0Sstevel@tonic-gate cno_handle,
88*0Sstevel@tonic-gate evd_flags,
89*0Sstevel@tonic-gate evd_handle);
90*0Sstevel@tonic-gate }
91*0Sstevel@tonic-gate
92*0Sstevel@tonic-gate
dat_evd_modify_cno(IN DAT_EVD_HANDLE evd_handle,IN DAT_CNO_HANDLE cno_handle)93*0Sstevel@tonic-gate DAT_RETURN dat_evd_modify_cno(
94*0Sstevel@tonic-gate IN DAT_EVD_HANDLE evd_handle,
95*0Sstevel@tonic-gate IN DAT_CNO_HANDLE cno_handle)
96*0Sstevel@tonic-gate {
97*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(evd_handle)) {
98*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE1));
99*0Sstevel@tonic-gate }
100*0Sstevel@tonic-gate return DAT_EVD_MODIFY_CNO(evd_handle,
101*0Sstevel@tonic-gate cno_handle);
102*0Sstevel@tonic-gate }
103*0Sstevel@tonic-gate
104*0Sstevel@tonic-gate
dat_cno_create(IN DAT_IA_HANDLE ia_handle,IN DAT_OS_WAIT_PROXY_AGENT agent,OUT DAT_CNO_HANDLE * cno_handle)105*0Sstevel@tonic-gate DAT_RETURN dat_cno_create(
106*0Sstevel@tonic-gate IN DAT_IA_HANDLE ia_handle,
107*0Sstevel@tonic-gate IN DAT_OS_WAIT_PROXY_AGENT agent,
108*0Sstevel@tonic-gate OUT DAT_CNO_HANDLE *cno_handle)
109*0Sstevel@tonic-gate {
110*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(ia_handle)) {
111*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE_IA));
112*0Sstevel@tonic-gate }
113*0Sstevel@tonic-gate return DAT_CNO_CREATE(ia_handle,
114*0Sstevel@tonic-gate agent,
115*0Sstevel@tonic-gate cno_handle);
116*0Sstevel@tonic-gate }
117*0Sstevel@tonic-gate
118*0Sstevel@tonic-gate
dat_cno_modify_agent(IN DAT_CNO_HANDLE cno_handle,IN DAT_OS_WAIT_PROXY_AGENT agent)119*0Sstevel@tonic-gate DAT_RETURN dat_cno_modify_agent(
120*0Sstevel@tonic-gate IN DAT_CNO_HANDLE cno_handle,
121*0Sstevel@tonic-gate IN DAT_OS_WAIT_PROXY_AGENT agent)
122*0Sstevel@tonic-gate {
123*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(cno_handle)) {
124*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE_CNO));
125*0Sstevel@tonic-gate }
126*0Sstevel@tonic-gate return DAT_CNO_MODIFY_AGENT(cno_handle,
127*0Sstevel@tonic-gate agent);
128*0Sstevel@tonic-gate }
129*0Sstevel@tonic-gate
130*0Sstevel@tonic-gate
dat_cno_query(IN DAT_CNO_HANDLE cno_handle,IN DAT_CNO_PARAM_MASK cno_param_mask,OUT DAT_CNO_PARAM * cno_param)131*0Sstevel@tonic-gate DAT_RETURN dat_cno_query(
132*0Sstevel@tonic-gate IN DAT_CNO_HANDLE cno_handle,
133*0Sstevel@tonic-gate IN DAT_CNO_PARAM_MASK cno_param_mask,
134*0Sstevel@tonic-gate OUT DAT_CNO_PARAM *cno_param)
135*0Sstevel@tonic-gate {
136*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(cno_handle)) {
137*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE_CNO));
138*0Sstevel@tonic-gate }
139*0Sstevel@tonic-gate return DAT_CNO_QUERY(cno_handle,
140*0Sstevel@tonic-gate cno_param_mask,
141*0Sstevel@tonic-gate cno_param);
142*0Sstevel@tonic-gate }
143*0Sstevel@tonic-gate
144*0Sstevel@tonic-gate
dat_cno_free(IN DAT_CNO_HANDLE cno_handle)145*0Sstevel@tonic-gate DAT_RETURN dat_cno_free(
146*0Sstevel@tonic-gate IN DAT_CNO_HANDLE cno_handle)
147*0Sstevel@tonic-gate {
148*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(cno_handle)) {
149*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE_CNO));
150*0Sstevel@tonic-gate }
151*0Sstevel@tonic-gate return (DAT_CNO_FREE(cno_handle));
152*0Sstevel@tonic-gate }
153*0Sstevel@tonic-gate
154*0Sstevel@tonic-gate
dat_cno_wait(IN DAT_CNO_HANDLE cno_handle,IN DAT_TIMEOUT timeout,OUT DAT_EVD_HANDLE * evd_handle)155*0Sstevel@tonic-gate DAT_RETURN dat_cno_wait(
156*0Sstevel@tonic-gate IN DAT_CNO_HANDLE cno_handle,
157*0Sstevel@tonic-gate IN DAT_TIMEOUT timeout,
158*0Sstevel@tonic-gate OUT DAT_EVD_HANDLE *evd_handle)
159*0Sstevel@tonic-gate {
160*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(cno_handle)) {
161*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE_CNO));
162*0Sstevel@tonic-gate }
163*0Sstevel@tonic-gate return DAT_CNO_WAIT(cno_handle,
164*0Sstevel@tonic-gate timeout,
165*0Sstevel@tonic-gate evd_handle);
166*0Sstevel@tonic-gate }
167*0Sstevel@tonic-gate
168*0Sstevel@tonic-gate
dat_evd_enable(IN DAT_EVD_HANDLE evd_handle)169*0Sstevel@tonic-gate DAT_RETURN dat_evd_enable(
170*0Sstevel@tonic-gate IN DAT_EVD_HANDLE evd_handle)
171*0Sstevel@tonic-gate {
172*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(evd_handle)) {
173*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE1));
174*0Sstevel@tonic-gate }
175*0Sstevel@tonic-gate return (DAT_EVD_ENABLE(evd_handle));
176*0Sstevel@tonic-gate }
177*0Sstevel@tonic-gate
178*0Sstevel@tonic-gate
dat_evd_wait(IN DAT_EVD_HANDLE evd_handle,IN DAT_TIMEOUT Timeout,IN DAT_COUNT Threshold,OUT DAT_EVENT * event,OUT DAT_COUNT * n_more_events)179*0Sstevel@tonic-gate DAT_RETURN dat_evd_wait(
180*0Sstevel@tonic-gate IN DAT_EVD_HANDLE evd_handle,
181*0Sstevel@tonic-gate IN DAT_TIMEOUT Timeout,
182*0Sstevel@tonic-gate IN DAT_COUNT Threshold,
183*0Sstevel@tonic-gate OUT DAT_EVENT *event,
184*0Sstevel@tonic-gate OUT DAT_COUNT *n_more_events)
185*0Sstevel@tonic-gate {
186*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(evd_handle)) {
187*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE1));
188*0Sstevel@tonic-gate }
189*0Sstevel@tonic-gate return DAT_EVD_WAIT(evd_handle,
190*0Sstevel@tonic-gate Timeout,
191*0Sstevel@tonic-gate Threshold,
192*0Sstevel@tonic-gate event,
193*0Sstevel@tonic-gate n_more_events);
194*0Sstevel@tonic-gate }
195*0Sstevel@tonic-gate
196*0Sstevel@tonic-gate
dat_evd_disable(IN DAT_EVD_HANDLE evd_handle)197*0Sstevel@tonic-gate DAT_RETURN dat_evd_disable(
198*0Sstevel@tonic-gate IN DAT_EVD_HANDLE evd_handle)
199*0Sstevel@tonic-gate {
200*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(evd_handle)) {
201*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE1));
202*0Sstevel@tonic-gate }
203*0Sstevel@tonic-gate return (DAT_EVD_DISABLE(evd_handle));
204*0Sstevel@tonic-gate }
205*0Sstevel@tonic-gate
206*0Sstevel@tonic-gate
dat_evd_set_unwaitable(IN DAT_EVD_HANDLE evd_handle)207*0Sstevel@tonic-gate DAT_RETURN dat_evd_set_unwaitable(
208*0Sstevel@tonic-gate IN DAT_EVD_HANDLE evd_handle)
209*0Sstevel@tonic-gate {
210*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(evd_handle)) {
211*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE1));
212*0Sstevel@tonic-gate }
213*0Sstevel@tonic-gate return (DAT_EVD_SET_UNWAITABLE(evd_handle));
214*0Sstevel@tonic-gate }
215*0Sstevel@tonic-gate
dat_evd_clear_unwaitable(IN DAT_EVD_HANDLE evd_handle)216*0Sstevel@tonic-gate DAT_RETURN dat_evd_clear_unwaitable(
217*0Sstevel@tonic-gate IN DAT_EVD_HANDLE evd_handle)
218*0Sstevel@tonic-gate {
219*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(evd_handle)) {
220*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE1));
221*0Sstevel@tonic-gate }
222*0Sstevel@tonic-gate return (DAT_EVD_CLEAR_UNWAITABLE(evd_handle));
223*0Sstevel@tonic-gate }
224*0Sstevel@tonic-gate
dat_cr_handoff(IN DAT_CR_HANDLE cr_handle,IN DAT_CONN_QUAL handoff)225*0Sstevel@tonic-gate DAT_RETURN dat_cr_handoff(
226*0Sstevel@tonic-gate IN DAT_CR_HANDLE cr_handle,
227*0Sstevel@tonic-gate IN DAT_CONN_QUAL handoff)
228*0Sstevel@tonic-gate {
229*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(cr_handle)) {
230*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE_CR));
231*0Sstevel@tonic-gate }
232*0Sstevel@tonic-gate return DAT_CR_HANDOFF(cr_handle,
233*0Sstevel@tonic-gate handoff);
234*0Sstevel@tonic-gate }
235*0Sstevel@tonic-gate
236*0Sstevel@tonic-gate
dat_psp_create_any(IN DAT_IA_HANDLE ia_handle,OUT DAT_CONN_QUAL * conn_qual,IN DAT_EVD_HANDLE evd_handle,IN DAT_PSP_FLAGS psp_flags,OUT DAT_PSP_HANDLE * psp_handle)237*0Sstevel@tonic-gate DAT_RETURN dat_psp_create_any(
238*0Sstevel@tonic-gate IN DAT_IA_HANDLE ia_handle,
239*0Sstevel@tonic-gate OUT DAT_CONN_QUAL *conn_qual,
240*0Sstevel@tonic-gate IN DAT_EVD_HANDLE evd_handle,
241*0Sstevel@tonic-gate IN DAT_PSP_FLAGS psp_flags,
242*0Sstevel@tonic-gate OUT DAT_PSP_HANDLE *psp_handle)
243*0Sstevel@tonic-gate {
244*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(ia_handle)) {
245*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE_IA));
246*0Sstevel@tonic-gate }
247*0Sstevel@tonic-gate return DAT_PSP_CREATE_ANY(ia_handle,
248*0Sstevel@tonic-gate conn_qual,
249*0Sstevel@tonic-gate evd_handle,
250*0Sstevel@tonic-gate psp_flags,
251*0Sstevel@tonic-gate psp_handle);
252*0Sstevel@tonic-gate }
253*0Sstevel@tonic-gate
254*0Sstevel@tonic-gate
dat_ia_query(IN DAT_IA_HANDLE ia_handle,OUT DAT_EVD_HANDLE * async_evd_handle,IN DAT_IA_ATTR_MASK ia_attr_mask,OUT DAT_IA_ATTR * ia_attr,IN DAT_PROVIDER_ATTR_MASK provider_attr_mask,OUT DAT_PROVIDER_ATTR * provider_attr)255*0Sstevel@tonic-gate DAT_RETURN dat_ia_query(
256*0Sstevel@tonic-gate IN DAT_IA_HANDLE ia_handle,
257*0Sstevel@tonic-gate OUT DAT_EVD_HANDLE *async_evd_handle,
258*0Sstevel@tonic-gate IN DAT_IA_ATTR_MASK ia_attr_mask,
259*0Sstevel@tonic-gate OUT DAT_IA_ATTR *ia_attr,
260*0Sstevel@tonic-gate IN DAT_PROVIDER_ATTR_MASK provider_attr_mask,
261*0Sstevel@tonic-gate OUT DAT_PROVIDER_ATTR *provider_attr)
262*0Sstevel@tonic-gate {
263*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(ia_handle)) {
264*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE_IA));
265*0Sstevel@tonic-gate }
266*0Sstevel@tonic-gate return DAT_IA_QUERY(ia_handle,
267*0Sstevel@tonic-gate async_evd_handle,
268*0Sstevel@tonic-gate ia_attr_mask,
269*0Sstevel@tonic-gate ia_attr,
270*0Sstevel@tonic-gate provider_attr_mask,
271*0Sstevel@tonic-gate provider_attr);
272*0Sstevel@tonic-gate }
273*0Sstevel@tonic-gate
274*0Sstevel@tonic-gate
dat_evd_query(IN DAT_EVD_HANDLE evd_handle,IN DAT_EVD_PARAM_MASK evd_param_mask,OUT DAT_EVD_PARAM * evd_param)275*0Sstevel@tonic-gate DAT_RETURN dat_evd_query(
276*0Sstevel@tonic-gate IN DAT_EVD_HANDLE evd_handle,
277*0Sstevel@tonic-gate IN DAT_EVD_PARAM_MASK evd_param_mask,
278*0Sstevel@tonic-gate OUT DAT_EVD_PARAM *evd_param)
279*0Sstevel@tonic-gate {
280*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(evd_handle)) {
281*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE1));
282*0Sstevel@tonic-gate }
283*0Sstevel@tonic-gate return DAT_EVD_QUERY(evd_handle,
284*0Sstevel@tonic-gate evd_param_mask,
285*0Sstevel@tonic-gate evd_param);
286*0Sstevel@tonic-gate }
287*0Sstevel@tonic-gate
288*0Sstevel@tonic-gate
dat_lmr_query(IN DAT_LMR_HANDLE lmr_handle,IN DAT_LMR_PARAM_MASK lmv_param_mask,OUT DAT_LMR_PARAM * lmr_param)289*0Sstevel@tonic-gate DAT_RETURN dat_lmr_query(
290*0Sstevel@tonic-gate IN DAT_LMR_HANDLE lmr_handle,
291*0Sstevel@tonic-gate IN DAT_LMR_PARAM_MASK lmv_param_mask,
292*0Sstevel@tonic-gate OUT DAT_LMR_PARAM *lmr_param)
293*0Sstevel@tonic-gate {
294*0Sstevel@tonic-gate if (DAT_BAD_HANDLE(lmr_handle)) {
295*0Sstevel@tonic-gate return (DAT_ERROR(DAT_INVALID_HANDLE, DAT_INVALID_HANDLE_LMR));
296*0Sstevel@tonic-gate }
297*0Sstevel@tonic-gate return DAT_LMR_QUERY(lmr_handle,
298*0Sstevel@tonic-gate lmv_param_mask,
299*0Sstevel@tonic-gate lmr_param);
300*0Sstevel@tonic-gate }
301