'\" te .\" Copyright (c) 2005, Sun Microsystems, Inc., All Rights Reserved .\" 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. 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 the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner] .\" Copyright 2022 Garrett D'Amore .TH INTRO 9F "July 30, 2022" .SH NAME Intro, intro \- introduction to DDI/DKI functions .SH DESCRIPTION Section 9F describes the kernel functions available for use by device drivers. See \fBIntro\fR(9E) for an overview of device driver interfaces. .sp .LP In this section, the information for each driver function is organized under the following headings: .RS +4 .TP .ie t \(bu .el o \fBNAME\fR summarizes the function's purpose. .RE .RS +4 .TP .ie t \(bu .el o \fBSYNOPSIS\fR shows the syntax of the function's entry point in the source code. \fB#include\fR directives are shown for required headers. .RE .RS +4 .TP .ie t \(bu .el o \fBINTERFACE\fR \fBLEVEL\fR describes any architecture dependencies. .RE .RS +4 .TP .ie t \(bu .el o \fBARGUMENTS\fR describes any arguments required to invoke the function. .RE .RS +4 .TP .ie t \(bu .el o \fBDESCRIPTION\fR describes general information about the function. .RE .RS +4 .TP .ie t \(bu .el o \fBRETURN\fR \fBVALUES\fR describes the return values and messages that can result from invoking the function. .RE .RS +4 .TP .ie t \(bu .el o \fBCONTEXT\fR indicates from which driver context (user, kernel, interrupt, or high-level interrupt) the function can be called. .RE .RS +4 .TP .ie t \(bu .el o A driver function has \fIuser context\fR if it was directly invoked because of a user thread. The \fBread\fR(9E) entry point of the driver, invoked by a \fBread\fR(2) system call, has user context. .RE .RS +4 .TP .ie t \(bu .el o A driver function has \fIkernel context\fR if was invoked by some other part of the kernel. In a block device driver, the \fBstrategy\fR(9E) entry point may be called by the page daemon to write pages to the device. The page daemon has no relation to the current user thread, so in this case \fBstrategy\fR(9E) has kernel context. .RE .RS +4 .TP .ie t \(bu .el o \fIInterrupt context\fR is kernel context, but also has an interrupt level associated with it. Driver interrupt routines have interrupt context. .sp Note that a mutex acquired in user or kernel context that can also be acquired in interrupt context means that the user or kernel context thread holding that mutex is subject to all the restrictions imposed by interrupt context, for the duration of the ownership of that mutex. Please see the \fBmutex\fR(9F) man page for a more complete discussion of proper mutex handling for drivers. .RE .RS +4 .TP .ie t \(bu .el o \fIHigh-level interrupt context\fR is a more restricted form of interrupt context. If a driver interrupt priority returned from \fBddi_intr_get_pri\fR(9F) is greater than the priority returned from \fBddi_intr_get_hilevel_pri\fR(9F) this indicates the interrupt handler will run in high-level interrupt context. These interrupt routines are only allowed to call \fBddi_intr_trigger_softint\fR(9F), \fBmutex_enter\fR(9F), and \fBmutex_exit\fR(9F). Furthermore, \fBmutex_enter\fR(9F) and \fBmutex_exit\fR(9F) may only be called on mutexes initialized with the interrupt priority returned by \fBddi_intr_get_pri\fR(9F). .RE .RS +4 .TP .ie t \(bu .el o \fBSEE ALSO\fR indicates functions that are related by usage and sources, and which can be referred to for further information. .RE .RS +4 .TP .ie t \(bu .el o \fBEXAMPLES\fR shows how the function can be used in driver code. .RE .sp .LP Every driver MUST include <\fBsys/ddi.h\fR> and <\fBsys/sunddi.h\fR>, in that order, and as the last files the driver includes. .SH STREAMS KERNEL FUNCTION SUMMARY The following table summarizes the STREAMS functions described in this section. .sp .sp .TS c c l l . Routine Type _ \fBadjmsg\fR DDI/DKI \fBallocb\fR DDI/DKI \fBallocb_tmpl\fR illumos DDI \fBbackq\fR DDI/DKI \fBbcanput\fR DDI/DKI \fBbcanputnext\fR DDI/DKI \fBbufcall\fR DDI/DKI \fBcanput\fR DDI/DKI \fBcanputnext\fR DDI/DKI \fBclrbuf\fR DDI/DKI \fBcopyb\fR DDI/DKI \fBcopymsg\fR DDI/DKI \fBDB_BASE\fR illumos DDI \fBDB_LIM\fR illumos DDI \fBDB_REF\fR illumos DDI \fBDB_TYPE\fR illumos DDI \fBdatamsg\fR DDI/DKI \fBdupb\fR DDI/DKI \fBdupmsg\fR DDI/DKI \fBenableok\fR DDI/DKI \fBesballoc\fR DDI/DKI \fBesbbcall\fR DDI/DKI \fBflushband\fR DDI/DKI \fBflushq\fR DDI/DKI \fBfreeb\fR DDI/DKI \fBfreemsg\fR DDI/DKI \fBfreezestr\fR DDI/DKI \fBgetq\fR DDI/DKI \fBIOC_CONVER_FROM\fR illumos DDI \fBinsq\fR DDI/DKI \fBlinkb\fR DDI/DKI \fBMBLKHEAD\fR illumos DDI \fBMBLKIN\fR illumos DDI \fBMBLKL\fR illumos DDI \fBMBLKSIZE\fR illumos DDI \fBMBLKTAIL\fR illumos DDI \fBmcopyin\fR illumos DDI \fBmcopymsg\fR illumos DDI \fBmcopyout\fR illumos DDI \fBmerror\fR illumos DDI \fBmexchange\fR illumos DDI \fBmioc2ack\fR illumos DDI \fBmiocack\fR illumos DDI \fBmexchange\fR illumos DDI \fBmiocpullup\fR illumos DDI \fBmkiocb\fR illumos DDI \fBmsgdsize\fR DDI/DKI \fBmsgpullup\fR DDI/DKI \fBmsgsize\fR illumos DDI \fBmt-streams\fR illumos DDI \fBnoenable\fR DDI/DKI \fBOTHERQ\fR DDI/DKI \fBpullupmsg\fR DDI/DKI \fBput\fR DDI/DKI \fBputbq\fR DDI/DKI \fBputctl\fR DDI/DKI \fBputctl1\fR DDI/DKI \fBputnext\fR DDI/DKI \fBputnextctl\fR DDI/DKI \fBputq\fR DDI/DKI \fBqassociate\fR illumos DDI \fBqbufcall\fR illumos DDI \fBqenable\fR DDI/DKI \fBqprocson\fR DDI/DKI \fBqprocsoff\fR DDI/DKI \fBqreply\fR DDI/DKI \fBqsize\fR DDI/DKI \fBqtimeout\fR illumos DDI \fBqunbufcall\fR illumos DDI \fBquntimeout\fR illumos DDI \fBqwait\fR illumos DDI \fBqwait_sig\fR illumos DDI \fBqwriter\fR illumos DDI \fBRD\fR DDI/DKI \fBrmvb\fR DDI/DKI \fBrmvq\fR DDI/DKI \fBSAMESTR\fR DDI/DKI \fBstrlog\fR DDI/DKI \fBstrqget\fR DDI/DKI \fBstrqset\fR DDI/DKI \fBtestb\fR DDI/DKI \fBunbufcall\fR DDI/DKI \fBunfreezestr\fR DDI/DKI \fBunlinkb\fR DDI/DKI \fBWR\fR DDI/DKI .TE .sp .LP The following table summarizes the functions not specific to STREAMS. .sp .sp .TS c c l l . Routine Type _ \fBASSERT\fR DDI/DKI \fBanocancel\fR illumos DDI \fBaphysio\fR illumos DDI \fBatomic_add\fR DDI/DKI \fBatomic_and\fR DDI/DKI \fBatomic_bits\fR DDI/DKI \fBatomic_cas\fR DDI/DKI \fBatomic_dec\fR DDI/DKI \fBatomic_inc\fR DDI/DKI \fBatomic_ops\fR DDI/DKI \fBatomic_or\fR DDI/DKI \fBatomic_swap\fR DDI/DKI \fBbcmp\fR DDI/DKI \fBbcopy\fR DDI/DKI \fBbioclone\fR illumos DDI \fBbiodone\fR DDI/DKI \fBbiofini\fR illumos DDI \fBbioinit\fR illumos DDI \fBbiomodified\fR illumos DDI \fBbiosize\fR illumos DDI \fBbioerror\fR illumos DDI \fBbioreset\fR illumos DDI \fBbiowait\fR DDI/DKI \fBbp_copyin\fR DDI/DKI \fBbp_copyout\fR DDI/DKI \fBbp_mapin\fR DDI/DKI \fBbp_mapout\fR DDI/DKI \fBbtop\fR DDI/DKI \fBbtopr\fR DDI/DKI \fBbzero\fR DDI/DKI \fBcmn_err\fR DDI/DKI \fBcondvar\fR illumos DDI \fBcopyin\fR DDI/DKI \fBcopyout\fR DDI/DKI \fBcsx_AccessConfigurationRegister\fR illumos DDI \fBcsx_ConvertSize\fR illumos DDI \fBcsx_ConvertSpeed\fR illumos DDI \fBcsx_CS_DDI_Info\fR illumos DDI \fBcsx_DeregisterClient\fR illumos DDI \fBcsx_DupHandle\fR illumos DDI \fBcsx_Error2Text\fR illumos DDI \fBcsx_Event2Text\fR illumos DDI \fBcsx_FreeHandle\fR illumos DDI \fBcsx_Get8\fR illumos DDI \fBcsx_GetFirstClient\fR illumos DDI \fBcsx_GetFirstTuple\fR illumos DDI \fBcsx_GetHandleOffset\fR illumos DDI \fBcsx_GetMappedAddr\fR illumos DDI \fBcsx_GetStatus\fR illumos DDI \fBcsx_GetTupleData\fR illumos DDI \fBcsx_MakeDeviceNode\fR illumos DDI \fBcsx_MapLogSocket\fR illumos DDI \fBcsx_MapMemPage\fR illumos DDI \fBcsx_ModifyConfiguration\fR illumos DDI \fBcsx_ModifyWindow\fR illumos DDI \fBcsx_Parse_CISTPL_BATTERY\fR illumos DDI \fBcsx_Parse_CISTPL_BYTEORDER\fR illumos DDI \fBcsx_Parse_CISTPL_CFTABLE_ENTRY\fR illumos DDI \fBcsx_Parse_CISTPL_CONFIG\fR illumos DDI \fBcsx_Parse_CISTPL_DATE\fR illumos DDI \fBcsx_Parse_CISTPL_DEVICE\fR illumos DDI \fBcsx_Parse_CISTPL_DEVICEGEO\fR illumos DDI \fBcsx_Parse_CISTPL_DEVICEGEO_A\fR illumos DDI \fBcsx_Parse_CISTPL_FORMAT\fR illumos DDI \fBcsx_Parse_CISTPL_FUNCE\fR illumos DDI \fBcsx_Parse_CISTPL_FUNCID\fR illumos DDI \fBcsx_Parse_CISTPL_GEOMETRY\fR illumos DDI \fBcsx_Parse_CISTPL_JEDEC_C\fR illumos DDI \fBcsx_Parse_CISTPL_LINKTARGET\fR illumos DDI \fBcsx_Parse_CISTPL_LONGLINK_A\fR illumos DDI \fBcsx_Parse_CISTPL_LONGLINK_MFC\fR illumos DDI \fBcsx_Parse_CISTPL_MANFID\fR illumos DDI \fBcsx_Parse_CISTPL_ORG\fR illumos DDI \fBcsx_Parse_CISTPL_SPCL\fR illumos DDI \fBcsx_Parse_CISTPL_SWIL\fR illumos DDI \fBcsx_Parse_CISTPL_VERS_1\fR illumos DDI \fBcsx_Parse_CISTPL_VERS_2\fR illumos DDI \fBcsx_ParseTuple\fR illumos DDI \fBcsx_Put8\fR illumos DDI \fBcsx_RegisterClient\fR illumos DDI \fBcsx_ReleaseConfiguration\fR illumos DDI \fBcsx_RepGet8\fR illumos DDI \fBcsx_RepPut8\fR illumos DDI \fBcsx_RequestConfiguration\fR illumos DDI \fBcsx_RequestIO\fR illumos DDI \fBcsx_RequestIRQ\fR illumos DDI \fBcsx_RequestSocketMask\fR illumos DDI \fBcsx_RequestWindow\fR illumos DDI \fBcsx_ResetFunction\fR illumos DDI \fBcsx_SetEventMask\fR illumos DDI \fBcsx_SetHandleOffset\fR illumos DDI \fBcsx_ValidateCIS\fR illumos DDI \fBcv_broadcast\fR illumos DDI \fBcv_destroy\fR illumos DDI \fBcv_init\fR illumos DDI \fBcv_reltimedwait\fR illumos DDI \fBcv_reltimedwait_sig\fR illumos DDI \fBcv_signal\fR illumos DDI \fBcv_timedwait\fR illumos DDI \fBcv_timedwait_sig\fR illumos DDI \fBcv_wait\fR illumos DDI \fBcv_wait_sig\fR illumos DDI \fBddi_add_event_handler\fR illumos DDI \fBddi_add_intr\fR illumos DDI \fBddi_add_softintr\fR illumos DDI \fBddi_binding_name\fR illumos DDI \fBddi_btop\fR illumos DDI \fBddi_btopr\fR illumos DDI \fBddi_can_receive_sig\fR illumos DDI \fBddi_check_acc_handle\fR illumos DDI \fBddi_copyin\fR illumos DDI \fBddi_copyout\fR illumos DDI \fBddi_create_minor_node\fR illumos DDI \fBddi_cred\fR illumos DDI \fBddi_dev_is_sid\fR illumos DDI \fBddi_dev_nintrs\fR illumos DDI \fBddi_dev_nregs\fR illumos DDI \fBddi_dev_regsize\fR illumos DDI \fBddi_device_copy\fR illumos DDI \fBddi_device_zero\fR illumos DDI \fBddi_devmap_segmap\fR illumos DDI \fBddi_dma_addr_bind_handle\fR illumos DDI \fBddi_dma_alloc_handle\fR illumos DDI \fBddi_dma_buf_bind_handle\fR illumos DDI \fBddi_dma_burstsizes\fR illumos DDI \fBddi_dma_cookie_get\fR illumos DDI \fBddi_dma_cookie_next\fR illumos DDI \fBddi_dma_cookie_one\fR illumos DDI \fBddi_dma_free_handle\fR illumos DDI \fBddi_dma_getwin\fR illumos DDI \fBddi_dma_mem_alloc\fR illumos DDI \fBddi_dma_mem_free\fR illumos DDI \fBddi_dma_ncookies\fR illumos DDI \fBddi_dma_nextcookie\fR illumos DDI \fBddi_dma_numwin\fR illumos DDI \fBddi_dma_set_sbus64\fR illumos DDI \fBddi_dma_sync\fR illumos DDI \fBddi_dma_unbind_handle\fR illumos DDI \fBddi_dmae\fR illumos x86 DDI \fBddi_dmae_1stparty\fR illumos x86 DDI \fBddi_dmae_alloc\fR illumos x86 DDI \fBddi_dmae_disable\fR illumos x86 DDI \fBddi_dmae_enable\fR illumos x86 DDI \fBddi_dmae_getattr\fR illumos x86 DDI \fBddi_dmae_getcnt\fR illumos x86 DDI \fBddi_dmae_getlim\fR illumos x86 DDI \fBddi_dmae_prog\fR illumos x86 DDI \fBddi_dmae_release\fR illumos x86 DDI \fBddi_dmae_stop\fR illumos x86 DDI \fBddi_driver_major\fR illumos DDI \fBddi_driver_name\fR illumos DDI \fBddi_enter_critical\fR illumos DDI \fBddi_exit_critical\fR illumos DDI \fBddi_ffs\fR illumos DDI \fBddi_fls\fR illumos DDI \fBddi_fm_acc_err_clear\fR illumos DDI \fBddi_fm_acc_err_get\fR illumos DDI \fBddi_fm_ereport_post\fR illumos DDI \fBddi_fm_handler_register\fR illumos DDI \fBddi_fm_init\fR illumos DDI \fBddi_fm_service_impact\fR illumos DDI \fBddi_get16\fR illumos DDI \fBddi_get32\fR illumos DDI \fBddi_get64\fR illumos DDI \fBddi_get8\fR illumos DDI \fBddi_get_cred\fR illumos DDI \fBddi_get_devstate\fR illumos DDI \fBddi_get_driver_private\fR illumos DDI \fBddi_get_eventcookie\fR illumos DDI \fBddi_get_iblock_cookie\fR illumos DDI \fBddi_get_instance\fR illumos DDI \fBddi_get_kt_did\fR illumos DDI \fBddi_get_lbolt\fR illumos DDI \fBddi_get_name\fR illumos DDI \fBddi_get_parent\fR illumos DDI \fBddi_get_pid\fR illumos DDI \fBddi_get_soft_iblock_cookie\fR illumos DDI \fBddi_get_soft_state\fR illumos DDI \fBddi_getlongprop\fR illumos DDI \fBddi_getlongprop_buf\fR illumos DDI \fBddi_getprop\fR illumos DDI \fBddi_getproplen\fR illumos DDI \fBddi_intr_add_handler\fR illumos DDI \fBddi_intr_add_softint\fR illumos DDI \fBddi_intr_alloc\fR illumos DDI \fBddi_intr_block_disable\fR illumos DDI \fBddi_intr_block_enable\fR illumos DDI \fBddi_intr_clr_mask\fR illumos DDI \fBddi_intr_dup_handler\fR illumos DDI \fBddi_intr_disable\fR illumos DDI \fBddi_intr_enable\fR illumos DDI \fBddi_intr_free\fR illumos DDI \fBddi_intr_get_cap\fR illumos DDI \fBddi_intr_get_hilevel_pri\fR illumos DDI \fBddi_intr_get_navail\fR illumos DDI \fBddi_intr_get_nintrs\fR illumos DDI \fBddi_intr_get_pending\fR illumos DDI \fBddi_intr_get_pri\fR illumos DDI \fBddi_intr_get_softint_pri\fR illumos DDI \fBddi_intr_get_supported_types\fR illumos DDI \fBddi_intr_remove_handler\fR illumos DDI \fBddi_intr_remove_softint\fR illumos DDI \fBddi_intr_set_cap\fR illumos DDI \fBddi_intr_set_mask\fR illumos DDI \fBddi_intr_set_pri\fR illumos DDI \fBddi_intr_set_softint_pri\fR illumos DDI \fBddi_intr_trigger_softint\fR illumos DDI \fBddi_io_get16\fR illumos DDI \fBddi_io_get32\fR illumos DDI \fBddi_io_get8\fR illumos DDI \fBddi_io_put16\fR illumos DDI \fBddi_io_put32\fR illumos DDI \fBddi_io_put8\fR illumos DDI \fBddi_io_rep_get16\fR illumos DDI \fBddi_io_rep_get32\fR illumos DDI \fBddi_io_rep_get8\fR illumos DDI \fBddi_io_rep_put16\fR illumos DDI \fBddi_io_rep_put32\fR illumos DDI \fBddi_io_rep_put8\fR illumos DDI \fBddi_iomin\fR illumos DDI \fBddi_log_sysevent\fR illumos DDI \fBddi_map_regs\fR illumos DDI \fBddi_mapdev\fR illumos DDI \fBddi_mapdev_intercept\fR illumos DDI \fBddi_mapdev_nointercept\fR illumos DDI \fBddi_mapdev_set_device_acc_attr\fR illumos DDI \fBddi_mem_get16\fR illumos DDI \fBddi_mem_get32\fR illumos DDI \fBddi_mem_get64\fR illumos DDI \fBddi_mem_get8\fR illumos DDI \fBddi_mem_put16\fR illumos DDI \fBddi_mem_put32\fR illumos DDI \fBddi_mem_put64\fR illumos DDI \fBddi_mem_put8\fR illumos DDI \fBddi_mem_rep_get16\fR illumos DDI \fBddi_mem_rep_get32\fR illumos DDI \fBddi_mem_rep_get64\fR illumos DDI \fBddi_mem_rep_get8\fR illumos DDI \fBddi_mem_rep_put16\fR illumos DDI \fBddi_mem_rep_put32\fR illumos DDI \fBddi_mem_rep_put64\fR illumos DDI \fBddi_mem_rep_put8\fR illumos DDI \fBddi_mmap_get_model\fR illumos DDI \fBddi_model_convert_from\fR illumos DDI \fBddi_modopen\fR illumos DDI \fBddi_no_info\fR illumos DDI \fBddi_node_name\fR illumos DDI \fBddi_peek16\fR illumos DDI \fBddi_peek32\fR illumos DDI \fBddi_peek64\fR illumos DDI \fBddi_peek8\fR illumos DDI \fBddi_periodic_add\fR illumos DDI \fBddi_periodic_delete\fR illumos DDI \fBddi_poke16\fR illumos DDI \fBddi_poke32\fR illumos DDI \fBddi_poke64\fR illumos DDI \fBddi_poke8\fR illumos DDI \fBddi_prop_create\fR illumos DDI \fBddi_prop_exists\fR illumos DDI \fBddi_prop_free\fR illumos DDI \fBddi_prop_get_int\fR illumos DDI \fBddi_prop_lookup\fR illumos DDI \fBddi_prop_lookup_byte_array\fR illumos DDI \fBddi_prop_lookup_int_array\fR illumos DDI \fBddi_prop_lookup_string\fR illumos DDI \fBddi_prop_lookup_string_array\fR illumos DDI \fBddi_prop_modify\fR illumos DDI \fBddi_prop_op\fR illumos DDI \fBddi_prop_remove\fR illumos DDI \fBddi_prop_remove_all\fR illumos DDI \fBddi_prop_undefine\fR illumos DDI \fBddi_prop_update\fR illumos DDI \fBddi_prop_update_byte_array\fR illumos DDI \fBddi_prop_update_int\fR illumos DDI \fBddi_prop_update_int_array\fR illumos DDI \fBddi_prop_update_string\fR illumos DDI \fBddi_prop_update_string_array\fR illumos DDI \fBddi_ptob\fR illumos DDI \fBddi_put16\fR illumos DDI \fBddi_put32\fR illumos DDI \fBddi_put64\fR illumos DDI \fBddi_put8\fR illumos DDI \fBddi_regs_map_free\fR illumos DDI \fBddi_regs_map_setup\fR illumos DDI \fBddi_remove_event_handler\fR illumos DDI \fBddi_remove_intr\fR illumos DDI \fBddi_remove_minor_node\fR illumos DDI \fBddi_remove_softintr\fR illumos DDI \fBddi_removing_power\fR illumos DDI \fBddi_rep_get16\fR illumos DDI \fBddi_rep_get32\fR illumos DDI \fBddi_rep_get64\fR illumos DDI \fBddi_rep_get8\fR illumos DDI \fBddi_rep_put16\fR illumos DDI \fBddi_rep_put32\fR illumos DDI \fBddi_rep_put64\fR illumos DDI \fBddi_rep_put8\fR illumos DDI \fBddi_report_dev\fR illumos DDI \fBddi_root_node\fR illumos DDI \fBddi_segmap\fR illumos DDI \fBddi_segmap_setup\fR illumos DDI \fBddi_set_driver_private\fR illumos DDI \fBddi_slaveonly\fR illumos DDI \fBddi_soft_state\fR illumos DDI \fBddi_soft_state_fini\fR illumos DDI \fBddi_soft_state_free\fR illumos DDI \fBddi_soft_state_init\fR illumos DDI \fBddi_soft_state_zalloc\fR illumos DDI \fBddi_strlol\fR illumos DDI \fBddi_strloul\fR illumos DDI \fBddi_trigger_softintr\fR illumos DDI \fBddi_umem_alloc\fR illumos DDI \fBddi_umem_free\fR illumos DDI \fBddi_umem_iosetup\fR illumos DDI \fBddi_umem_lock\fR illumos DDI \fBddi_unmap_regs\fR illumos DDI \fBdelay\fR DDI/DKI \fBdevmap_default_access\fR illumos DDI \fBdevmap_devmem_setup\fR illumos DDI \fBdevmap_do_ctxmgt\fR illumos DDI \fBdevmap_load\fR illumos DDI \fBdevmap_set_ctx_timeout\fR illumos DDI \fBdevmap_setup\fR illumos DDI \fBdevmap_umem_setup\fR illumos DDI \fBdevmap_unload\fR illumos DDI \fBdisksort\fR illumos DDI \fBdlbindack\fR illumos DDI \fBdrv_getparm\fR DDI/DKI \fBdrv_hztousec\fR DDI/DKI \fBdrv_priv\fR DDI/DKI \fBdrv_usectohz\fR DDI/DKI \fBdrv_usecwait\fR DDI/DKI \fBfree_pktiopb\fR illumos DDI \fBfreerbuf\fR DDI/DKI \fBget_pktiopb\fR illumos DDI \fBgeterror\fR DDI/DKI \fBgethrtime\fR DDI/DKI \fBgetmajor\fR DDI/DKI \fBgetminor\fR DDI/DKI \fBgetrbuf\fR DDI/DKI \fBgld\fR illumos DDI \fBhat_getkpfnum\fR DKI only \fBid32_alloc\fR illumos DDI \fBinb\fR illumos x86 DDI \fBinl\fR illumos x86 DDI \fBinw\fR illumos x86 DDI \fBkiconv\fR illumos DDI \fBkiconv_close\fR illumos DDI \fBkiconv_open\fR illumos DDI \fBkiconvstr\fR illumos DDI \fBkmem_alloc\fR DDI/DKI \fBkmem_cache_create\fR illumos DDI \fBkmem_free\fR DDI/DKI \fBkmem_zalloc\fR DDI/DKI \fBkstat_create\fR illumos DDI \fBkstat_delete\fR illumos DDI \fBkstat_install\fR illumos DDI \fBkstat_named_init\fR illumos DDI \fBkstat_queue\fR illumos DDI \fBkstat_runq_back_to_waitq\fR illumos DDI \fBkstat_runq_enter\fR illumos DDI \fBkstat_runq_exit\fR illumos DDI \fBkstat_waitq_enter\fR illumos DDI \fBkstat_waitq_exit\fR illumos DDI \fBkstat_waitq_to_runq\fR illumos DDI \fBldi_add_event_handler\fR illumos DDI \fBldi_aread\fR illumos DDI \fBldi_devmap\fR illumos DDI \fBldi_dump\fR illumos DDI \fBldi_ev_finalize\fR illumos DDI \fBldi_ev_get_cookie\fR illumos DDI \fBldi_ev_get_type\fR illumos DDI \fBldi_ev_notify\fR illumos DDI \fBldi_ev_register_callbacks\fR illumos DDI \fBldi_ev_remove_callbacks\fR illumos DDI \fBldi_get_dev\fR illumos DDI \fBldi_get_eventcookie\fR illumos DDI \fBldi_get_size\fR illumos DDI \fBldi_ident_from_dev\fR illumos DDI \fBldi_ioctl\fR illumos DDI \fBldi_open_by_dev\fR illumos DDI \fBldi_poll\fR illumos DDI \fBldi_prop_exists\fR illumos DDI \fBldi_prop_get_int\fR illumos DDI \fBldi_prop_get_lookup_int_array\fR illumos DDI \fBldi_putmsg\fR illumos DDI \fBldi_read\fR illumos DDI \fBldi_remove_event_handler\fR illumos DDI \fBldi_strategy\fR illumos DDI \fBmakecom_g0\fR illumos DDI \fBmakecom_g0_s\fR illumos DDI \fBmakecom_g1\fR illumos DDI \fBmakecom_g5\fR illumos DDI \fBmakedevice\fR DDI/DKI \fBmax\fR DDI/DKI \fBmax\fR DDI/DKI \fBmembar_ops\fR illumos DDI \fBmemchr\fR illumos DDI \fBminphys\fR illumos DDI \fBmod_info\fR illumos DDI \fBmod_install\fR illumos DDI \fBmod_remove\fR illumos DDI \fBmutex_destroy\fR illumos DDI \fBmutex_enter\fR illumos DDI \fBmutex_exit\fR illumos DDI \fBmutex_init\fR illumos DDI \fBmutex_owned\fR illumos DDI \fBmutex_tryenter\fR illumos DDI \fBnochpoll\fR illumos DDI \fBnodev\fR DDI/DKI \fBnulldev\fR DDI/DKI \fBnumtos\fR illumos DDI \fBnvlist_add_boolean\fR illumos DDI \fBnvlist_alloc\fR illumos DDI \fBnvlist_lookup_boolean\fR illumos DDI \fBnvlist_lookup_nvpair\fR illumos DDI \fBnvlist_next_nvpair\fR illumos DDI \fBnvlist_remove\fR illumos DDI \fBnvlist_value_byte\fR illumos DDI \fBoutb\fR illumos x86 DDI \fBoutl\fR illumos x86 DDI \fBoutw\fR illumos x86 DDI \fBpci_config_get16\fR illumos DDI \fBpci_config_get32\fR illumos DDI \fBpci_config_get64\fR illumos DDI \fBpci_config_get8\fR illumos DDI \fBpci_config_put16\fR illumos DDI \fBpci_config_put32\fR illumos DDI \fBpci_config_put64\fR illumos DDI \fBpci_config_put8\fR illumos DDI \fBpci_config_setup\fR illumos DDI \fBpci_config_teardown\fR illumos DDI \fBpci_ereport_setup\fR illumos DDI \fBpci_report_pmcap\fR illumos DDI \fBpci_save_config_regs\fR illumos DDI \fBphysio\fR illumos DDI \fBpm_busy_component\fR illumos DDI \fBpm_power_has_changed\fR illumos DDI \fBpm_raise_power\fR illumos DDI \fBpm_trans_check\fR illumos DDI \fBpollwakeup\fR DDI/DKI \fBpci_config_teardown\fR illumos DDI \fBpci_config_teardown\fR illumos DDI \fBpriv_getbyname\fR illumos DDI \fBpriv_policy\fR illumos DDI \fBproc_signal\fR illumos DDI \fBproc_unref\fR illumos DDI \fBptob\fR DDI/DKI \fBrmalloc\fR DDI/DKI \fBrmalloc_wait\fR DDI/DKI \fBrmallocmap\fR DDI/DKI \fBrmallocmap_wait\fR DDI/DKI \fBrmfree\fR DDI/DKI \fBrmfreemap\fR DDI/DKI \fBrw_destroy\fR illumos DDI \fBrw_downgrade\fR illumos DDI \fBrw_enter\fR illumos DDI \fBrw_exit\fR illumos DDI \fBrw_init\fR illumos DDI \fBrw_read_locked\fR illumos DDI \fBrw_tryenter\fR illumos DDI \fBrw_tryupgrade\fR illumos DDI \fBscsi_abort\fR illumos DDI \fBscsi_alloc_consistent_buf\fR illumos DDI \fBscsi_cname\fR illumos DDI \fBscsi_destroy_pkt\fR illumos DDI \fBscsi_dmafree\fR illumos DDI \fBscsi_dmaget\fR illumos DDI \fBscsi_dname\fR illumos DDI \fBscsi_errmsg\fR illumos DDI \fBscsi_ext_sense_fields\fR illumos DDI \fBscsi_find_sense_descr\fR illumos DDI \fBscsi_free_consistent_buf\fR illumos DDI \fBscsi_get_device_type_scsi_options\fR illumos DDI \fBscsi_get_device_type_string\fR illumos DDI \fBscsi_hba_attach_setup\fR illumos DDI \fBscsi_hba_detach\fR illumos DDI \fBscsi_hba_fini\fR illumos DDI \fBscsi_hba_init\fR illumos DDI \fBscsi_hba_lookup_capstr\fR illumos DDI \fBscsi_hba_pkt_alloc\fR illumos DDI \fBscsi_hba_pkt_free\fR illumos DDI \fBscsi_hba_probe\fR illumos DDI \fBscsi_hba_tran_alloc\fR illumos DDI \fBscsi_hba_tran_free\fR illumos DDI \fBscsi_ifgetcap\fR illumos DDI \fBscsi_ifsetcap\fR illumos DDI \fBscsi_init_pkt\fR illumos DDI \fBscsi_log\fR illumos DDI \fBscsi_mname\fR illumos DDI \fBscsi_pktalloc\fR illumos DDI \fBscsi_pktfree\fR illumos DDI \fBscsi_poll\fR illumos DDI \fBscsi_probe\fR illumos DDI \fBscsi_resalloc\fR illumos DDI \fBscsi_reset\fR illumos DDI \fBscsi_reset_notify\fR illumos DDI \fBscsi_resfree\fR illumos DDI \fBscsi_rname\fR illumos DDI \fBscsi_sense_key\fR illumos DDI \fBscsi_setup_cdb\fR illumos DDI \fBscsi_slave\fR illumos DDI \fBscsi_sname\fR illumos DDI \fBscsi_sync_pkt\fR illumos DDI \fBscsi_transport\fR illumos DDI \fBscsi_unprobe\fR illumos DDI \fBscsi_unslave\fR illumos DDI \fBscsi_validate_sense\fR illumos DDI \fBscsi_vu_errmsg\fR illumos DDI \fBsema_destroy\fR illumos DDI \fBsema_init\fR illumos DDI \fBsema_p\fR illumos DDI \fBsema_p_sig\fR illumos DDI \fBsema_tryp\fR illumos DDI \fBsema_v\fR illumos DDI \fBsprintf\fR illumos DDI \fBstoi\fR illumos DDI \fBstrchr\fR illumos DDI \fBstrcmp\fR illumos DDI \fBstrcpy\fR illumos DDI \fBstrlen\fR illumos DDI \fBstrncmp\fR illumos DDI \fBstrncpy\fR illumos DDI \fBSTRUCT_DECL\fR illumos DDI \fBswab\fR DDI/DKI \fBtaskq\fR illumos DDI \fBtimeout\fR DDI/DKI \fBu8_strcmp\fR illumos DDI \fBu8_textprep_str\fR illumos DDI \fBu8_validate\fR illumos DDI \fBuconv_u16tou32\fR illumos DDI \fBuiomove\fR DDI/DKI \fBuntimeout\fR DDI/DKI \fBureadc\fR DDI/DKI \fBusb_alloc_request\fR illumos DDI \fBusb_client_attach\fR illumos DDI \fBusb_clr_feature\fR illumos DDI \fBusb_create_pm_components\fR illumos DDI \fBusb_get_addr\fR illumos DDI \fBusb_get_alt_if\fR illumos DDI \fBusb_get_cfg\fR illumos DDI \fBusb_get_current_frame_number\fR illumos DDI \fBusb_get_dev_data\fR illumos DDI \fBusb_get_max_pkts_per_ioc_request\fR illumos DDI \fBusb_get_status\fR illumos DDI \fBusb_get_string_desc\fR illumos DDI \fBusb_handle_remote_wakeup\fR illumos DDI \fBusb_lookup_ep_data\fR illumos DDI \fBusb_parse_data\fR illumos DDI \fBusb_pipe_bulk_xfer\fR illumos DDI \fBusb_pipe_close\fR illumos DDI \fBusb_pipe_ctrl_xfer\fR illumos DDI \fBusb_pipe_drain_reqs\fR illumos DDI \fBusb_pipe_get_max_bulk_transfer_size\fR illumos DDI \fBusb_pipe_get_state\fR illumos DDI \fBusb_pipe_intr_xfer\fR illumos DDI \fBusb_pipe_isoc_xfer\fR illumos DDI \fBusb_pipe_open\fR illumos DDI \fBusb_pipe_reset\fR illumos DDI \fBusb_pipe_set_private\fR illumos DDI \fBusb_register_hotplug_cbs\fR illumos DDI \fBusb_reset_device\fR illumos DDI \fBuwritec\fR DDI/DKI \fBva_arg\fR illumos DDI \fBva_end\fR illumos DDI \fBva_start\fR illumos DDI \fBvcmn_err\fR DDI/DKI \fBvsprintf\fR illumos DDI .TE .SH SEE ALSO .BR Intro (9E), .BR mutex (9F)