2 .\" Copyright (c) 2001, Sun Microsystems, Inc., All Rights Reserved
3 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License"). You may not use this file except in compliance with the License.
4 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing. See the License for the specific language governing permissions and limitations under the License.
5 .\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE. If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
6 .TH DDI_PROP_LOOKUP 9F "Apr 11, 2001"
8 ddi_prop_lookup, ddi_prop_lookup_int_array, ddi_prop_lookup_int64_array,
9 ddi_prop_lookup_string_array, ddi_prop_lookup_string,
10 ddi_prop_lookup_byte_array, ddi_prop_free \- look up property information
15 #include <sys/sunddi.h>
19 \fBint\fR \fBddi_prop_lookup_int_array\fR(\fBdev_t\fR \fImatch_dev\fR, \fBdev_info_t *\fR\fIdip\fR,
20 \fBuint_t\fR \fIflags\fR, \fBchar *\fR\fIname\fR, \fBint **\fR\fIdatap\fR, \fBuint_t *\fR\fInelementsp\fR);
25 \fBint\fR \fBddi_prop_lookup_int64_array\fR(\fBdev_t\fR \fImatch_dev\fR, \fBdev_info_t *\fR\fIdip\fR,
26 \fBuint_t\fR \fIflags\fR, \fBchar *\fR\fIname\fR, \fBint64_t **\fR\fIdatap\fR, \fBuint_t *\fR\fInelementsp\fR);
31 \fBint\fR \fBddi_prop_lookup_string_array\fR(\fBdev_t\fR \fImatch_dev\fR, \fBdev_info_t *\fR\fIdip\fR,
32 \fBuint_t\fR \fIflags\fR, \fBchar *\fR\fIname\fR, \fBchar ***\fR\fIdatap\fR, \fBuint_t *\fR\fInelementsp\fR);
37 \fBint\fR \fBddi_prop_lookup_string\fR(\fBdev_t\fR \fImatch_dev\fR, \fBdev_info_t *\fR\fIdip\fR, \fBuint_t\fR \fIflags\fR,
38 \fBchar *\fR\fIname\fR, \fBchar **\fR\fIdatap\fR);
43 \fBint\fR \fBddi_prop_lookup_byte_array\fR(\fBdev_t\fR \fImatch_dev\fR, \fBdev_info_t *\fR\fIdip\fR,
44 \fBuint_t\fR \fIflags\fR, \fBchar *\fR\fIname\fR, \fBuchar_t **\fR\fIdatap\fR, \fBuint_t *\fR\fInelementsp\fR);
49 \fBvoid\fR \fBddi_prop_free\fR(\fBvoid *\fR\fIdata\fR);
59 Device number associated with property or \fBDDI_DEV_T_ANY.\fR
68 Pointer to the device info node of device whose property list should be
78 Possible flag values are some combination of:
82 \fB\fBDDI_PROP_DONTPASS\fR\fR
85 Do not pass request to parent device information node if the property is not
92 \fB\fBDDI_PROP_NOTPROM\fR\fR
95 Do not look at \fBPROM \fRproperties (ignored on platforms that do not support
96 \fBPROM \fRproperties).
107 String containing the name of the property.
113 \fB\fInelementsp\fR\fR
116 The address of an unsigned integer which, upon successful return, will contain
117 the number of elements accounted for in the memory pointed at by \fIdatap\fR.
118 The elements are either integers, strings or bytes depending on the interface
131 \fB\fBddi_prop_lookup_int_array()\fR\fR
135 The address of a pointer to an array of integers which, upon successful return,
136 will point to memory containing the integer array property value.
142 \fB\fBddi_prop_lookup_int64_array()\fR\fR
146 The address of a pointer to an array of 64-bit integers which, upon successful
147 return, will point to memory containing the integer array property value.
153 \fB\fBddi_prop_lookup_string_array()\fR\fR
157 The address of a pointer to an array of strings which, upon successful return,
158 will point to memory containing the array of strings. The array of strings is
159 formatted as an array of pointers to \fBNULL \fRterminated strings, much like
160 the \fIargv\fR argument to \fBexecve\fR(2).
166 \fB\fBddi_prop_lookup_string()\fR\fR
170 The address of a pointer to a string which, upon successful return, will point
171 to memory containing the \fBNULL \fRterminated string value of the property.
177 \fB\fBddi_prop_lookup_byte_array()\fR\fR
181 The address of pointer to an array of bytes which, upon successful return, will
182 point to memory containing the byte array value of the property.
190 Solaris DDI specific (Solaris DDI).
194 The property look up routines search for and, if found, return the value of a
195 given property. Properties are searched for based on the \fIdip\fR, \fIname\fR,
196 \fImatch_dev\fR, and the type of the data (integer, string, or byte). The
197 property search order is as follows:
201 Search software properties created by the driver.
206 Search the software properties created by the system (or nexus nodes in the
212 Search the driver global properties list.
217 If \fBDDI_PROP_NOTPROM\fR is not set, search the \fBPROM \fRproperties (if
223 If \fBDDI_PROP_DONTPASS\fR is not set, pass this request to the parent
224 device information node.
229 Return \fBDDI_PROP_NOT_FOUND\fR.
233 Usually, the \fImatch_dev\fR argument should be set to the actual device number
234 that this property is associated with. However, if the \fImatch_dev\fR argument
235 is \fBDDI_DEV_T_ANY\fR, the property look up routines will match the request
236 regardless of the actual \fImatch_dev\fR the property was created with. If a
237 property was created with \fImatch_dev\fR set to \fBDDI_DEV_T_NONE\fR, then the
238 only way to look up this property is with a \fImatch_dev\fR set to
239 \fBDDI_DEV_T_ANY\fR. \fBPROM \fRproperties are always created with
240 \fImatch_dev\fR set to \fBDDI_DEV_T_NONE\fR.
243 \fIname\fR must always be set to the name of the property being looked up.
246 For the routines \fBddi_prop_lookup_int_array()\fR,
247 \fBddi_prop_lookup_int64_array()\fR, \fBddi_prop_lookup_string_array()\fR,
248 \fBddi_prop_lookup_string()\fR, and \fBddi_prop_lookup_byte_array()\fR,
249 \fIdatap\fR is the address of a pointer which, upon successful return, will
250 point to memory containing the value of the property. In each case \fI*datap\fR
251 points to a different type of property value. See the individual descriptions
252 of the routines below for details on the different return values.
253 \fInelementsp\fR is the address of an unsigned integer which, upon successful
254 return, will contain the number of integer, string or byte elements accounted
255 for in the memory pointed at by \fI*datap\fR.
258 All of the property look up routines may block to allocate memory needed to
259 hold the value of the property.
262 When a driver has obtained a property with any look up routine and is finished
263 with that property, it must be freed by calling \fBddi_prop_free()\fR.
264 \fBddi_prop_free()\fR must be called with the address of the allocated
265 property. For instance, if one called \fBddi_prop_lookup_int_array()\fR with
266 \fIdatap\fR set to the address of a pointer to an integer, \fI&my_int_ptr\fR,
267 then the companion free call would be
268 \fBddi_prop_free(\fR\fImy_int_ptr\fR\fB)\fR.
272 \fB\fBddi_prop_lookup_int_array()\fR\fR
276 This routine searches for and returns an array of integer property values. An
277 array of integers is defined to \fI*nelementsp\fR number of 4 byte long integer
278 elements. \fIdatap\fR should be set to the address of a pointer to an array of
279 integers which, upon successful return, will point to memory containing the
280 integer array value of the property.
286 \fB\fBddi_prop_lookup_int64_array()\fR\fR
290 This routine searches for and returns an array of 64-bit integer property
291 values. The array is defined to be *\fInelementsp\fR number of \fBint64_t\fR
292 elements. \fIdatap\fR should be set to the address of a pointer to an array of
293 \fBint64_t\fR's which, upon successful return, will point to memory containing
294 the integer array value of the property. This routine will not search the PROM
295 for 64-bit property values.
301 \fB\fBddi_prop_lookup_string_array()\fR\fR
305 This routine searches for and returns a property that is an array of strings.
306 \fIdatap\fR should be set to address of a pointer to an array of strings which,
307 upon successful return, will point to memory containing the array of strings.
308 The array of strings is formatted as an array of pointers to null-terminated
309 strings, much like the \fIargv\fR argument to \fBexecve\fR(2).
315 \fB\fBddi_prop_lookup_string()\fR\fR
319 This routine searches for and returns a property that is a null-terminated
320 string. \fIdatap\fR should be set to the address of a pointer to string which,
321 upon successful return, will point to memory containing the string value of the
328 \fB\fBddi_prop_lookup_byte_array()\fR\fR
332 This routine searches for and returns a property that is an array of bytes.
333 \fIdatap\fR should be set to the address of a pointer to an array of bytes
334 which, upon successful return, will point to memory containing the byte array
335 value of the property.
341 \fB\fBddi_prop_free()\fR\fR
345 Frees the resources associated with a property previously allocated using
346 \fBddi_prop_lookup_int_array()\fR, \fBddi_prop_lookup_int64_array()\fR,
347 \fBddi_prop_lookup_string_array()\fR, \fBddi_prop_lookup_string()\fR, or
348 \fBddi_prop_lookup_byte_array()\fR.
354 The functions \fBddi_prop_lookup_int_array()\fR,
355 \fBddi_prop_lookup_int64_array()\fR, \fBddi_prop_lookup_string_array()\fR,
356 \fBddi_prop_lookup_string()\fR, and \fBddi_prop_lookup_byte_array()\fR return
357 the following values:
361 \fB\fBDDI_PROP_SUCCESS\fR\fR
370 \fB\fBDDI_PROP_INVAL_ARG\fR\fR
373 If an attempt is made to look up a property with \fImatch_dev\fR equal to
374 \fBDDI_DEV_T_NONE\fR, \fIname\fR is \fBNULL \fRor \fIname\fR is the null
381 \fB\fBDDI_PROP_NOT_FOUND\fR\fR
390 \fB\fBDDI_PROP_UNDEFINED\fR\fR
393 Property explicitly not defined (see \fBddi_prop_undefine\fR(9F)).
399 \fB\fBDDI_PROP_CANNOT_DECODE\fR\fR
402 The value of the property cannot be decoded.
408 These functions can be called from user or kernel context.
411 \fBExample 1 \fRUsing \fBddi_prop_lookup_int_array()\fR
414 The following example demonstrates the use of
415 \fBddi_prop_lookup_int_array()\fR.
425 * Get the data associated with the integer "options" property
426 * array, along with the number of option integers
428 if (ddi_prop_lookup_int_array(DDI_DEV_T_ANY, xx_dip, 0,
429 "options", &options, &noptions) == DDI_PROP_SUCCESS) {
431 * Do "our thing" with the options data from the property
433 xx_process_options(options, noptions);
436 * Free the memory allocated for the property data
438 ddi_prop_free(options);
446 \fBexecve\fR(2), \fBddi_prop_exists\fR(9F), \fBddi_prop_get_int\fR(9F),
447 \fBddi_prop_remove\fR(9F), \fBddi_prop_undefine\fR(9F),
448 \fBddi_prop_update\fR(9F)
451 \fIWriting Device Drivers\fR