SCSI_HBA_TRAN(9S) Data Structures for Drivers SCSI_HBA_TRAN(9S)
NAME
scsi_hba_tran - SCSI Host Bus Adapter (HBA) driver transport vector
structure
SYNOPSIS
#include <sys/scsi/scsi.h>
INTERFACE LEVEL
illumos architecture specific (illumos DDI).
DESCRIPTION
A
scsi_hba_tran_t structure defines vectors that an
HBA driver
exports to
SCSA interfaces so that
HBA specific functions can be
executed.
STRUCTURE MEMBERS
dev_info_t *tran_hba_dip; /* HBAs dev_info
pointer */
void *tran_hba_private; /* HBA softstate */
void *tran_tgt_private; /* HBA target private
pointer */
struct scsi_device *tran_sd; /* scsi_device */
int (*tran_tgt_init)( ); /* Transport target */
Initialization */
int (*tran_tgt_probe)( ); /* Transport target
probe */
void (*tran_tgt_free)( ); /* Transport target
free */
int (*tran_start)( ); /* Transport start */
int (*tran_reset)( ); /* Transport reset */
int (*tran_abort)( ); /* Transport abort */
int (*tran_getcap)( ); /* Capability
retrieval */
int (*tran_setcap)( ); /* Capability
establishment */
struct scsi_pkt *(*tran_init_pkt)( ); /* Packet and DMA
allocation */
void (*tran_destroy_pkt)( ); /* Packet and DMA */
deallocation */
void (*tran_dmafree)( ); /* DMA deallocation */
void (*tran_sync_pkt)( ); /* Sync DMA */
void (*tran_reset_notify)( );/* Bus reset
notification */
int (*tran_bus_reset)( ); /* Reset bus only */
int (*tran_quiesce)( ); /* Quiesce a bus */
int (*tran_unquiesce)( ); /* Unquiesce a bus */
int (*tran_setup_pkt)( ); /* Initialization
for pkt */
int (*tran_teardown_pkt)( );/* Deallocation */
int (*tran_pkt_constructor) ( );
/* Constructor */
int (*tran_pkt_destructor) ( );
/* Destructor */
int tran_hba_len; /* # bytes for
pkt_ha_private */
int tran_interconnect_type; /* transport
interconnect */
tran_hba_dip dev_info pointer to the
HBA that supplies
the
scsi_hba_tran structure.
tran_hba_private Private pointer that the
HBA driver can use
to refer to the device's soft state
structure.
tran_tgt_private Private pointer that the
HBA can use to
refer to per-target specific data. This
field can only be used when the
SCSI_HBA_TRAN_CLONE flag is specified in
scsi_hba_attach(9F). In this case, the
HBA driver must initialize this field in its
tran_tgt_init(9E) entry point.
tran_sd Pointer to
scsi_device(9S) structure if
cloning; otherwise
NULL.
tran_tgt_init Function entry that allows per-target
HBA initialization, if necessary.
tran_tgt_probe Function entry that allows per-target
scsi_probe(9F) customization, if necessary.
tran_tgt_free Function entry that allows per-target
HBA deallocation, if necessary.
tran_start Function entry that starts a
SCSI command
execution on the
HBA hardware.
tran_reset Function entry that resets a
SCSI bus or
target device.
tran_abort Function entry that aborts one
SCSI command, or all pending
SCSI commands.
tran_getcap Function entry that retrieves a
SCSI capability.
tran_setcap Function entry that sets a
SCSI capability.
tran_init_pkt Function entry that allocates a
scsi_pkt structure.
tran_destroy_pkt Function entry that frees a
scsi_pkt structure allocated by
tran_init_pkt.
tran_dmafree Function entry that frees
DMA resources
that were previously allocated by
tran_init_pkt. Not called for
HBA drivers
that provide a
tran_setup_pkt entry point.
tran_sync_pkt Synchronizes data in
pkt after a data
transfer has been completed. Not called for
HBA drivers that provide a
tran_setup_pkt entry point.
tran_reset_notify Function entry that allows a target to
register a bus reset notification request
with the
HBA driver.
tran_bus_reset Function entry that resets the
SCSI bus
without resetting targets.
tran_quiesce Function entry that waits for all
outstanding commands to complete and blocks
(or queues) any
I/O requests issued.
tran_unquiesce Function entry that allows
I/O activities
to resume on the
SCSI bus.
tran_setup_pkt Optional entry point that initializes a
scsi_pkt structure. See
tran_setup_pkt(9E).
tran_teardown_pkt Entry point that releases resources
allocated by
tran_setup_pkt.
tran_pkt_constructor Additional optional entry point that
performs the actions of a constructor. See
tran_setup_pkt(9E).
tran_pkt_destructor Additional optional entry point that
performs the actions of a destructor. See
tran_setup_pkt(9E).
tran_hba_len Size of
pkt_ha_private. See
tran_setup_pkt(9E).
tran_interconnect_type Integer value that denotes the interconnect
type of the transport as defined in the
services.h header file.
SEE ALSO
tran_abort(9E),
tran_bus_reset(9E),
tran_destroy_pkt(9E),
tran_dmafree(9E),
tran_getcap(9E),
tran_init_pkt(9E),
tran_quiesce(9E),
tran_reset(9E),
tran_reset_notify(9E),
tran_setcap(9E),
tran_setup_pkt(9E),
tran_start(9E),
tran_sync_pkt(9E),
tran_tgt_free(9E),
tran_tgt_init(9E),
tran_tgt_probe(9E),
tran_unquiesce(9E),
ddi_dma_sync(9F),
scsi_hba_attach(9F),
scsi_hba_pkt_alloc(9F),
scsi_hba_pkt_free(9F),
scsi_probe(9F),
scsi_device(9S),
scsi_pkt(9S) Writing Device Drivers May 30, 2006 SCSI_HBA_TRAN(9S)