2000-08-12 15:11:46 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* *
|
|
|
|
* ASPI Router Library *
|
|
|
|
* *
|
|
|
|
* This is a sample library which shows how to send SRB's to the *
|
|
|
|
* ASPI Router device driver. USE AT YOUR OWN RISK!! *
|
|
|
|
* *
|
|
|
|
* Version 1.01 - June 1997 *
|
|
|
|
* Daniel Dorau (woodst@cs.tu-berlin.de) *
|
|
|
|
* *
|
|
|
|
* Changes since 1.00: *
|
|
|
|
* abort(), AbortSRB added *
|
|
|
|
* *
|
|
|
|
***************************************************************************/
|
|
|
|
|
|
|
|
#pragma pack(1)
|
|
|
|
|
|
|
|
/* SRB command */
|
|
|
|
#define SRB_Inquiry 0x00
|
|
|
|
#define SRB_Device 0x01
|
|
|
|
#define SRB_Command 0x02
|
|
|
|
#define SRB_Abort 0x03
|
|
|
|
#define SRB_Reset 0x04
|
|
|
|
#define SRB_Param 0x05
|
|
|
|
|
|
|
|
/* SRB status */
|
|
|
|
#define SRB_Busy 0x00 /* SCSI request in progress */
|
|
|
|
#define SRB_Done 0x01 /* SCSI request completed without error */
|
|
|
|
#define SRB_Aborted 0x02 /* SCSI aborted by host */
|
|
|
|
#define SRB_BadAbort 0x03 /* Unable to abort SCSI request */
|
|
|
|
#define SRB_Error 0x04 /* SCSI request completed with error */
|
|
|
|
#define SRB_BusyPost 0x10 /* SCSI request in progress with POST - Nokia */
|
|
|
|
#define SRB_InvalidCmd 0x80 /* Invalid SCSI request */
|
|
|
|
#define SRB_InvalidHA 0x81 /* Invalid Hhost adapter number */
|
|
|
|
#define SRB_BadDevice 0x82 /* SCSI device not installed */
|
|
|
|
|
|
|
|
/* SRB flags */
|
|
|
|
#define SRB_Post 0x01 /* Post vector valid */
|
|
|
|
#define SRB_Link 0x02 /* Link vector valid */
|
|
|
|
#define SRB_SG 0x04 /* Nokia: scatter/gather */
|
|
|
|
/* S/G: n * (4 bytes length, 4 bytes addr) */
|
|
|
|
/* No of s/g items not limited by HA spec. */
|
|
|
|
#define SRB_NoCheck 0x00 /* determined by command, not checked */
|
|
|
|
#define SRB_Read 0x08 /* target to host, length checked */
|
|
|
|
#define SRB_Write 0x10 /* host to target, length checked */
|
|
|
|
#define SRB_NoTransfer 0x18 /* no data transfer */
|
|
|
|
#define SRB_DirMask 0x18 /* bit mask */
|
|
|
|
|
|
|
|
/* SRB host adapter status */
|
|
|
|
#define SRB_NoError 0x00 /* No host adapter detected error */
|
|
|
|
#define SRB_Timeout 0x11 /* Selection timeout */
|
|
|
|
#define SRB_DataLength 0x12 /* Data over/underrun */
|
|
|
|
#define SRB_BusFree 0x13 /* Unexpected bus free */
|
|
|
|
#define SRB_BusSequence 0x14 /* Target bus sequence failure */
|
|
|
|
|
|
|
|
/* SRB target status field */
|
|
|
|
#define SRB_NoStatus 0x00 /* No target status */
|
|
|
|
#define SRB_CheckStatus 0x02 /* Check status (sense data valid) */
|
|
|
|
#define SRB_LUN_Busy 0x08 /* Specified LUN is busy */
|
|
|
|
#define SRB_Reserved 0x18 /* Reservation conflict */
|
|
|
|
|
|
|
|
#define MaxCDBStatus 64 /* max size of CDB + status */
|
|
|
|
|
|
|
|
typedef struct SRB SRB;
|
|
|
|
struct SRB {
|
|
|
|
unsigned char cmd, /* 00 */
|
|
|
|
status, /* 01 */
|
|
|
|
ha_num, /* 02 */
|
|
|
|
flags; /* 03 */
|
|
|
|
unsigned long res_04_07; /* 04..07 */
|
|
|
|
union { /* 08 */
|
|
|
|
|
|
|
|
/* SRB_Inquiry */
|
|
|
|
struct {
|
|
|
|
unsigned char num_ha, /* 08 */
|
|
|
|
ha_target, /* 09 */
|
|
|
|
aspimgr_id[16], /* 0A..19 */
|
|
|
|
host_id[16], /* 1A..29 */
|
|
|
|
unique_id[16]; /* 2A..39 */
|
|
|
|
} inq;
|
|
|
|
|
|
|
|
/* SRB_Device */
|
|
|
|
struct {
|
|
|
|
unsigned char target, /* 08 */
|
|
|
|
lun, /* 09 */
|
|
|
|
devtype; /* 0A */
|
|
|
|
} dev;
|
|
|
|
|
|
|
|
/* SRB_Command */
|
|
|
|
struct {
|
|
|
|
unsigned char target, /* 08 */
|
|
|
|
lun; /* 09 */
|
|
|
|
unsigned long data_len; /* 0A..0D */
|
|
|
|
unsigned char sense_len; /* 0E */
|
|
|
|
void * _Seg16 data_ptr; /* 0F..12 */
|
|
|
|
void * _Seg16 link_ptr; /* 13..16 */
|
|
|
|
unsigned char cdb_len, /* 17 */
|
|
|
|
ha_status, /* 18 */
|
|
|
|
target_status; /* 19 */
|
|
|
|
void (* _Seg16 post) (SRB *); /* 1A..1D */
|
|
|
|
unsigned char res_1E_29[12]; /* 1E..29 */
|
|
|
|
unsigned char res_2A_3F[22]; /* 2A..3F */
|
|
|
|
unsigned char cdb_st[64]; /* 40..7F CDB+status */
|
|
|
|
unsigned char res_80_BF[64]; /* 80..BF */
|
|
|
|
} cmd;
|
|
|
|
|
|
|
|
/* SRB_Abort */
|
|
|
|
struct {
|
|
|
|
void * _Seg16 srb; /* 08..0B */
|
|
|
|
} abt;
|
|
|
|
|
|
|
|
/* SRB_Reset */
|
|
|
|
struct {
|
|
|
|
unsigned char target, /* 08 */
|
|
|
|
lun, /* 09 */
|
|
|
|
res_0A_17[14], /* 0A..17 */
|
|
|
|
ha_status, /* 18 */
|
|
|
|
target_status; /* 19 */
|
|
|
|
} res;
|
|
|
|
|
|
|
|
/* SRB_Param - unused by ASPI4OS2 */
|
|
|
|
struct {
|
|
|
|
unsigned char unique[16]; /* 08..17 */
|
|
|
|
} par;
|
|
|
|
|
|
|
|
} u;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/* SCSI sense codes */
|
|
|
|
/* Note! This list may not be complete. I did this compilation for use with tape drives.*/
|
|
|
|
|
|
|
|
#define Sense_Current 0x70; /* Current Error */
|
|
|
|
#define Sense_Deferred 0x71; /* Deferred Error */
|
|
|
|
#define Sense_Filemark 0x80; /* Filemark detected */
|
|
|
|
#define Sense_EOM 0x40; /* End of medium detected */
|
|
|
|
#define Sense_ILI 0x20; /* Incorrect length indicator */
|
|
|
|
|
|
|
|
/* Sense Keys */
|
|
|
|
|
|
|
|
#define SK_NoSense 0x00; /* No Sense */
|
|
|
|
#define SK_RcvrdErr 0x01; /* Recovered Error */
|
|
|
|
#define SK_NotReady 0x02; /* Not ready */
|
|
|
|
#define SK_MedErr 0x03; /* Medium Error */
|
|
|
|
#define SK_HWErr 0x04; /* Hardware Error */
|
|
|
|
#define SK_IllReq 0x05; /* Illegal Request */
|
|
|
|
#define SK_UnitAtt 0x06; /* Unit attention */
|
|
|
|
#define SK_DataProt 0x07: /* Data Protect */
|
|
|
|
#define SK_BlankChk 0x08: /* Blank Check */
|
|
|
|
#define SK_VndSpec 0x09; /* Vendor Specific */
|
|
|
|
#define SK_CopyAbort 0x0A; /* Copy Aborted */
|
|
|
|
#define SK_AbtdCmd 0x0B; /* Aborted Command */
|
|
|
|
#define SK_Equal 0x0C; /* Equal */
|
|
|
|
#define SK_VolOvfl 0x0D; /* Volume Overflow */
|
|
|
|
#define SK_MisComp 0x0E; /* Miscompare */
|
|
|
|
#define SK_Reserved 0x0F; /* Reserved */
|