2 .\" Copyright (c) 2009, 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. You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing.
4 .\" See the License for the specific language governing permissions and limitations under the License. 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
5 .\" the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
6 .TH DDI_DEVID_COMPARE 9F "May 21, 2009"
8 ddi_devid_compare, ddi_devid_free, ddi_devid_init, ddi_devid_register,
9 ddi_devid_sizeof, ddi_devid_str_decode, ddi_devid_str_encode,
10 ddi_devid_str_free, ddi_devid_get, ddi_devid_unregister, ddi_devid_valid \-
11 kernel interfaces for device ids
15 \fBint\fR \fBddi_devid_compare\fR(\fBddi_devid_t\fR \fIdevid1\fR, \fBddi_devid_t\fR \fIdevid2\fR);
20 \fBsize_t\fR \fBddi_devid_sizeof\fR(\fBddi_devid_t\fR \fIdevid\fR);
25 \fBint\fR \fBddi_devid_init\fR(\fBdev_info_t *\fR\fIdip\fR, \fBushort_t\fR \fIdevid_type\fR,
26 \fBushort_t\fR \fInbytes\fR, \fBvoid *\fR\fIid\fR, \fBddi_devid_t *\fR\fIretdevid\fR);
31 \fBvoid\fR \fBddi_devid_free\fR(\fBddi_devid_t\fR \fIdevid\fR);
36 \fBint\fR \fBddi_devid_register\fR(\fBdev_info_t *\fR\fIdip\fR, \fBddi_devid_t\fR \fIdevid\fR);
41 \fBint\fR \fBddi_devid_str_decode\fR(\fBchar *\fR\fIdevidstr\fR, \fBddi_devid_t *\fR\fIretdevid\fR,
42 \fBchar **\fR\fIretminor_name\fR);
47 \fBint\fR \fBddi_devid_str_encode\fR(\fBddi_devid_t\fR \fIdevid\fR, \fBchar *\fR\fIminor_name\fR);
52 \fBint\fR \fBddi_devid_str_free\fR(\fBchar *\fR\fIdevidstr\fR);
57 \fBint\fR \fBddi_devid_get\fR(\fBdev_info_t *\fR\fIdip\fR, \fBddi_devid_t *\fR\fIretdevid\fR);
62 \fBvoid\fR \fBddi_devid_unregister\fR(\fBdev_info_t *\fR\fIdip\fR);
67 \fBint\fR \fBddi_devid_valid\fR(\fBddi_devid_t\fR \fIdevid\fR);
77 The device id address.
86 The \fIdevid\fR and \fIminor_name\fR represented as a string.
95 The first of two device id addresses to be compared calling
96 \fBddi_devid_compare()\fR.
105 The second of two device id addresses to be compared calling
106 \fBddi_devid_compare()\fR.
115 A \fBdev_info\fR pointer, which identifies the device.
121 \fB\fIdevid_type\fR\fR
124 The following device id types may be accepted by the \fBddi_devid_init()\fR
129 \fB\fBDEVID_SCSI3_WWN\fR\fR
132 World Wide Name associated with SCSI-3 devices.
138 \fB\fBDEVID_SCSI_SERIAL\fR\fR
141 Vendor \fBID\fRand serial number associated with a SCSI device. Note: This may
142 only be used if known to be unique; otherwise a fabricated device id must be
149 \fB\fBDEVID_ENCAP\fR\fR
152 Device \fBID\fR of another device. This is for layered device driver usage.
158 \fB\fBDEVID_FAB\fR\fR
161 Fabricated device \fBID\fR.
169 \fB\fIminor_name\fR\fR
172 The minor name to be encoded.
181 The length in bytes of device \fBID\fR.
190 The return address of the device \fBID\fR.
196 \fB\fIretminor_name\fR\fR
199 The return address of a minor name. Free string with
200 \fBddi_devid_str_free()\fR.
206 Solaris DDI specific (Solaris DDI).
210 The following routines are used to provide unique identifiers, device
211 \fBID\fRs, for devices. Specifically, kernel modules use these interfaces to
212 identify and locate devices, independent of the device's physical connection or
213 its logical device name or number.
216 \fBddi_devid_compare()\fR compares two device \fBID\fRs byte-by-byte and
217 determines both equality and sort order.
220 \fBddi_devid_sizeof()\fR returns the number of bytes allocated for the passed
221 in device \fBID\fR (\fIdevid\fR).
224 \fBddi_devid_init()\fR allocates memory and initializes the opaque device
225 \fBID\fR structure. This function does not store the \fIdevid\fR. If the device
226 id is not derived from the device's firmware, it is the driver's responsibility
227 to store the \fIdevid\fR on some reliable store. When a \fIdevid_type\fR of
228 either \fBDEVID_SCSI3_WWN,\fR \fBDEVID_SCSI_SERIAL\fR, or \fBDEVID_ENCAP\fR is
229 accepted, an array of bytes (\fIid\fR) must be passed in (\fInbytes\fR).
232 When the \fIdevid_type\fR \fBDEVID_FAB\fR is used, the array of bytes
233 (\fIid\fR) must be \fBNULL\fR and the length (\fInbytes\fR) must be zero. The
234 fabricated device ids, \fBDEVID_FAB\fR will be initialized with the machine's
235 host id and a timestamp.
238 Drivers must free the memory allocated by this function, using the
239 \fBddi_devid_free()\fR function.
242 \fBddi_devid_free()\fR frees the memory allocated for the returned \fIdevid\fR
243 by the \fBddi_devid_init()\fR and \fBdevid_str_decode()\fR functions.
246 \fBddi_devid_register()\fR registers the device \fBID\fR address (\fIdevid\fR)
247 with the \fBDDI\fR framework, associating it with the \fBdev_info\fR passed in
248 (\fIdip\fR). The drivers must register device \fBID\fRs at attach time. See
252 \fBddi_devid_unregister()\fR removes the device \fBID\fR address from the
253 \fBdev_info\fR passed in (\fIdip\fR). Drivers must use this function to
254 unregister the device \fBID\fR when devices are being detached. This function
255 does not free the space allocated for the device \fBID\fR. The driver must free
256 the space allocated for the device \fBID\fR, using the \fBddi_devid_free()\fR
257 function. See \fBdetach\fR(9E).
260 \fBddi_devid_valid()\fR validates the device \fBID\fR (\fIdevid\fR) passed in.
261 The driver must use this function to validate any fabricated device \fBID\fR
262 that has been stored on a device.
265 The \fBddi_devid_get()\fR function returns a pointer to the device ID structure
266 through \fIretdevid\fR if there is already a registered device ID associated
267 with the \fBdev_info\fR node. A driver can use this interface to check and get
268 the device ID associated with the \fBdev_info\fR node. It returns
269 \fBDDI_FAILURE\fR if no device ID is registered for the node.
272 The \fBddi_devid_get()\fR function allocates memory for the opaque device ID
273 structure and initializes it with the associated device ID and returns the
274 pointer to it. The driver must free the memory allocated by this function using
275 the \fBddi_devid_free()\fR function.
278 The \fBddi_devid_str_encode()\fR function encodes a \fIdevid\fR and minor_name
279 into a null-terminated ASCII string, returning a pointer to that string. If
280 both a \fIdevid\fR and a \fIminor_name\fR are non-null, then a slash (\fB/\fR)
281 is used to separate the \fIdevid\fR from the \fIminor_name\fR in the encoded
282 string. If \fIminor_name\fR is null, then only the \fIdevid\fR is encoded. If
283 the \fIdevid\fR is null, then the special string \fBid0\fR is returned. Note
284 that you cannot compare the returned string against another string with
285 \fBstrcmp()\fR to determine \fIdevid\fR equality. The returned string must be
286 freed by calling \fBdevid_str_free()\fR.
289 The \fBddi_devid_str_decode()\fR function takes a string previously produced by
290 the \fBdevid_str_encode\fR(3DEVID) or \fBddi_devid_str_encode()\fR function and
291 decodes the contained device ID and minor_name, allocating and returning
292 pointers to the extracted parts through the \fIretdevid\fR and
293 \fIretminor_name\fR arguments. If the special \fIdevidstr\fR \fBid0\fR was
294 specified then the returned device ID and minor name will both be null. A
295 non-null returned \fIdevid\fR must be freed by the caller through the
296 \fBddi_devid_free()\fR function. A non-null returned minor name must be freed
297 by calling \fBddi_devid_str_free()\fR.
300 The \fBddi_devid_str_free()\fR function is used to free all strings returned by
301 the \fBddi_devid\fR functions (the \fBddi_devid_str_encode()\fR function return
302 value and the returned \fIretminor_name\fR argument).
306 \fBddi_devid_init()\fR returns the following values:
316 \fB\fBDDI_SUCCESS\fR\fR
325 \fB\fBDDI_FAILURE\fR\fR
328 Out of memory. An invalid \fIdevid_type\fR was passed in.
335 \fBddi_devid_valid()\fR returns the following values:
345 \fB\fBDDI_SUCCESS\fR\fR
348 Valid device \fBID\fR.
354 \fB\fBDDI_FAILURE\fR\fR
357 Invalid device \fBID\fR.
364 \fBddi_devid_register()\fR returns the following values:
374 \fB\fBDDI_SUCCESS\fR\fR
383 \fB\fBDDI_FAILURE\fR\fR
386 Failure. The device \fBID\fR is already registered or the device \fBID\fR is
394 \fBddi_devid_valid()\fR returns the following values:
404 \fB\fBDDI_SUCCESS\fR\fR
407 Valid device \fBID\fR.
413 \fB\fBDDI_FAILURE\fR\fR
416 Invalid device \fBID\fR.
423 \fBddi_devid_get()\fR returns the following values:
433 \fB\fBDDI_SUCCESS\fR\fR
436 Device \fBID\fR is present and a pointer to it is returned in \fIretdevid\fR.
442 \fB\fBDDI_FAILURE\fR\fR
445 No device \fBID\fR is defined for this \fBdev_info\fR node.
452 \fBddi_devid_compare()\fR returns the following values:
465 The first device ID is less than the second device ID.
474 The first device ID is equal to the second device ID.
483 The first device ID is greater than the second device ID.
490 \fBddi_devid_sizeof()\fR returns the size of the \fIdevid\fR in bytes. If
491 called with a null, then the number of bytes that must be allocated and
492 initialized to determine the size of a complete device ID is returned.
495 \fBddi_devid_str_encode()\fR returns a value of null to indicate failure.
496 Failure can be caused by attempting to encode an invalid \fIdevid\fR. If the
497 return value is non-null then the caller must free the returned string by using
498 the \fBdevid_str_free()\fR function.
501 \fBddi_devid_str_decode()\fR returns the following values:
511 \fB\fBDDI_SUCCESS\fR\fR
520 \fB\fBDDI_FAILURE\fR\fR
523 Failure; the \fIdevidstr\fR string was not valid.
531 These functions can be called from a user or kernel context.
535 \fBdevid_get\fR(3DEVID), , \fBlibdevid\fR(3LIB), \fBattributes\fR(5),
536 \fBattach\fR(9E), \fBdetach\fR(9E), \fBkmem_free\fR(9F)
539 \fIWriting Device Drivers\fR