Go to main content
Index
Numbers and Symbols
- /devices directory
- description of
Devices as Special Files
- displaying the device tree
/devices Directory
- /etc/driver_aliases file
Checking Device Driver Bindings
- /var/adm/messages file
Additional Suggestions for Testing Console Frame
Buffer Drivers
- 64-bit device drivers
Making a Device Driver 64-Bit Ready
I/O Control Support for 64-Bit Capable
Device Drivers
- _fini() entry point
- required implementation
Loadable Module Entry Points
- _info() entry point
- required implementation
Loadable Module Entry Points
- _init() entry point
- required implementation
Loadable Module Entry Points
A
- add_drv command
Checking Device Driver Bindings
How to Build and Load the Layered Driver
- description of
Installing Drivers with add_drv
- device name
Compatible Device Names Shown by the Print Configuration
Command
- address spaces
- description of
Virtual Memory
- agent
- definition
What Is Predictive Self-Healing?
- allocb()function
Request Features and Fields
- alternate access mechanisms
Programmed I/O Functions
- aphysio() function
DMA Transfers (Asynchronous)
- aread() entry point
- asynchronous data transfers
Differences Between Synchronous and Asynchronous
I/O
- ASSERT() macro
Use ASSERT to Catch Invalid
Assumptions
Compiling and Linking the Driver
- associating kernel memory with user applications
Associating Kernel Memory With User Mappings
- asynchronous communication drivers
- testing
Asynchronous Communication Drivers
- asynchronous data transfers
- block drivers
Asynchronous Data Transfers (Block Drivers)
- character drivers
Differences Between Synchronous and Asynchronous
I/O
- USB
Synchronous and Asynchronous Transfers and Callbacks
- attach() entry point
Device Power Management
Registering Drivers to Gain Device Access
- active power management
Active Power Management
- description of
attach Entry Point
- network drivers
GLDv2 Network Device Driver Framework
The mac_register and mac_unregister Functions
- system power management
System Power Management
- auto-request sense mode
Auto-Request Sense Mode
- autoconfiguration
- of block devices
Block Device Autoconfiguration
- of character devices
Character Device Autoconfiguration
- of SCSI HBA drivers
Autoconfiguration Entry Points
- of SCSI target drivers
Autoconfiguration for SCSI Target Drivers
- overview
Driver Loading and Unloading
- routines
Autoconfiguration Entry Points
- Automated System Recovery Unit (ASRU)
- definition
Diagnosis, Suspect Lists, and Fault Events
- autoshutdown threshold
Autoshutdown Threshold
- autovectored interrupts
Device Interrupts
- avoiding data loss while testing
Avoiding Data Loss on a Test System
- awrite() entry point
- asynchronous data transfers
Differences Between Synchronous and Asynchronous
I/O
B
- binary compatibility
- description of
DDI/DKI Interfaces
- potential problems
Modify Routines That Handle Data Sharing
- binding a driver to a device
Binding a Driver to a Device
- binding a driver to a USB device
Compatible Device Names
- biodone() function
Synchronous Data Transfers (Block Drivers)
- blitting
VIS_CONSDISPLAY Macro
- block driver
- autoconfiguration of
Block Device Autoconfiguration
- buf structure
buf Structure
- cb_ops structure
cb_ops Structure
- overview
Entry Points for Block Device Drivers
- slice number
Block Device Autoconfiguration
- block driver entry points
Block Driver Roadmap- close() function
close Entry Point (Block Drivers)
- open() function
open Entry Point (Block Drivers)
- strategy() function
strategy Entry Point
- booting the kmdb debugger
- on SPARC systems
Booting kmdb With an Alternate Kernel on the SPARC Platform
- on x86 systems
Booting kmdb With an Alternate Kernel on the x86 Platform
- buf structure
- changes to
buf Structure Changes
- description of
buf Structure
- buffer allocation, DMA
Allocating Private DMA Buffers
- buffered I/O functions
Buffered I/O Functions
- burst sizes, DMA
Determining Maximum Burst Sizes
- bus
- architectures
Bus Architectures
- PCI architectures
PCI Local Bus
- SBus architecture
SBus Architecture
- SCSI
Introduction to Target Drivers
- bus nexus device drivers
- description of
Device Tree Components
- bus-master DMA
Performing Bus-Master DMA Transfers
Bus-Master DMA
- byte ordering
Endianness and Portability
C
- .conf files See
hardware configuration files
- cache
- description of
CPU and System I/O Cache
- callback functions
- description of
Callback Functions
- example of
DMA Callback Example
- cb_ops structure
- description of
cb_ops Structure
- cc command
Compiling and Linking the Driver
- cfgadm_usb command
Multiple-Configuration Devices
- character device driver
- aphysio() function
DMA Transfers (Asynchronous)
- autoconfiguration
Character Device Autoconfiguration
- cb_ops structure
cb_ops Structure
- close() entry point
close Entry Point (Character
Drivers)
- data transfers
I/O Request Handling
- device polling
Multiplexing I/O on File Descriptors
- entry points for
Character Driver Roadmap
- I/O control mechanism
Miscellaneous I/O Control
- memory mapping
Mapping Device Memory
- minphys() function
minphys Entry Point
- open() entry point
open Entry Point (Character
Drivers)
- overview
Entry Points for Character Device Drivers
- physio() function
DMA Transfers (Synchronous)
- strategy() entry point
strategy Entry Point
- checksumming
Hardware Checksumming: MAC Layer
Hardware Checksumming: Hardware
Hardware Checksum Offload
- cloning SCSI HBA driver
Transport Structure Cloning
- close() entry point
- block drivers
close Entry Point (Block Drivers)
- description of
close Entry Point (Character
Drivers)
- cmn_err() function
Write a Short Message to the Layered Device- debugging
Use cmn_err to Log Driver
Activity
- description of
Returning Errors
- example of
print Entry Point (Block
Drivers)
- compatible property
- description of
Device Node Names
- compiling drivers
Compiling and Linking the Driver
- condition variable functions
Kernel Thread Control and Synchronization
Functions- cv_broadcast()
Signaling the Condition
- cv_destroy()
Initializing Condition Variables
- cv_init()
Initializing Condition Variables
- cv_timedwait()
cv_wait and cv_timedwait Functions
- cv_timedwait_sig()
cv_timedwait_sig Function
- cv_wait()
Waiting for the Condition
- cv_wait_sig()
cv_wait_sig Function
- condition variables
- and mutex locks
Condition Variables in Thread Synchronization
- routines
Initializing Condition Variables
- configuration
- testing device drivers
Testing Drivers
- configuration descriptor clouds
Hot Reinsertion
- configuration entry points
- attach() function
attach Entry Point
- detach() function
detach Entry Point
- getinfo() function
getinfo Entry Point
- configuration files, hardware See
hardware configuration files
- console frame buffer drivers
Console Frame Buffer Drivers- debugging
Developing, Testing, and Debugging Console Frame
Buffer Drivers
- kernel terminal emulator
Oracle Solaris Consoles and the Kernel Terminal Emulator
- polled I/O interfaces
Implementing Polled I/O in Console Frame Buffer Drivers
Polled I/O Interfaces
- standalone mode
Implementing Polled I/O in Console Frame Buffer Drivers
Polled I/O Interfaces
- video mode change callback interface
Frame Buffer Specific Configuration Module
VIS_DEVINIT Macro
Video Mode Change Callback Interface
- visual I/O interfaces
Console Visual I/O Interfaces
- context management See
device context management
- context of device driver
Driver Context
- cookies
- DMA
DMA Model
- copying data
- copyin() function
User Addresses
- copyout() function
User Addresses
- CPR (CheckPoint and Resume)
System Power Management
- crash dumps, saving
Capture System Crash Dumps
- crash command
Postmortem Debugging
- csi_arq_status structure
- changes to
csi_arq_status Structure
Changes
- cv_timedwait() function
- changes to
cv_timedwait and cv_timedwait_sig Argument Changes
- cv_timedwait_sig() function
- changes to
cv_timedwait and cv_timedwait_sig Argument Changes
D
- .dict dictionary files
Message IDs and Dictionary Files
- data alignment for SPARC
SPARC Data Alignment
- data sharing
- using devmap()
Data Sharing in devmap
- using ioctl()
Data Sharing in ioctl
- using mmap()
Data Sharing in mmap
- data storage classes
Storage Classes of Driver Data
- data structures
- dev_ops structure
dev_ops Structure
- GLDv2
gld_stats Structure
GLDv2 Declarations and Data Structures
- modldrv structure
modldrv Structure
- data transfers
- character drivers
I/O Request Handling
- DDI function tables
Summary of Oracle Solaris DDI/DKI Services
- DDI-compliant drivers
- byte ordering
Endianness and Portability
- compliance testing
DDI/DKI Compliance Testing
- DDI/DKI See Also
LDI- and disk performance
Disk Performance
- design considerations
DDI/DKI Facilities
- overview
DDI/DKI Interfaces
- purpose in kernel
Oracle Solaris Kernel
- ddi_cb_register() function
Callback Interfaces
- ddi_cb_unregister() function
Callback Interfaces
- ddi_create_minor_node() function
Creating Minor Device Nodes
- ddi_device_copy() function
ddi_device_copy Argument Changes
- ddi_device_zero() function
ddi_device_zero Argument Changes
- ddi_devid_free() function
Retrieving Target Device Information
- ddi_dma_attr structure
ddi_dma_attr Structure
ddi_dma_attr Structure
- ddi_dma_cookie structure
ddi_dma_cookie Structure
Changes
- ddi_dma_getwin() function
DMA Software Components: Handles, Windows, and Cookies
- ddi_dma_mem_alloc() function
ddi_dma_mem_alloc Argument
Changes
- ddi_dma_nextseg() function
DMA Software Components: Handles, Windows, and Cookies
- ddi_driver_major() function
Block Device Autoconfiguration
Block Device Autoconfiguration
- ddi_enter_critical() function
Timing-Critical Sections
- ddi_eventcookie_t
Receiving Asynchronous Device Event Notification
- ddi_fm_capable() function
Getting the Fault Management Capability Bit Mask
- ddi_fm_ereport_post() function
Reporting Standard I/O Controller Errors
Queueing an Error Event
- ddi_fm_fini() function
Cleaning Up Fault Management Resources
- ddi_fm_init() function
Declaring Fault Management Capabilities
- ddi_fm_service_impact() function
Service Impact Function
- ddi_get_cred() function
Data Sharing in ioctl
drv_getparm Argument Changes
- ddi_get_driver_private() function
GLDv2 Driver Requirements
scsi_device Structure
- ddi_get_instance() function
gld_mac_info Structure
- ddi_get_lbolt() function
drv_getparm Argument Changes
- ddi_get_pid() function
drv_getparm Argument Changes
- ddi_get_time() function
drv_getparm Argument Changes
- DDI_INFO_DEVT2DEVINFO
getinfo Entry Point
- DDI_INFO_DEVT2INSTANCE
getinfo Entry Point
- ddi_intr_add_handler() function
Registering Interrupts
Interrupt Initialization and Destruction Functions
MSI-X Interrupts
- ddi_intr_add_softint() function
Soft Interrupt Functions
- ddi_intr_alloc() function
Interrupt Request Interfaces
Interrupt Initialization and Destruction Functions
MSI-X Interrupts
- ddi_intr_block_disable() function
Interrupt Initialization and Destruction Functions
- ddi_intr_block_enable() function
Interrupt Initialization and Destruction Functions
- DDI_INTR_CLAIMED
Interrupt Handler Functionality
- ddi_intr_clr_mask() function
Clearing Interrupt Masks
Interrupt Initialization and Destruction Functions
- ddi_intr_disable() function
Interrupt Initialization and Destruction Functions
MSI-X Interrupts
- ddi_intr_dup_handler() function
Interrupt Initialization and Destruction Functions
MSI-X Interrupts
- ddi_intr_enable() function
Interrupt Initialization and Destruction Functions
MSI-X Interrupts
- ddi_intr_free() function
Interrupt Initialization and Destruction Functions
MSI-X Interrupts
- ddi_intr_get_cap() function
Interrupt Capability Functions
- ddi_intr_get_hilevel_pri() function
Priority Management Functions
- ddi_intr_get_hilevel_pri() function
Handling High-Level Interrupts
- ddi_intr_get_navail() function
Interrupt Capability Functions
- ddi_intr_get_nintrs() function
Interrupt Capability Functions
- ddi_intr_get_pending() function
Checking for Pending Interrupts
Interrupt Initialization and Destruction Functions
- ddi_intr_get_pri() function
Handling High-Level Interrupts
Priority Management Functions
- ddi_intr_get_softint_pri() function
Soft Interrupt Functions
- ddi_intr_get_supported_types() function
Interrupt Capability Functions
- ddi_intr_hilevel() function
High-Level Interrupts
- ddi_intr_remove_handler() function
Interrupt Initialization and Destruction Functions
MSI-X Interrupts
- ddi_intr_remove_softint() function
Soft Interrupt Functions
- ddi_intr_set_cap() function
Interrupt Initialization and Destruction Functions
- ddi_intr_set_mask() function
Setting Interrupt Masks
Interrupt Initialization and Destruction Functions
- ddi_intr_set_nreq() function
Interrupt Request Interfaces
- ddi_intr_set_pri() function
Priority Management Functions
- ddi_intr_set_softint_pri() function
Soft Interrupt Functions
- ddi_intr_set_softint_pri() function
Changing Soft Interrupt Priority
- ddi_intr_trigger_softint() function
Soft Interrupt Functions
- ddi_intr_trigger_softint() function
High-Level Interrupts
- DDI_INTR_UNCLAIMED
Interrupt Handler Functionality
- ddi_log_sysevent() function
Using ddi_log_sysevent to Log Events
Using ddi_log_sysevent to Log Events
- ddi_model_convert_from() function
Data Sharing in ioctl
- ddi_prop_free() function
Driver Source File
- ddi_prop_get_int() function
HBA Configuration Properties
- ddi_prop_lookup() function
Looking Up Properties
- ddi_prop_lookup_string() function
Driver Source File
- ddi_prop_op() function
prop_op Entry Point
- ddi_regs_map_setup() function
ddi_device_acc_attr Structure
- ddi_removing_power() function
detach Entry Point
- DDI_RESUME
- detach() function
detach Entry Point
- ddi_set_driver_private() function
scsi_device Structure
- DDI_SUSPEND
- detach() function
detach Entry Point
- ddi_umem_alloc() function
Allocating Kernel Memory for User Access
- ddi_umem_free() function
Freeing Kernel Memory Exported for User Access
- DDX module
The X Window System Frame Buffer Specific DDX Module
- deadman kernel feature
Using the Deadman Feature
- DEBUG symbol
Use ASSERT to Catch Invalid
Assumptions
Compiling and Linking the Driver
- debugging
- ASSERT() macro
Use ASSERT to Catch Invalid
Assumptions
- coding hints
Debugging Preparation Techniques
- common tasks
Useful Debugging Tasks With kmdb and mdb
- conditional compilation
Use Conditional Compilation to
Toggle Costly Debugging Features
- console frame buffer drivers
Developing, Testing, and Debugging Console Frame
Buffer Drivers
- DEBUG symbol
Use ASSERT to Catch Invalid
Assumptions
- detecting kernel memory leaks
Detecting Kernel Memory Leaks
- displaying kernel data structures
Obtaining Kernel Data Structure Information
- kmdb debugger
Using the kmdb Kernel Debugger
- kmem_flags
Setting kmem_flags Debugging Flags
- mdb debugger
Using the mdb Modular Debugger
- moddebug
Loading and Unloading Test Modules
- postmortem
Postmortem Debugging
- preparing for disasters
Avoiding Data Loss on a Test System
- setting up a serial connection
Testing With a Serial Connection
- setting up a SPARC test system
Setting Up a Target System on the SPARC Platform
- setting up an x86 test system
Setting Up a Target System on the x86 Platform
- system registers
Exploring System Registers With kmdb
- system file
Setting Up Test Modules
- tools
Debugging Tools
- using kernel variables
Modifying Kernel Variables
- using the SPARC PROM for device debugging
PROM on SPARC Systems
- writing mdb commands
Writing Debugger Commands With mdb
- delay() function
delay and timeout Argument
Changes- changes to
delay and timeout Argument
Changes
- dependency
Power Management Dependencies
- deprecated device access functions
Deprecated User Application Kernel and Device Access Functions
- deprecated DMA functions
Deprecated Direct Memory Access (DMA)
Functions
- deprecated interrupt functions
Deprecated Interrupt Functions
- deprecated memory allocation functions
Deprecated Memory Allocation and Deallocation
Functions
- deprecated power management functions
Deprecated Power Management Functions
- deprecated programmed I/O functions
Deprecated Programmed I/O Functions
- deprecated property functions
Deprecated Property Functions
- deprecated SCSI functions
Deprecated SCSI Functions
- deprecated time-related functions
Deprecated Time-Related Functions
- deprecated user application kernel functions
Deprecated User Application Kernel and Device Access Functions
- deprecated user process information functions
Deprecated User Process Information
Functions
- deprecated user space access functions
Deprecated User Space Access Functions
- deprecated virtual memory functions
Deprecated Virtual Memory Functions
- descriptor tree
Registering Drivers to Gain Device Access
The Descriptor Tree
- dest_adcent argument, ddi_device_copy()
- changes to
ddi_device_copy Argument Changes
- detach() entry point
- active power management
Active Power Management
- description of
detach Entry Point
- hot removal
Hot Removal
- network drivers
The mac_register and mac_unregister Functions
- system power management
System Power Management
- detecting kernel memory leaks with mdb
Detecting Kernel Memory Leaks
- dev_advcnt argument, ddi_device_zero()
- changes to
ddi_device_zero Argument Changes
- dev_datasz argument, ddi_device_copy()
- changes to
ddi_device_copy Argument Changes
- dev_datasz argument, ddi_device_zero()
- changes to
ddi_device_zero Argument Changes
- dev_info_t functions
Device Information Tree Node (dev_info_t)
Functions
- dev_ops structure
- description of
dev_ops Structure
- dev_t functions
Device (dev_t) Functions
- devfsadm command
Installing Drivers with add_drv
- device
- alternate settings
How USB Devices Appear to the System
- composite
Managing Entire Devices
Devices With Multiple Interfaces
- configurations
How USB Devices Appear to the System
- endpoints
How USB Devices Appear to the System
- interface number
Getting Interface Numbers
- interfaces
How USB Devices Appear to the System
- quiesce
Example Implementation of Interrupt Resource Management
System Quiesce Entry Point
- resume
Example Implementation of Interrupt Resource Management
System Quiesce Entry Point
- splitting interfaces
Multiple-Configuration Devices
USB Audio Compatible Device Names
- device access functions
- block drivers
open Entry Point (Block Drivers)
- character drivers
open Entry Point (Character
Drivers)
- deprecated
Deprecated User Application Kernel and Device Access Functions
- table
User Application Kernel and Device Access
Functions
- device configuration
- entry points
Device Configuration Concepts
- device context management
What Is a Device Context?- entry points
Entry Points for Device Context Management
- model
Context Management Model
- operation
Context Management Operation
- device directory
- recovering
Recovering the Device Directory
- device drivers
- See Also
loading drivers - See Also
linking drivers - See Also
compiling drivers
- 64-bit drivers
Making a Device Driver 64-Bit Ready
I/O Control Support for 64-Bit Capable
Device Drivers
- access from within kernel
Layered Driver Interface (LDI)
- aliases
Updating Driver Information
- binding to device node
Compatible Device Names
Binding a Driver to a Device
- bindings
Checking Device Driver Bindings
- block driver
Entry Points for Block Device Drivers
- configuration descriptor clouds
Hot Reinsertion
- context
Driver Context
- debugging
Debugging, Testing, and Tuning Device Drivers- coding hints
Debugging Preparation Techniques
- setting up a serial connection
Testing With a Serial Connection
- tools
Debugging Tools
- using the PROM
PROM on SPARC Systems
- definition
What Is a Device Driver?
- entry points
What Is a Device Driver Entry Point?
- error handling
Error Handling
- header files
Header Files
- hubd USB hub driver
Hot Insertion
- interface association nodes
Devices With Interface-Association Descriptors
- loadable interface
Loadable Driver Interfaces
- modifying information with update_drv
Updating Driver Information
- modifying permissions
Updating Driver Information
- module configuration
Source Files
- network drivers
Drivers for Network Devices
- offlining
Hot Removal
Hotplug Callbacks
- packaging
Driver Packaging
- printing messages
Returning Errors
- purpose in kernel
What Is the Kernel?
- source files
Source Files
- standard character driver
Entry Points for Character Device Drivers
- testing
Testing Drivers
Criteria for Testing Drivers
- tuning
Tuning Drivers
- USB driver
USB Drivers
- usb_ia USB interface association driver
Devices With Interface-Association Descriptors
- usb_mid USB multi-interface driver
Getting Interface Numbers
Hot Removal
Devices With Interface-Association Descriptors
Devices With Multiple Interfaces
- using stats
Kernel Statistics
- device ID functions
Device ID Functions
- device information
- binding a driver to a device
Binding a Driver to a Device
- binding a driver to a USB device
Compatible Device Names
- compatible device names
Compatible Device Names
- di_link_next_by_lnode() function
Device Information Library Interfaces
- di_link_next_by_node() function
Device Information Library Interfaces
- di_link_private_get() function
Device Information Library Interfaces
- di_link_private_set() function
Device Information Library Interfaces
- di_link_spectype() function
Device Information Library Interfaces
- di_link_t
Device Information Library Interfaces
- di_link_to_lnode() function
Device Information Library Interfaces
- di_lnode_devinfo() function
Device Information Library Interfaces
- di_lnode_devt() function
Device Information Library Interfaces
- di_lnode_name() function
Device Information Library Interfaces
- di_lnode_next() function
Device Information Library Interfaces
- di_lnode_private_get() function
Device Information Library Interfaces
- di_lnode_private_set() function
Device Information Library Interfaces
- di_lnode_t
Device Information Library Interfaces
- di_node_t
Device Information Library Interfaces
- di_walk_link() function
Device Information Library Interfaces
- di_walk_lnode() function
Device Information Library Interfaces
- DINFOLYR
Device Information Library Interfaces
- LDI
Retrieving Target Device Information
- lnode
Device Information Library Interfaces
- nblocks property
Device Sizes
- Nblocks property
Device Sizes
- property values
Retrieving Target Device Property Values
- self-identifying
Device Identification
- tree structure
Device Tree Components
Device Tree Components
- device interrupts See
interrupts; interrupt handling
- device layering See
LDI
- device memory
- D_DEVMAP flag in cb_ops
cb_ops Structure
- mapping
Mapping Device and Kernel Memory
Entry Points for Memory Mapped Devices
- device node
USB Devices and the Oracle Solaris Device Tree
- device number
- description of
Devices as Special Files
- device polling
Interrupt Handler Functionality- chpoll() function
Multiplexing I/O on File Descriptors
- in character drivers
Multiplexing I/O on File Descriptors
- poll() function
Multiplexing I/O on File Descriptors
- device power management
- components
Power Management Components
- definition of
Power Management Framework
- dependency
Power Management Dependencies
- entry points
power Entry Point
- interfaces
Device Power Management Interfaces
- model
Device Power Management Model
- pm_busy_component() function
Device Power Management
Busy-Idle State Transitions
Power Management States
- pm_idle_component() function
Device Power Management
Busy-Idle State Transitions
Busy-Idle State Transitions
Power Management States
- pm_lower_power() function
Multiple Component pm-components Entry
- pm_raise_power() function
Device Power Management
Busy-Idle State Transitions
Multiple Component pm-components Entry
Multiple Power Management Components
- power levels
Power Levels
- power() entry point
Active Power Management
Device Power Management
- power() function
power Entry Point
- state transitions
Busy-Idle State Transitions
- USB devices
Device Power Management
- usb_create_pm_components() function
Device Power Management
- device registers
- mapping
attach Entry Point
- device state in power management
Hardware State
- device tree
- displaying
Displaying the Device Tree
- navigating, in debugger
Obtaining Device Tree Information
- overview
Device Tree Components
- purpose in kernel
Oracle Solaris Kernel
- device usage
Kernel Interfaces- See
LDI
- device-dependency
- power.conf entry
Power Management Dependencies
- device-dependency-property
- power.conf entry
Power Management Dependencies
- devmap_ entry point
- devmap_access() function
devmap_access Entry Point
- devmap_ entry points
- devmap() function
The devmap(9E) Entry Point
- devmap_access() function
devmap_unload Entry Point
- devmap_contextmgt()function
devmap_contextmgt Entry
Point
- devmap_dup() function
devmap_dup Entry Point
- devmap_map() function
devmap_map Entry Point
- devmap_unmap() function
devmap_unmap Entry Point
- devmap_ functions
- devmap_devmem_setup() function
Associating Device Memory With User Mappings
- devmap_load() function
devmap_load Entry Point
- devmap_umem_setup() function
Exporting Kernel Memory to Applications
- devmap_unload() function
devmap_unload Entry Point
- diagnosis engine
- definition
What Is Predictive Self-Healing?
- disaster recovery
Recovering the Device Directory
- disk
- I/O controls
Disk ioctls
- performance
Disk Performance
- disk driver testing
Testing Disk Drivers
- DKI See
DDI/DKI
- DL_ETHER
- network statistics
GLDv2 Network Statistics
- DLIOCRAW
- ioctl() function
GLDv2 I/O Control Functions
- DLPI (Data Link Provider Interface) See
network drivers, GLDv2
- DLPI primitives
- DL_GET_STATISTICS_REQ
GLDv2 Network Statistics
- DMA
- buffer allocation
Allocating Private DMA Buffers
- burst sizes
Determining Maximum Burst Sizes
- callbacks
Canceling DMA Callbacks
- cookie
DMA Software Components: Handles, Windows, and Cookies
DMA Model
- freeing handle
Freeing the DMA Handle
- freeing resources
Freeing the DMA Resources
- handle
Allocating a DMA Handle
DMA Software Components: Handles, Windows, and Cookies
DMA Model
- object
DMA Model
- object locking
Object Locking
- operations
DMA Operations
- physical addresses
Types of Host Platform DMA
- private buffer allocation
Allocating Private DMA Buffers
- register structure
Device Register Structure
- resource allocation
Allocating DMA Resources
- restrictions
DMA Attributes and Limits
- transfers
DMA Transfers (Synchronous)
DMA Operations
- virtual addresses
Types of Host Platform DMA
- windows
DMA Windows
DMA Software Components: Handles, Windows, and Cookies
- DMA functions
Direct Memory Access (DMA) Functions- deprecated
Deprecated Direct Memory Access (DMA)
Functions
- driver binding name
Binding a Driver to a Device
- driver module entry points See
entry points
- driver.conf files See
hardware configuration files
- drv_getparm() function
- changes to
drv_getparm Argument Changes
- drv_usecwait(9F)
Delays in Chip Access
- DTrace
- task queues
Task Queue DTrace SDT Probes
- dump() entry point
- block drivers
dump Entry Point (Block Drivers)
- DVMA
- SBus slots supporting
Ultra 2 SBus Address Bits
- virtual addresses
Types of Host Platform DMA
- dynamic memory allocation
Dynamic Memory Allocation
E
- eeprom(1M) command
Additional Suggestions for Testing Console Frame
Buffer Drivers
- EHCI (Enhanced Host Controller Interface)
USB Client Drivers
- ENA (Error Numeric Association)
Queueing an Error Event
- entry points
- attach() function
Device Power Management
Registering Drivers to Gain Device Access
attach Entry Point
attach Entry Point
- active power management
Active Power Management
- system power management
System Power Management
- definition
What Is a Device Driver Entry Point?
- detach() function
Active Power Management
detach Entry Point
detach Entry Point
- hot removal
Hot Removal
- system power management
System Power Management
- device context management
Entry Points for Device Context Management
- for block drivers
Block Driver Roadmap
Block Driver Roadmap
- for character drivers
Character Driver Roadmap
Character Driver Roadmap
- for device configuration
Device Configuration Concepts
- for device power management
power Entry Point
- for network drivers
GLDv2 Entry Points
- ioctl() function
Miscellaneous I/O Control
- power() function
Active Power Management
Device Power Management
power Entry Point
- probe() function
probe Entry Point
- quiesce() function
System Quiesce Entry Point
- SCSA HBA summary
SCSA HBA Entry Point Summary
- system power management
Entry Points Used by System Power Management
- ereport
- definition
What Is Predictive Self-Healing?
- ereport event
- definition
What Is Predictive Self-Healing?
- error handling
Functionality Testing
- error messages, printing
print Entry Point (Block
Drivers)
Returning Errors
- Ethernet V2 See
DL_ETHER
- event registry
Queueing an Error Event
Message IDs and Dictionary Files
- events
- asynchronous notification
Receiving Asynchronous Device Event Notification
- attributes
Defining Event Attributes
- description of
Introduction to Events
- hotplug notification
Hotplug Callbacks
- Eversholt fault tree (eft) rules
Queueing an Error Event
- exporting device memory to user applications
Associating Device Memory With User Mappings
- external registers
Internal Sequencing Logic
- system file
Setting Up Test Modules
F
- _fini() entry point
- example of
_fini Example
- network drivers
The mac_init_ops and mac_fini_ops Functions
- fault
- definition
What Is Predictive Self-Healing?
- fault event
- definition
What Is Predictive Self-Healing?
- fault management
- pci_ereport_setup() function
Declaring Fault Management Capabilities
- .dict dictionary files
Message IDs and Dictionary Files
- .po message files
Message IDs and Dictionary Files
- access or DMA handle error
Service Impact Function
- agent
What Is Predictive Self-Healing?
- Automated System Recovery Unit (ASRU)
Diagnosis, Suspect Lists, and Fault Events
- DDI_FM_* I/O controller errors
Reporting Standard I/O Controller Errors
- ddi_fm_capable() function
Getting the Fault Management Capability Bit Mask
- ddi_fm_ereport_post() function
Reporting Standard I/O Controller Errors
Queueing an Error Event
- ddi_fm_fini() function
Cleaning Up Fault Management Resources
- ddi_fm_init() function
Declaring Fault Management Capabilities
- ddi_fm_service_impact() function
Service Impact Function
- DDI_SERVICE_* service impact values
Service Impact Function
- diagnosis engine
What Is Predictive Self-Healing?
- eft diagnosis engine
Reporting Standard I/O Controller Errors
- ENA (Error Numeric Association)
Queueing an Error Event
- ereport
Error Handling
What Is Predictive Self-Healing?
- ereport events
Queueing an Error Event
What Is Predictive Self-Healing?
- error handling
Error Handling
- event registry
Reporting Standard I/O Controller Errors
Queueing an Error Event
Message IDs and Dictionary Files
- Eversholt fault tree (eft) rules
Queueing an Error Event
- fault
What Is Predictive Self-Healing?
- fault event
System Topology
What Is Predictive Self-Healing?
- fault management capabilities
Declaring Fault Management Capabilities
- fault management capabilities, declaring
Declaring Fault Management Capabilities
- fault management capability bit mask
Getting the Fault Management Capability Bit Mask
- fault management capability properties
Declaring Fault Management Capabilities
- fault management resources, cleaning up
Cleaning Up Fault Management Resources
- fault manager daemon fmd
Oracle Solaris Fault Manager
- fault messages
Message IDs and Dictionary Files
- Field Replaceable Unit (FRU)
Diagnosis, Suspect Lists, and Fault Events
- fmadm command
Response Agents
- fmdump command
Diagnosis, Suspect Lists, and Fault Events
- I/O Fault Services
Hardening Oracle Solaris Drivers
- interfaces
Fault Management Functions
- list suspect
Message IDs and Dictionary Files
Diagnosis, Suspect Lists, and Fault Events
- pci_ereport_post() function
Detecting and Reporting PCI-Related Errors
- pci_ereport_seetup() function
Detecting and Reporting PCI-Related Errors
- pci_ereport_teardown() function
Detecting and Reporting PCI-Related Errors
Cleaning Up Fault Management Resources
- response agent
Response Agents
- retire agent
Response Agents
- suspect list
Diagnosis, Suspect Lists, and Fault Events
- topology of system
System Topology
- Fault Management Architecture (FMA) See
fault management
- faults
- latent fault, definition of
Periodic Health Checks
- fbconfig() module
Frame Buffer Specific Configuration Module
- fbconfig(1M) command
Testing the Video Mode Change Callback Function
- FDDI (Fibre Distributed Data Interface)
TPR and FDDI: SNAP Processing
- Fibre Channel
- supported HBA interfaces
Supported Fibre Channel HBA API
- fibre distributed data interface See
DL_FDDI
- Field Replaceable Unit (FRU)
- definition
Diagnosis, Suspect Lists, and Fault Events
- file system I/O
File I/O
- first-party DMA
Performing First-Party DMA Transfers
First-Party DMA
- flags argument, ddi_dma_mem_alloc()
- changes to
ddi_dma_mem_alloc Argument
Changes
- flow of control for power management
Power Management Flow of Control
- fmadm command
Response Agents
- fmd fault manager daemon
Oracle Solaris Fault Manager
- fmdump command
Diagnosis, Suspect Lists, and Fault Events
- freemsg() function
Request Features and Fields
- functions
- See
individual functions - See Also
LDI functions - See Also
device power management - See Also
condition variable functions - See
specific function name
- fuser command
- display device usage information
Device User Command Interfaces
G
- getinfo() entry point
getinfo Entry Point
- GCC
Compiling and Linking the Driver
- gcc command
Compiling and Linking the Driver
- generic device name
Generic Device Names
- getmajor() function
Block Device Autoconfiguration
- getrbuf() function
- changes to
getrbuf Argument Changes
- getting major numbers
- example of
Block Device Autoconfiguration
- GLD (Generic LAN Driver) See
network drivers
- gld() entry point
GLDv2 Network Device Driver Framework
- gld() functions
GLDv2 Network Device Driver Framework
- gld(9F) function
- network driver
GLDv2 Driver Requirements
- gld_intr() function
gld_intr Function
- gld_mac_alloc() function
gld_mac_alloc Function
- gld_mac_free() function
gld_mac_free Function
- gld_mac_info structure
GLDv2 Network Device Driver Framework- description of
gld_mac_info Structure
- GLDv2 arguments
GLDv2 Function Arguments
- network drivers
GLDv2 Driver Requirements
- used in gld_intr() function
gld_intr Function
- gld_recv() function
gld_recv Function
- gld_register() function
gld_register Function
- gld_sched() function
gld_sched Function
- gld_stats structure
- network driver
GLDv2 Network Statistics
- gld_unregister() function
gld_unregister Function
- gldm_get_stats()
- description of
GLDv2 Network Statistics
- gldm_private structure
gld_mac_info Structure
- GLDv2 data structures
- gld_mac_info
gld_mac_info Structure
- gld_stats
gld_stats Structure
- GLDv2 entry points
- gldm_get_stats()
gldm_get_stats Entry
Point
- gldm_intr()
gldm_intr Entry Point
- gldm_ioctl()
gldm_ioctl Entry Point
- gldm_reset()
gldm_reset Entry Point
- gldm_send()
gldm_send Entry Point
- gldm_set_mac_addr()
gldm_set_mac_addr Entry
Point
- gldm_set_multicast()
gldm_set_multicast Entry
Point
- gldm_set_promiscuous()
gldm_set_promiscuous Entry
Point
- gldm_start()
gldm_start Entry Point
- gldm_stop()
gldm_stop Entry Point
- GLDv2 ioctl functions
GLDv2 I/O Control Functions
- GLDv2 network statistics
GLDv2 Network Statistics
- GLDv2 service routines
- gld_intr() function
gld_intr Function
- gld_mac_alloc() function
gld_mac_alloc Function
- gld_mac_free() function
gld_mac_free Function
- gld_recv() function
gld_recv Function
- gld_register() function
gld_register Function
- gld_sched() function
gld_sched Function
- gld_unregister() function
gld_unregister Function
- GLDv2 symbols
- GLD_BADARG
GLDv2 Return Values
- GLD_FAILURE
GLDv2 Return Values
- GLD_MAC_PROMISC_MULTI
GLDv2 Function Arguments
- GLD_MAC_PROMISC_NONE
GLDv2 Function Arguments
- GLD_MAC_PROMISC_PHYS
GLDv2 Function Arguments
- GLD_MULTI_DISABLE
gldm_set_multicast Entry
Point
- GLD_MULTI_ENABLE
gldm_set_multicast Entry
Point
- GLD_NOLINK
gldm_send Entry Point
- GLD_NORESOURCES
gld_sched Function
- GLD_NOTSUPPORTED
gldm_set_mac_addr Entry
Point
- GLD_SUCCESS
GLDv2 Return Values
- graphics devices
- device context management of
Context Management Model
H
- handle, DMA
Freeing the DMA Handle
Allocating a DMA Handle
DMA Model
- hardening drivers
Hardening Oracle Solaris Drivers
- hardware checksumming
Hardware Checksumming: MAC Layer
Hardware Checksumming: Hardware
Hardware Checksum Offload
- hardware configuration files
Writing a Hardware Configuration File
Configuration Files
- PCI devices
PCI Hardware Configuration Files
- SBus devices
SBus Hardware Configuration Files
- SCSI target devices
Hardware Configuration File
- where to place
Copying the Driver to a Module Directory
- hardware context
What Is a Device Context?
- hardware state in power management
Hardware State
- HBA driver See
SCSI HBA driver
- header files for device drivers
Header Files
- high-level mutexes
- interrupts
High-Level Mutexes
- host bus adapter transport layer
SCSA Interface
- hot-plug See
hotplugging
- hotpluggable drivers See
hotplugging
- hotplugging
Hotplugging and Device Drivers- and SCSI HBA driver
Dynamic Reconfiguration
Hotplugging and Device Drivers
- USB device
Hotplugging USB Devices
- hub driver
USB Client Drivers
- hubd USB hub driver
Hot Insertion
I
- _info() entry point
- example of
_info Example
- _init() entry point
- example of
_init Function
- network drivers
The mac_init_ops and mac_fini_ops Functions
- I/O
- asynchronous data transfers
Asynchronous Data Transfers (Block Drivers)
Differences Between Synchronous and Asynchronous
I/O
- byte stream
Entry Points for Character Device Drivers
- disk controls
Disk ioctls
- DMA transfers
DMA Transfers (Synchronous)
- file system structure
File I/O
- miscellaneous control of
Miscellaneous I/O Control
- multiplexing
Multiplexing I/O on File Descriptors
- polled I/O interfaces
Implementing Polled I/O in Console Frame Buffer Drivers
Polled I/O Interfaces
- programmed transfers
Programmed I/O Transfers
- scatter/gather structures
Vectored I/O
- synchronous data transfers
Synchronous Data Transfers (Block Drivers)
Differences Between Synchronous and Asynchronous
I/O
- visual I/O interfaces
Console Visual I/O Interfaces
- IEEE 802.3
Ethernet V2 and ISO 8802-3 (IEEE 802.3)
- IEEE 802.5
TPR and FDDI: SNAP Processing
- ILP32
- use in devmap()
Data Sharing in devmap
- use in ioctl()
Data Sharing in ioctl
- use in mmap()
Data Sharing in mmap
- ILP64
- use in mmap()
Data Sharing in mmap
- instance numbers
Device Instances and Instance Numbers
- interface association nodes
Devices With Interface-Association Descriptors
- internal mode registers
Internal Sequencing Logic
- internal sequencing logic
Internal Sequencing Logic
- interrupt functions
Interrupt Functions
- interrupt handlers
- functionality
Interrupt Handler Functionality
- registering
Registering Interrupts
- interrupt handling
Interrupt Handlers- callback handler function
Callback Interfaces
- clearing masks
Clearing Interrupt Masks
- ddi_cb_register() function
Callback Interfaces
- ddi_cb_unregister() function
Callback Interfaces
- ddi_intr_add_handler() function
Interrupt Initialization and Destruction Functions
- ddi_intr_add_handler() function
Registering Interrupts
MSI-X Interrupts
- ddi_intr_add_softint() function
Soft Interrupt Functions
- ddi_intr_alloc() function
Interrupt Request Interfaces
Interrupt Initialization and Destruction Functions
MSI-X Interrupts
- ddi_intr_block_disable() function
Interrupt Initialization and Destruction Functions
- ddi_intr_block_enable() function
Interrupt Initialization and Destruction Functions
- ddi_intr_clr_mask() function
Clearing Interrupt Masks
Interrupt Initialization and Destruction Functions
- ddi_intr_disable() function
Interrupt Initialization and Destruction Functions
MSI-X Interrupts
- ddi_intr_dup_handler() function
Interrupt Initialization and Destruction Functions
- ddi_intr_dup_handler() function
MSI-X Interrupts
- ddi_intr_enable() function
Interrupt Initialization and Destruction Functions
MSI-X Interrupts
- ddi_intr_free() function
Interrupt Initialization and Destruction Functions
MSI-X Interrupts
- ddi_intr_get_cap() function
Interrupt Capability Functions
- ddi_intr_get_hilevel_pri() function
Priority Management Functions
- ddi_intr_get_hilevel_pri() function
Handling High-Level Interrupts
- ddi_intr_get_navail() function
Interrupt Capability Functions
- ddi_intr_get_nintrs() function
Interrupt Capability Functions
- ddi_intr_get_pending() function
Interrupt Initialization and Destruction Functions
- ddi_intr_get_pending() function
Checking for Pending Interrupts
- ddi_intr_get_pri() function
Handling High-Level Interrupts
Priority Management Functions
- ddi_intr_get_softint_pri() function
Soft Interrupt Functions
- ddi_intr_get_supported_types() function
Interrupt Capability Functions
- ddi_intr_hilevel() function
High-Level Interrupts
- ddi_intr_remove_handler() function
Interrupt Initialization and Destruction Functions
- ddi_intr_remove_handler() function
MSI-X Interrupts
- ddi_intr_remove_softint() function
Soft Interrupt Functions
- ddi_intr_set_cap() function
Interrupt Initialization and Destruction Functions
- ddi_intr_set_mask() function
Setting Interrupt Masks
Interrupt Initialization and Destruction Functions
- ddi_intr_set_nreq() function
Interrupt Request Interfaces
- ddi_intr_set_pri() function
Priority Management Functions
- ddi_intr_set_softint_pri() function
Soft Interrupt Functions
- ddi_intr_set_softint_pri() function
Changing Soft Interrupt Priority
- ddi_intr_trigger_softint() function
Soft Interrupt Functions
- ddi_intr_trigger_softint() function
High-Level Interrupts
- gld_intr() function
gld_intr Function
- high-level interrupts
Handling High-Level Interrupts
Software Interrupts
High-Level Interrupts
- overview
Interrupt Handling
- pending interrupts
Checking for Pending Interrupts
- setting masks
Setting Interrupt Masks
- software interrupts
Handling High-Level Interrupts
Changing Soft Interrupt Priority
Software Interrupts
- interrupt property
- definition
Interrupt Handling
- Interrupt Resource Management
Interrupt Resource Management
- interrupts
- allocating
Interrupt Request Interfaces
- callback support
Callback Interfaces
- capability functions
Interrupt Capability Functions
- changing soft interrupt priority example
Interrupt Function Examples
- checking pending interrupts example
Interrupt Function Examples
- clearing interrupt masks example
Interrupt Function Examples
- common problems with
Interrupt Issues
- description of
Interrupt Handler Overview
- handling high-level interrupts examples
High-Level Interrupt Handling Example
- handling low-level interrupts example
High-level Interrupt Routine
- high-level mutexes
High-Level Mutexes
- initialization and destruction functions
Interrupt Initialization and Destruction Functions
- interrupt handling example
Interrupt Handler Functionality
- legacy defined
Device Interrupts
- message-signaled defined
Device Interrupts
- MSI defined
Device Interrupts
- MSI implementation
MSI Interrupts
- MSI-X defined
Device Interrupts
- MSI-X implementation
MSI-X Interrupts
- network drivers
GLDv2 Driver Requirements
- priority levels
High-Level Interrupts
- priority management functions
Priority Management Functions
- registering legacy interrupt example
Registering a Legacy Interrupt
- registering legacy interrupts
Registering Legacy Interrupts
- registering MSI interrupts
Registering MSI Interrupts
- registering MSI interrupts example
Registering a Set of MSI Interrupts
- removing legacy interrupt example
Removing a Legacy Interrupt
- removing MSI interrupts example
Removing MSI Interrupts
- requesting
Interrupt Request Interfaces
- setting interrupt masks example
Interrupt Function Examples
- soft interrupt functions
Soft Interrupt Functions
- software interrupts
Handling High-Level Interrupts
- types of
Device Interrupts
- using legacy
Legacy Interrupts
- writing handlers
Interrupt Handlers
- ioctl() function
- character drivers
ioctl Entry Point (Character
Drivers)
- commands
Well Known ioctl Interfaces
- DLIOCRAW
GLDv2 I/O Control Functions
- ioctl(9E) driver entry point
SPARC Platform Console Communication
- iovec structure
Vectored I/O
- IRM See
Interrupt Resource Management
- ISO 8802-3
Ethernet V2 and ISO 8802-3 (IEEE 802.3)
- ISO 9314-2
TPR and FDDI: SNAP Processing
- ISR (interrupt service routine)
Interrupt Handler Functionality
K
- _KERNEL symbol
Compiling and Linking the Driver
- kernel
- debugger See
kmdb debugger
- device tree
Oracle Solaris Kernel
- memory
- allocation
Dynamic Memory Allocation
- associating with user applications
Associating Kernel Memory With User Mappings
- detecting leaks with mdb
Detecting Kernel Memory Leaks
- module directory
Copying the Driver to a Module Directory
- overview
What Is the Kernel?
- kernel data structures
Obtaining Kernel Data Structure Information
- kernel logging functions
Kernel Logging and Printing Functions
- kernel statistics See
stats
- kernel statistics functions
Kernel Statistics Functions
- kernel terminal emulator
Oracle Solaris Consoles and the Kernel Terminal Emulator
- kernel thread functions
Kernel Thread Control and Synchronization
Functions
- kernel variables
- setting
Setting Kernel Variables
- use with debuggers
Modifying Kernel Variables
- using
Setting Up Test Modules
- kmdb debugger
Using the kmdb Kernel Debugger- booting on SPARC systems
Booting kmdb With an Alternate Kernel on the SPARC Platform
- booting on x86 systems
Booting kmdb With an Alternate Kernel on the x86 Platform
- macros
kmdb Macros for Driver Developers
- setting breakpoints
Setting Breakpoints in kmdb
- kmdb kernel debugger
Using the Deadman Feature
- kmem_alloc() function
Dynamic Memory Allocation
- kmem_flags kernel variable
Setting kmem_flags Debugging Flags
- kmem_free() function
Retrieving Target Device Information
- kstats See
network statistics- functions
Kernel Statistics Functions
- task queues
Task Queue Kernel Statistics Counters
L
- latent fault
- definition of
Periodic Health Checks
- layered driver handle See
LDI
- Layered Driver Interface See
LDI
- layered identifier See
LDI
- ld command
Compiling and Linking the Driver
- LDI
Layered Driver Interface (LDI)- definition
Oracle Solaris Kernel
- device access
Kernel Interfaces
- device consumer
LDI Overview
- device information
Kernel Interfaces
- device layering
User Interfaces
- device usage
Device User Command Interfaces
Print System Configuration Command Interfaces
User Interfaces
Kernel Interfaces
- event notification interfaces
Receiving Asynchronous Device Event Notification
- fuser command
Device User Command Interfaces
- kernel device consumer
LDI Overview
- layered driver
LDI Overview
- layered driver handle
Driver Source File
Layered Driver Handles – Target Devices
- layered identifier
Driver Source File
Layered Identifiers – Kernel Device Consumers
- libdevinfo interfaces
User Interfaces
- prtconf command
Print System Configuration Command Interfaces
- target device
Layered Driver Handles – Target Devices
LDI Overview
- LDI functions
- ldi_add_event_handler() function
Receiving Asynchronous Device Event Notification
- ldi_aread() function
Accessing Target Devices
- ldi_awrite() function
Accessing Target Devices
- ldi_close() function
Driver Source File
Opening and Closing Target Devices
- ldi_devmap() function
Accessing Target Devices
- ldi_dump() function
Accessing Target Devices
- ldi_get_dev() function
Retrieving Target Device Information
- ldi_get_devid() function
Retrieving Target Device Information
- ldi_get_eventcookie() function
Receiving Asynchronous Device Event Notification
- ldi_get_minor_name() function
Retrieving Target Device Information
- ldi_get_otyp() function
Retrieving Target Device Information
- ldi_get_size() function
Retrieving Target Device Information
- ldi_getmsg() function
Accessing Target Devices
- ldi_ident_from_dev() function
Driver Source File
- ldi_ident_from_dev() function
Layered Identifiers – Kernel Device Consumers
- ldi_ident_from_dip() function
Layered Identifiers – Kernel Device Consumers
- ldi_ident_from_stream() function
Layered Identifiers – Kernel Device Consumers
- ldi_ident_release() function
Driver Source File
Layered Identifiers – Kernel Device Consumers
- ldi_ioctl() function
Accessing Target Devices
- ldi_open_by_dev() function
Opening and Closing Target Devices
- ldi_open_by_devid() function
Opening and Closing Target Devices
- ldi_open_by_name() function
Driver Source File
Opening and Closing Target Devices
- ldi_poll() function
Accessing Target Devices
- ldi_prop_exists() function
Retrieving Target Device Property Values
- ldi_prop_get_int() function
Retrieving Target Device Property Values
- ldi_prop_get_int64() function
Retrieving Target Device Property Values
- ldi_prop_lookup_byte_array() function
Retrieving Target Device Property Values
- ldi_prop_lookup_int64_array() function
Retrieving Target Device Property Values
- ldi_prop_lookup_int_array() function
Retrieving Target Device Property Values
- ldi_prop_lookup_string() function
Retrieving Target Device Property Values
- ldi_prop_lookup_string_array() function
Retrieving Target Device Property Values
- ldi_putmsg() function
Accessing Target Devices
- ldi_read() function
Accessing Target Devices
- ldi_remove_event_handler() function
Receiving Asynchronous Device Event Notification
- ldi_strategy() function
Accessing Target Devices
- ldi_write() function
Driver Source File
Accessing Target Devices
- LDI types
- ldi_callback_id_t
Receiving Asynchronous Device Event Notification
- ldi_handle_t
Layered Driver Handles – Target Devices
- ldi_ident_t
Layered Identifiers – Kernel Device Consumers
- leaf devices
- description of
Device Tree Components
- legacy interrupts
- defined
Device Interrupts
- using
Legacy Interrupts
- length argument, ddi_dma_mem_alloc()
- changes to
ddi_dma_mem_alloc Argument
Changes
- libdevinfo()
- displaying the device tree
libdevinfo Library
- libdevinfo device information library
User Interfaces
- linking drivers
Compiling and Linking the Driver
- lint command
- 64-bit environment
General Conversion Steps
- list suspect
- definition
Diagnosis, Suspect Lists, and Fault Events
- lnode
Device Information Library Interfaces
- loadable module functions
Module Functions
- loading drivers
Compiling and Linking the Driver- add_drv command
Installing Drivers with add_drv
- hardware configuration file
Writing a Hardware Configuration File
- loading modules
Copying the Driver to a Module Directory
Loadable Module Entry Points
- loading test modules
Loading and Unloading Test Modules
- locking primitives, types of
Locking Primitives
- locks
- manipulating
Kernel Thread Control and Synchronization
Functions
- mutex
Mutual-Exclusion Locks
- readers/writer
Readers/Writer Locks
- scheme for
Choosing a Locking Scheme
- LP64
- use in devmap()
Data Sharing in devmap
- use in ioctl()
Data Sharing in ioctl
- lso_basic_tcp_ipv4() structure
Large Segment (or Send) Offload
- LUN bits
Building a Command
M
- mac_alloc() function
The mac_alloc and mac_free Functions
- mac_callbacks MAC entry points structure
GLDv3 MAC Registration Data Structures
- mac_capab_lso() structure
Large Segment (or Send) Offload
- mac_fini_ops() function
The mac_init_ops and mac_fini_ops Functions
- mac_hcksum_get() function
Hardware Checksumming: Hardware
Hardware Checksum Offload
- mac_hcksum_set() function
Hardware Checksumming: MAC Layer
Hardware Checksum Offload
- mac_init_ops() function
The mac_init_ops and mac_fini_ops Functions
- mac_link_update() function
GLDv3 State Change Notifications
- mac_lso_get() function
Large Segment Offload
Large Segment (or Send) Offload
- mac_register() function
The mac_register and mac_unregister Functions
- mac_register MAC registration information structure
GLDv3 MAC Registration Data Structures
The mac_alloc and mac_free Functions
- mac_rx() function
Receive Data Path
- mac_tx_update() function
GLDv3 State Change Notifications
Flow Control
- mac_unregister() function
The mac_register and mac_unregister Functions
- major numbers
- description of
Devices as Special Files
- example of
Block Device Autoconfiguration
- makedevice() function
Block Device Autoconfiguration
- mapsize argument, rmallocmap()
- changes to
rmallocmap and rmallocmap_wait Argument Changes
- mc_getcapab() entry point
GLDv3 Capabilities
- mc_getprop() entry point
GLDv3 Properties
- mc_getstat() entry point
GLDv3 Network Statistics
- mc_propinfo() entry point
GLDv3 Properties
- mc_setprop() entry point
GLDv3 Properties
- mc_tx() entry point
Transmit Data Path
- mc_unicst() entry point
Receive Data Path
- mdb
- detecting kernel memory leaks
Detecting Kernel Memory Leaks
- writing commands
Writing Debugger Commands With mdb
- mdb debugger
Using the mdb Modular Debugger- navigating device tree with
Obtaining Device Tree Information
- retrieving soft state information
Retrieving Driver Soft State Information
- running
Getting Started With the Modular Debugger
- memory allocation
- description of
Dynamic Memory Allocation
- memory allocation functions
Memory Allocation and Deallocation Functions
Memory Allocation and Deallocation Functions
- deprecated
Deprecated Memory Allocation and Deallocation
Functions
- memory leaks, detecting with mdb
Detecting Kernel Memory Leaks
- memory management unit
- description of
Virtual Memory
- memory mapping
- device context management of
Context Management Model
- device memory management
Mapping Device Memory
Mapping Device and Kernel Memory
Entry Points for Memory Mapped Devices
- memory model
- SPARC
System Memory Model
- store buffers
Store Buffers
- message-signaled interrupts
- defined
Device Interrupts
- minor device node
Creating Minor Device Nodes- modifying permissions of
Updating Driver Information
- minor numbers
Devices as Special Files
- minphys() function
minphys Entry Point- bulk requests
Bulk Requests
- mmap() function
- driver notification
Associating User Mappings With Driver Notifications
- mod_install() function
- network drivers
The mac_init_ops and mac_fini_ops Functions
- mod_remove() function
- network drivers
The mac_init_ops and mac_fini_ops Functions
- moddebug kernel variable
Setting the moddebug Kernel Variable
- modinfo command
Loading and Unloading Test Modules
Change the Target Device
- modldrv structure
- description of
modldrv Structure
- modlinkage structure
- description of
modlinkage Structure
- modload command
Loading and Unloading Test Modules
- modular debugger See
mdb debugger
- module directory
Copying the Driver to a Module Directory
- module functions
Module Functions
- module_info structure
- network drivers
GLDv2 Driver Requirements
- modunload command
Loading and Unloading Test Modules- description of
Loading and Unloading Drivers
- mount() function
- block drivers
open Entry Point (Block Drivers)
- msgb() structure
Isochronous Requests
Bulk Requests
- MSI interrupts
- defined
Device Interrupts
- implementation
MSI Interrupts
- MSI-X interrupts
- defined
Device Interrupts
- implementation
MSI-X Interrupts
- multiplexing I/O
Multiplexing I/O on File Descriptors
- multiprocessor considerations
Device Context Switched to User Process A
- multithreading
- and condition variables
Initializing Condition Variables
- and locking primitives
Locking Primitives
- D_MP flag in cb_ops structure
cb_ops Structure
- execution environment
Multithreaded Execution Environment
- thread synchronization
Condition Variables in Thread Synchronization
- mutex
- functions
Setting Up Mutexes
- locks
Mutual-Exclusion Locks- manipulating
Kernel Thread Control and Synchronization
Functions
- related panics
Potential Locking Pitfalls
- routines
Mutual-Exclusion Locks
- mutex_enter() function
High-Level Interrupts
- mutex_exit() function
High-Level Interrupts
- mutex_init() function
Registering Drivers to Gain Device Access
- mutex_owned() function
- example of
Use mutex_owned to Validate and Document Locking Requirements
- mutual-exclusion locks See
mutex
N
- name property
- description of
Binding a Driver to a Device
- naming
- unique prefix for driver symbols
Use a Unique Prefix to Avoid Kernel Symbol Collisions
What Is a Device Driver Entry Point?
- nblocks property
- deprecated
Device Sizes
- Nblocks property
- definition
Device Sizes
- nblocks property
- use in block device drivers
Block Device Autoconfiguration
- Nblocks property
- use in block device drivers
Block Device Autoconfiguration
- nbytes argument, uiomove()
- changes to
uiomove Argument Changes
- network drivers
- _fini() entry point
The mac_init_ops and mac_fini_ops Functions
- _init() entry point
The mac_init_ops and mac_fini_ops Functions
- attach() entry point
GLDv2 Network Device Driver Framework
The mac_register and mac_unregister Functions
- detach() entry point
The mac_register and mac_unregister Functions
- DL_ETHER
Ethernet V2 and ISO 8802-3 (IEEE 802.3)
- DL_FDDI
TPR and FDDI: SNAP Processing
- DL_TPR
TPR and FDDI: SNAP Processing
- entry points
Summary of GLDv3 Interfaces
GLDv3 MAC Registration Data Structures
- Ethernet V2 packet processing
Ethernet V2 and ISO 8802-3 (IEEE 802.3)
- FDDI (Fibre Distributed Data Interface)
TPR and FDDI: SNAP Processing
- gld() entry point
GLDv2 Network Device Driver Framework
- gld() functions
GLDv2 Network Device Driver Framework
- gld_mac_info structure
GLDv2 DLPI Primitives
GLDv2 Network Device Driver Framework
- gld_register() function
GLDv2 DLPI Primitives
- GLDv2
GLDv2 Network Device Driver Framework
- hardware checksumming
Hardware Checksumming: MAC Layer
Hardware Checksumming: Hardware
Hardware Checksum Offload
- IEEE 802.3
Ethernet V2 and ISO 8802-3 (IEEE 802.3)
- IEEE 802.5
TPR and FDDI: SNAP Processing
- ISO 8802-3
Ethernet V2 and ISO 8802-3 (IEEE 802.3)
- ISO 9314-2
TPR and FDDI: SNAP Processing
- lso_basic_tcp_ipv4() structure
Large Segment (or Send) Offload
- MAC type identifier
GLDv3 MAC Registration Data Structures
- MAC version number
The mac_alloc and mac_free Functions
- mac_alloc() function
The mac_alloc and mac_free Functions
- mac_callbacks structure
GLDv3 MAC Registration Data Structures
- mac_capab_lso() structure
Large Segment (or Send) Offload
- mac_fini_ops() function
The mac_init_ops and mac_fini_ops Functions
- mac_hcksum_get() function
Hardware Checksumming: Hardware
Hardware Checksum Offload
- mac_hcksum_set() function
Hardware Checksumming: MAC Layer
Hardware Checksum Offload
- mac_init_ops() function
The mac_init_ops and mac_fini_ops Functions
- mac_link_update() function
GLDv3 State Change Notifications
- mac_lso_get() function
Large Segment Offload
Large Segment (or Send) Offload
- mac_register() function
The mac_register and mac_unregister Functions
- mac_register structure
GLDv3 MAC Registration Data Structures
The mac_alloc and mac_free Functions
- mac_rx() function
Receive Data Path
- mac_tx_update() function
GLDv3 State Change Notifications
Flow Control
- mac_unregister() function
The mac_register and mac_unregister Functions
- mc_getcapab() entry point
GLDv3 Capabilities
- mc_getprop() entry point
GLDv3 Properties
- mc_getstat() entry point
GLDv3 Network Statistics
- mc_propinfo() entry point
GLDv3 Properties
- mc_setprop() entry point
GLDv3 Properties
- mc_tx() entry point
Transmit Data Path
- mc_unicst() entry point
Receive Data Path
- mod_install() function
The mac_init_ops and mac_fini_ops Functions
- mod_remove() function
The mac_init_ops and mac_fini_ops Functions
- open() entry point
GLDv2 DLPI Providers
- SAP (Service Access Point)
Ethernet V2 and ISO 8802-3 (IEEE 802.3)
- SNAP processing
TPR and FDDI: SNAP Processing
- source routing
TPR: Source Routing
- testing
Testing Network Drivers
- TPR (Token Passing Ring)
TPR and FDDI: SNAP Processing
- network statistics
- DL_ETHER
GLDv2 Network Statistics
- gld_stats
GLDv2 Network Statistics
- gldm_get_stats()
GLDv2 Network Statistics
- kstat structures
GLDv2 Network Statistics
- nexus See
bus nexus device drivers
- nexus driver
USB Client Drivers
- no-involuntary-power-cycles property
Device Power State Transitions
- nvlist_alloc structure
- description of
Defining Event Attributes
O
- object locking
Object Locking
- offlining
Hot Removal
Hotplug Callbacks
- OHCI (Open Host Controller Interface)
USB Client Drivers
- open() entry point
- block drivers
open Entry Point (Block Drivers)
- character drivers
Device Access (Character Drivers)
- network drivers
GLDv2 DLPI Providers
- Oracle Developer Studio
Compiling and Linking the Driver
P
- .po message files
Message IDs and Dictionary Files
- packaging
Driver Packaging
- partial store ordering
Partial Store Ordering (PSO)
- PCI bus
PCI Local Bus- configuration address space
PCI Address Domain
- configuration base address registers
PCI Configuration Base Address Registers
- hardware configuration files
PCI Hardware Configuration Files
- I/O address space
PCI I/O Address Space
- memory address space
PCI Memory Address Space
- PCI configuration functions
- alternate access mechanisms
Programmed I/O Functions
- PCI devices
PCI Local Bus
- pci_ereport_post() function
Detecting and Reporting PCI-Related Errors
- pci_ereport_setup() function
Detecting and Reporting PCI-Related Errors
Declaring Fault Management Capabilities
- pci_ereport_teardown() function
Detecting and Reporting PCI-Related Errors
Cleaning Up Fault Management Resources
- physical DMA
Types of Host Platform DMA
- physio() function
- description of
DMA Transfers (Synchronous)
- pipe
- alternate setting
Modifying or Getting the Alternate Setting
- pipes
- closing
Closing Pipes
- default control
The Default Pipe
Registering Drivers to Gain Device Access
- flushing
Flushing Pipes
- mutex initialization
Registering Drivers to Gain Device Access
- opening
Opening Pipes
- policy
Synchronous and Asynchronous Transfers and Callbacks
- USB device communication
Device Communication
- USB devices
How USB Devices Appear to the System
- use before attach()
Before the Client Driver Is Attached
- pixel depth mode
Oracle Solaris Consoles and the Kernel Terminal Emulator
- pm_busy_component() function
Active Power Management
Device Power Management
- pm_idle_component() function
Active Power Management
Device Power Management
- pm_lower_power() function
Active Power Management
- pm_raise_power() function
Active Power Management
Device Power Management
- polled I/O interfaces
Implementing Polled I/O in Console Frame Buffer Drivers
Polled I/O Interfaces
- postmortem debugging
Postmortem Debugging
- power cycle
Device Power State Transitions
- power management
- See Also
system power management - See Also
device power management
- flow of control
Power Management Flow of Control
- USB devices
Power Management
- power management functions
Power Management Functions- deprecated
Deprecated Power Management Functions
- power() entry point
Active Power Management
Device Power Management
- Predictive Self-Healing
What Is Predictive Self-Healing?- See Also
fault management
- prefix
- unique prefix for driver symbols
Use a Unique Prefix to Avoid Kernel Symbol Collisions
What Is a Device Driver Entry Point?
- print() entry point
- block drivers
print Entry Point (Block
Drivers)
- printing functions
Kernel Logging and Printing Functions
- printing messages
Returning Errors
- probe() entry point
- description of
probe Entry Point
- SCSI target drivers
probe Entry Point (SCSI
Target Drivers)
- processor issues
- SPARC
SPARC Multiply and Divide Instructions
SPARC Register Windows
SPARC Processor Issues
- x86
x86 Processor Issues
- programmed I/O
Programmed I/O Transfers
- programmed I/O functions
Programmed I/O Functions- deprecated
Deprecated Programmed I/O Functions
- PROM commands
Open Boot PROM 3
- prop_op() entry point
- description of
prop_op Entry Point
- properties
- class property
Hardware Configuration File
- ddi_prop_op
prop_op Entry Point
- device node name property
Binding a Driver to a Device
- LDI
Retrieving Target Device Property Values
- nblocks property
Device Sizes
- Nblocks property
Device Sizes
- nblocks property
Block Device Autoconfiguration
- Nblocks property
Block Device Autoconfiguration
- no-involuntary-power-cycles
Device Power State Transitions
- overview
Device Properties
Device Properties
- pm-hardware-state property
attach Entry Point (SCSI
Target Drivers)
attach Entry Point
Hardware State
- prtconf
Looking Up Properties
- reg property
Hardware State
- removable-media
Power Management Dependencies
- reporting device properties
prop_op Entry Point
- SCSI HBA properties
HBA Configuration Properties
- SCSI target driver
x86 Target Driver Configuration Properties
- size property
Character Device Autoconfiguration
- types of
Device Properties
- property functions
Property Functions
- prtconf command
- displaying device names
Compatible Device Names
- displaying interfaces
USB Audio Compatible Device Names
- displaying kernel device usage information
Print System Configuration Command Interfaces
- displaying properties
Looking Up Properties
- displaying the bound driver
USB Mouse Compatible Device Names
- displaying the device tree
prtconf Command
- pseudo device driver
What Is a Device Driver?
Q
- queuing
Support for Queuing
- quiesce a device
Example Implementation of Interrupt Resource Management
System Quiesce Entry Point
- quiesce() entry point
System Quiesce Entry Point
R
- read() entry point
- synchronous data transfers
Differences Between Synchronous and Asynchronous
I/O
- readers/writer locks
Readers/Writer Locks- manipulating
Kernel Thread Control and Synchronization
Functions
- real_length argument, ddi_dma_mem_alloc()
- changes to
ddi_dma_mem_alloc Argument
Changes
- recovering the device directory
Recovering the Device Directory
- reg property
Device Properties
- register structure, DMA
Device Register Structure
- removable-media
Power Management Dependencies
- resource map functions
Resource Map Management Functions
- resume a device
Example Implementation of Interrupt Resource Management
System Quiesce Entry Point
- retire agent
- definition
Response Agents
- rmallocmap() function
- changes to
rmallocmap and rmallocmap_wait Argument Changes
- rmallocmap_wait() function
- changes to
rmallocmap and rmallocmap_wait Argument Changes
S
- S_IFCHR
Creating Minor Device Nodes
- SAP (Service Access Point)
Ethernet V2 and ISO 8802-3 (IEEE 802.3)
- saving crash dumps
Capture System Crash Dumps
- SBus
- address bits
Physical SBus Addresses
- geographical addressing
SBus Architecture
- hardware configuration files
SBus Hardware Configuration Files
- physical address space
SBus Physical Address Space
- slots supporting DVMA
Ultra 2 SBus Address Bits
- scatter-gather
- DMA engines
DMA Software Components: Handles, Windows, and Cookies
- I/O
Vectored I/O
- scheduling tasks
Queueing Tasks
- SCSA
SCSI Interface
Introduction to Target Drivers
- global data definitions
SCSI Options
- HBA transport layer
SCSA Interface
- interfaces
SCSA HBA Entry Point Summary
- SCSI
- architecture
Sun Common SCSI Architecture Overview
- bus
Introduction to Target Drivers
- SCSI functions
SCSI Functions- deprecated
Deprecated SCSI Functions
- SCSI HBA driver
- abort and reset management
tran_abort Entry Point
- and hotplugging
Dynamic Reconfiguration
Hotplugging and Device Drivers
- autoconfiguration
Autoconfiguration Entry Points
- capability management
tran_getcap Entry Point
- cloning
Transport Structure Cloning
- command state structure
Per-Command Structure
- command timeout
Timeout Handler
- command transport
Command Transport
- configuration properties
HBA Configuration Properties
- data structures
SCSA HBA Data Structures
- DMA resources
Allocation of DMA Resources
- driver instance initialization
tran_tgt_init Entry Point
- entry points summary
SCSA HBA Entry Point Summary
- header files
Declarations and Structures
- initializing a transport structure
Transport Structure
- installation
SCSI HBA Driver Specific Issues
- interrupt handling
Interrupt Handler and Command Completion
- overview
SCSA Interface
SCSI Interface
- properties
x86 Target Driver Configuration Properties
- resource allocation
tran_init_pkt Entry Point
- SCSI HBA driver entry points
- by category
Entry Points for SCSA HBA Drivers
- tran_abort() function
tran_abort Entry Point
- tran_dmafree() function
tran_dmafree Entry Point
- tran_getcap() function
tran_getcap Entry Point
- tran_init_pkt() function
tran_init_pkt Entry Point
- tran_reset() function
tran_reset Entry Point
- tran_reset_notify() function
tran_reset_notify Entry
Point
- tran_setcap() function
tran_setcap Entry Point
- tran_start() function
tran_start Entry Point
- tran_sync_pkt() function
tran_sync_pkt Entry Point
- tran_tgt_free() function
tran_tgt_free Entry Point
- tran_tgt_init() function
tran_tgt_init Entry Point
- tran_tgt_probe() function
tran_tgt_probe Entry Point
- SCSI target driver
- auto-request sense mode
Auto-Request Sense Mode
- autoconfiguration of
Autoconfiguration for SCSI Target Drivers
- building a command
Building a Command
- callback routine
Command Completion
- data structures
Declarations and Data Structures
- initializing a command descriptor block
Building a Command
- overview
Introduction to Target Drivers
- properties
x86 Target Driver Configuration Properties
attach Entry Point (SCSI
Target Drivers)
Hardware Configuration File
- resource allocation
Resource Allocation
- reusing packets
Reuse of Packets
- SCSI routines
SCSA Functions
- transporting a command
Transporting a Command
- scsi_ structures
- scsi_address structure
scsi_address Structure
- scsi_device structure
scsi_device Structure
- scsi_hba_tran structure
scsi_hba_tran Structure
- scsi_pkt structure
scsi_pkt Structure (HBA)
- scsi_ functions
- scsi_alloc_consistent_buf()function
scsi_alloc_consistent_buf Function
- scsi_destroy_pkt() function
scsi_destroy_pkt Function
- scsi_dmafree() function
Reuse of Packets
- scsi_free_consistent_buf() function
scsi_free_consistent_buf Function
- scsi_ifgetcap() function
Setting Target Capabilities
- scsi_ifsetcap() function
Setting Target Capabilities
- scsi_init_pkt() function
scsi_init_pkt Function
- scsi_probe() function
tran_tgt_probe Entry Point
- scsi_setup_cdb() function
Building a Command
- scsi_sync_pkt() function
Reuse of Packets
scsi_sync_pkt Function
- scsi_transport() function
Transporting a Command
- scsi_unprobe() function
tran_tgt_probe Entry Point
- summary
SCSA Functions
- scsi_alloc_consistent_buf() function
- changes to
scsi_alloc_consistent_buf Argument
Changes
- scsi_device structure
scsi_device Structure
- scsi_hba_ functions
- scsi_hba_pkt_free() function
tran_destroy_pkt Entry
Point
- scsi_hba_ functions
- scsi_hba_attach_setup() function
HBA Configuration Properties
- scsi_hba_lookup_capstr() function
tran_getcap Entry Point
- scsi_hba_pkt_alloc() function
Allocation and Initialization of a scsi_pkt9S Structure
- scsi_hba_probe() function
tran_tgt_probe Entry Point
- summary list
SCSA HBA Functions
- scsi_hba_tran structures
- scsi_pkt structure
Per-Target Instance Data
- scsi_pkt structure
scsi_pkt Structure
(Target Drivers)- changes to
scsi_pkt Structure Changes
- segmap() entry point
- description of
Mapping Device Memory
The segmap(9E) Entry Point
- driver notification
Associating User Mappings With Driver Notifications
- self-identifying devices
Device Identification
- serial connection
Testing With a Serial Connection
- serviceability
- add new device
Driver Serviceability
- detect faulty device
Driver Serviceability
- perform periodic health checks
Driver Serviceability
- remove faulty device
Driver Serviceability
- report faults
Driver Serviceability
- single device node
USB Devices and the Oracle Solaris Device Tree
- size property
Character Device Autoconfiguration
- slice number for block devices
Block Device Autoconfiguration
- SNAP (Sub-Net Access Protocol)
TPR and FDDI: SNAP Processing
- snoop command
- network drivers
GLDv2 I/O Control Functions
- soft interrupts
Software Interrupts
- soft state information
- LDI
Driver Source File
- retrieving in mdb
Retrieving Driver Soft State Information
- USB
Registering Drivers to Gain Device Access
- software interrupts
- changing priority
Changing Soft Interrupt Priority
- software state functions
Device Software State Functions
- Solaris kernel See
kernel
- source compatibility
- description of
DDI/DKI Interfaces
- source files for device drivers
Source Files
- SPARC processor
- byte ordering
SPARC Byte Ordering
- data alignment
SPARC Data Alignment
- floating point operations
SPARC Processor Issues
- multiply and divide instructions
SPARC Multiply and Divide Instructions
- register windows
SPARC Register Windows
- structure member alignment
Member Alignment in SPARC Structures
- special files
- description of
Devices as Special Files
- src_advcnt argument, ddi_device_copy()
- changes to
ddi_device_copy Argument Changes
- standalone mode
Implementing Polled I/O in Console Frame Buffer Drivers
Console Visual I/O Interfaces
- state structure
Driver Source File
Driver Soft-State Management
Software State Management
- stats
- definition
Kernel Statistics
- Ethernet drivers
Kernel Statistics for Oracle Solaris Ethernet Drivers
- functions
Kernel Statistics Functions
- structure members
Kernel Statistics Structure Members
- structures
Kernel Statistics Structures
- storage classes
- driver data
Storage Classes of Driver Data
- store buffers
Store Buffers
- strategy() entry point
- block drivers
strategy Entry Point
- character drivers
strategy Entry Point
- streaming access
Using ddi_dma_mem_alloc(9F)
- STREAMS See
network drivers, GLDv2- cb_ops structure
cb_ops Structure
- drivers
Entry Points for STREAMS Device Drivers
- suspect list
- definition
Diagnosis, Suspect Lists, and Fault Events
- synchronous data transfers
- block drivers
Synchronous Data Transfers (Block Drivers)
- character drivers
Differences Between Synchronous and Asynchronous
I/O
- USB
Synchronous and Asynchronous Transfers and Callbacks
- system calls
What Is the Kernel?
- system global state functions
System Global State
- system power management
- description of
System Power Management
- entry points
Entry Points Used by System Power Management
- model
System Power Management Model
- policy
Automatic Power Management for Systems
- saving hardware state
Hardware State
- USB devices
System Power Management
- system registers
- reading and writing
Exploring System Registers With kmdb
T
- tagged queuing
Support for Queuing
- tape drivers
- testing
Testing Specific Types of Drivers
- task queues
Queueing Tasks- definition
Introduction to Task Queues
- interfaces
Task Queue Management Functions
Task Queue Interfaces
- tem (terminal emulator module)
x86 Platform Console Communication- See Also
kernel terminal emulator
- tem-support DDI property
SPARC Platform Console Communication
Oracle Solaris Consoles and the Kernel Terminal Emulator
- test modules
Setting Up Test Modules
- testing
- asynchronous communication drivers
Asynchronous Communication Drivers
- configurations
Configuration Testing
- console frame buffer drivers
Developing, Testing, and Debugging Console Frame
Buffer Drivers
- DDI compliance
DDI/DKI Compliance Testing
- device drivers
Criteria for Testing Drivers
- disk drivers
Testing Disk Drivers
- functionality
Functionality Testing
- installation and packaging
Installation and Packaging Testing
- network drivers
Testing Network Drivers
- tape drivers
Testing Tape Drivers
- testing debuggers
- avoiding data loss
Avoiding Data Loss on a Test System
- testing device drivers
Testing Drivers
- third-party DMA
Performing Third-Party DMA Transfers
Third-Party DMA
- thread synchronization
- condition variables
Condition Variables in Thread Synchronization
- mutex locks
Mutual-Exclusion Locks
- mutex_init
Setting Up Mutexes
- per instance mutex
attach Entry Point
attach Entry Point
- readers/writer locks
Readers/Writer Locks
- threads
- preemption of
Locking Primitives
- task queues
Queueing Tasks
- ticks argument, delay()
- changes to
delay and timeout Argument
Changes
- ticks argument, timeout()
- changes to
delay and timeout Argument
Changes
- time-related functions
Time-Related Functions- deprecated
Deprecated Time-Related Functions
- timeout() function
delay and timeout Argument
Changes- changes to
delay and timeout Argument
Changes
- timeout argument, cv_timedwait()
- changes to
cv_timedwait and cv_timedwait_sig Argument Changes
- tip connection
Testing With a Serial Connection
- total store ordering
Total Store Ordering (TSO)
- TPR (Token Passing Ring)
TPR and FDDI: SNAP Processing
- trace
- definition
trace for Dynamic Instrumentation
- tran_abort() entry point
- SCSI HBA drivers
tran_abort Entry Point
- tran_destroy_pkt() entry point
- SCSI HBA drivers
tran_destroy_pkt Entry
Point
- tran_dmafree() entry point
- SCSI HBA drivers
tran_dmafree Entry Point
- tran_getcap() entry point
- SCSI HBA drivers
tran_getcap Entry Point
- tran_init_pkt() entry point
- SCSI HBA drivers
tran_init_pkt Entry Point
- tran_reset() entry point
- SCSI HBA drivers
tran_reset Entry Point
- tran_reset_notify() entry point
- SCSI HBA drivers
tran_reset_notify Entry
Point
- tran_setcap() entry point
- SCSI HBA drivers
tran_setcap Entry Point
- tran_start() entry point
- SCSI HBA drivers
tran_start Entry Point
- tran_sync_pkt() entry point
- SCSI HBA drivers
tran_sync_pkt Entry Point
- tuning device drivers
Tuning Drivers- stats
Kernel Statistics
- trace
trace for Dynamic Instrumentation
U
- UHCI (Universal Host Controller Interface)
USB Client Drivers
- uiomove() example
Programmed I/O Transfers
- uiomove() function
- changes to
uiomove Argument Changes
- example of
Programmed I/O Transfers
- unloading drivers
Loading and Unloading Drivers
- unloading test modules
Loading and Unloading Test Modules
- untagged queuing
Support for Queuing
- update_drv command
Checking Device Driver Bindings
Change the Target Device
- description of
Updating Driver Information
- USB device
- alternate settings
How USB Devices Appear to the System
- compatible device names
Compatible Device Names
- composite
Managing Entire Devices
Devices With Multiple Interfaces
- configuration descriptors
The Descriptor Tree
- current configuration
How USB Devices Appear to the System
- endpoints
How USB Devices Appear to the System- bulk
USB Endpoints
- control
USB Endpoints
- default
The Default Pipe
- interrupt
USB Endpoints
- isochronous
USB Endpoints
- hotplugging
Hotplugging USB Devices- callbacks
Hotplug Callbacks
- insertion
Hot Insertion
- reinsertion
Hot Reinsertion
- removal
Hot Removal
- interface number
Getting Interface Numbers
- interfaces
How USB Devices Appear to the System
- multiple configurations
How USB Devices Appear to the System
- power management
Power Management- active
Active Power Management
- device
Device Power Management
- passive
Passive Power Management
- system
System Power Management
- remote wakeup
Device Power Management
- splitting interfaces
Multiple-Configuration Devices
USB Audio Compatible Device Names
- states
Device State Management
- USB drivers
USB Client Drivers- asynchronous transfer callbacks
Synchronous and Asynchronous Transfers and Callbacks
- bulk data transfer requests
Bulk Requests
- control data transfer requests
Control Requests
- data transfer
- callback status flags
Request Features and Fields
Synchronous and Asynchronous Transfers and Callbacks
- completion reasons
Request Features and Fields
Synchronous and Asynchronous Transfers and Callbacks
- data transfer requests
Request Structures
- descriptor tree
Registering Drivers to Gain Device Access
The Descriptor Tree
- event notification
Hotplug Callbacks
- hubd USB hub driver
Hot Insertion
- interfaces
USB Client Drivers
- interrupt data transfer requests
Interrupt Requests
- isochronous data transfer requests
Isochronous Requests
- message blocks
Request Features and Fields
- mutex initialization
Registering Drivers to Gain Device Access
- pipes
Device Communication
Registering Drivers to Gain Device Access
How USB Devices Appear to the System
- closing
Closing Pipes
- default control
The Default Pipe
Registering Drivers to Gain Device Access
Before the Client Driver Is Attached
- flushing
Flushing Pipes
- opening
Opening Pipes
- registering
Registering Drivers to Gain Device Access
- registering for events
Hotplug Callbacks
- set alternate
Modifying or Getting the Alternate Setting
- set configuration
Multiple-Configuration Devices
- synchronous control requests
Control Requests
- usb_ia USB interface association driver
Devices With Interface-Association Descriptors
- usb_mid USB multi-interface driver
Getting Interface Numbers
Hot Removal
Devices With Interface-Association Descriptors
Devices With Multiple Interfaces
- versioning
Registering Drivers to Gain Device Access
- USB functions
- cfgadm_usb command
Multiple-Configuration Devices
- usb_alloc_bulk_req() function
Request Initialization
- usb_alloc_ctrl_req() function
Request Initialization
- usb_alloc_intr_req() function
Request Initialization
- usb_alloc_isoc_req() function
Request Initialization
- usb_client_attach() function
Registering Drivers to Gain Device Access
- usb_client_detach() function
Registering Drivers to Gain Device Access
- usb_clr_feature() function
Clearing a USB Condition
- usb_create_pm_components() function
Active Power Management
Device Power Management
- usb_free_bulk_req() function
Request Initialization
- usb_free_ctrl_req() function
Request Initialization
- usb_free_descr_tree() function
Registering Drivers to Gain Device Access
- usb_free_dev_data() function
Registering Drivers to Gain Device Access
- usb_free_intr_req() function
Request Initialization
- usb_free_isoc_req() function
Request Initialization
- usb_get_addr() function
Getting the Bus Address of a Device
- usb_get_alt_if() function
Modifying or Getting the Alternate Setting
- usb_get_cfg() function
Multiple-Configuration Devices
- usb_get_current_frame_number() function
Isochronous Requests
- usb_get_dev_data() function
The Default Pipe
Registering Drivers to Gain Device Access
Registering Drivers to Gain Device Access
The Descriptor Tree
- usb_get_if_number() function
Getting Interface Numbers
- usb_get_max_pkts_per_isoc_request() function
Isochronous Requests
- usb_get_status() function
Getting Device, Interface, or Endpoint Status
- usb_get_string_descr() function
Retrieving a String Descriptor
- usb_handle_remote_wakeup() function
Active Power Management
Device Power Management
- usb_lookup_ep_data() function
Opening Pipes
A Hierarchical USB Descriptor Tree
- usb_owns_device() function
Managing Entire Devices
- usb_parse_data() function
The Descriptor Tree
- usb_pipe_bulk_xfer() function
Request Transfer Setup
Data Transfer
- usb_pipe_close() function
Isochronous Requests
Closing Pipes
- usb_pipe_ctrl_xfer() function
Request Transfer Setup
Data Transfer
- usb_pipe_ctrl_xfer_wait() function
Control Requests
Request Transfer Setup
- usb_pipe_drain_reqs() function
Flushing Pipes
- usb_pipe_get_max_bulk_transfer_ size() function
Bulk Requests
- usb_pipe_get_private() function
Pipe Private Data Facility
- usb_pipe_get_state() function
Flushing Pipes
Pipe States
- usb_pipe_intr_xfer() function
Interrupt Requests
Request Transfer Setup
Data Transfer
- usb_pipe_isoc_xfer() function
Request Transfer Setup
Data Transfer
- usb_pipe_open() function
Synchronous and Asynchronous Transfers and Callbacks
Opening Pipes
- usb_pipe_reset() function
Flushing Pipes
Pipe States
- usb_pipe_set_private() function
Pipe Private Data Facility
- usb_pipe_stop_intr_polling() function
Interrupt Requests
Request Transfer Setup
- usb_pipe_stop_isoc_polling() function
Isochronous Requests
Request Transfer Setup
- usb_print_descr_tree() function
Registering Drivers to Gain Device Access
- usb_register_hotplug_cbs() function
Hotplug Callbacks
- usb_set_alt_if() function
Modifying or Getting the Alternate Setting
- usb_set_cfg() function
Multiple-Configuration Devices
- usb_unregister_hotplug_cbs() function
Hotplug Callbacks
- USB structures
- usb_alloc_intr_request
Interrupt Requests
- usb_bulk_request
Bulk Requests
Request Initialization
- usb_callback_flags
Request Features and Fields
Synchronous and Asynchronous Transfers and Callbacks
- usb_completion_reason
Request Features and Fields
Synchronous and Asynchronous Transfers and Callbacks
- usb_ctrl_request
Control Requests
Request Initialization
- usb_intr_request
Request Initialization
- usb_isoc_request
Isochronous Requests
Request Initialization
- usb_request_attributes
Request Features and Fields
- USB 2.0 specification
USBA 2.0 Framework
- usb_ia USB interface association driver
Devices With Interface-Association Descriptors
- usb_mid USB multi-interface driver
Getting Interface Numbers
Hot Removal
Devices With Interface-Association Descriptors
Devices With Multiple Interfaces
- USBA (Solaris USB Architecture)
USB Drivers
- USBA 2.0 framework
USB Drivers
- user application kernel functions
- deprecated
Deprecated User Application Kernel and Device Access Functions
- table
User Application Kernel and Device Access
Functions
- user process event functions
User Process Event Functions
- user process information functions
User Process Information Functions- deprecated
Deprecated User Process Information
Functions
- user space access functions
User Space Access Functions- deprecated
Deprecated User Space Access Functions
- utility functions
- table
Utility Functions
V
- VGA text mode
x86 Platform Console Communication
Oracle Solaris Consoles and the Kernel Terminal Emulator
- vgatext module
x86 Platform Console Communication
- video mode
Frame Buffer Specific Configuration Module
Video Mode Change Callback Interface
Console Visual I/O Interfaces
SPARC Platform Console Communication
- virtual addresses
- description of
Virtual Memory
- virtual DMA
Types of Host Platform DMA
- virtual memory
- address spaces
Virtual Memory
- memory management unit (MMU)
Virtual Memory
- virtual memory functions
- deprecated
Deprecated Virtual Memory Functions
- table
Virtual Memory Functions
- visual I/O interfaces
Console Visual I/O Interfaces
- volatile keyword
Declaring a Variable Volatile
W
- windows, DMA
DMA Windows
- write() function
- synchronous data transfers
Differences Between Synchronous and Asynchronous
I/O
- user address example
User Addresses
X
- x86 processor
- byte ordering
x86 Byte Ordering
- data alignment
x86 Processor Issues
- floating point operations
x86 Processor Issues