diff options
author | mjacob <mjacob@cvs.openbsd.org> | 1999-04-04 01:33:14 +0000 |
---|---|---|
committer | mjacob <mjacob@cvs.openbsd.org> | 1999-04-04 01:33:14 +0000 |
commit | 4c9ffad11dfe0033f11d20d2ec8e7ebe9ef17c1c (patch) | |
tree | 89aa60cef74e33ce07aaea5eebdb9a1a0ebc9cf2 | |
parent | 7ca563acbff9c710a6bdeb48c49d94858e8dc6b6 (diff) |
Remove incorrect BIG_ENDIAN defines and substitute in the SBus only macros
that will SBusify an isp header or the lun/target portions of a request IOCB-
and have these only valid iff __sparc__ (no non-sparc SBus machine that *I*
know about).
-rw-r--r-- | sys/dev/ic/ispmbox.h | 171 |
1 files changed, 45 insertions, 126 deletions
diff --git a/sys/dev/ic/ispmbox.h b/sys/dev/ic/ispmbox.h index 99ec82a90db..ea3ee34299c 100644 --- a/sys/dev/ic/ispmbox.h +++ b/sys/dev/ic/ispmbox.h @@ -1,5 +1,5 @@ -/* $OpenBSD: ispmbox.h,v 1.4 1999/03/25 22:58:38 mjacob Exp $ */ -/* release_03_25_99 */ +/* $OpenBSD: ispmbox.h,v 1.5 1999/04/04 01:33:13 mjacob Exp $ */ +/* release_4_3_99 */ /* * Mailbox and Queue Entry Definitions for for Qlogic ISP SCSI adapters. * @@ -185,19 +185,34 @@ typedef struct { u_int32_t ds_count; } ispds_t; +#define _ISP_SWAP8(a, b) { \ + u_int8_t tmp; \ + tmp = a; \ + a = b; \ + b = tmp; \ +} + +/* + * These elements get swizzled around for SBus instances. + */ typedef struct { -#if BYTE_ORDER == BIG_ENDIAN - u_int8_t rqs_entry_count; - u_int8_t rqs_entry_type; - u_int8_t rqs_flags; - u_int8_t rqs_seqno; -#else u_int8_t rqs_entry_type; u_int8_t rqs_entry_count; u_int8_t rqs_seqno; u_int8_t rqs_flags; -#endif } isphdr_t; +/* + * There are no (for all intents and purposes) non-sparc SBus machines + */ +#ifdef __sparc__ +#define ISP_SBUSIFY_ISPHDR(isp, hdrp) \ + if ((isp)->isp_bustype == ISP_BT_SBUS) { \ + _ISP_SWAP8((hdrp)->rqs_entry_count, (hdrp)->rqs_entry_type); \ + _ISP_SWAP8((hdrp)->rqs_flags, (hdrp)->rqs_seqno); \ + } +#else +#define ISP_SBUSIFY_ISPHDR(a, b) +#endif /* RQS Flag definitions */ #define RQSFLAG_CONTINUATION 0x01 @@ -237,13 +252,8 @@ typedef struct { typedef struct { isphdr_t req_header; u_int32_t req_handle; -#if BYTE_ORDER == BIG_ENDIAN - u_int8_t req_target; - u_int8_t req_lun_trn; -#else u_int8_t req_lun_trn; u_int8_t req_target; -#endif u_int16_t req_cdblen; #define req_modifier req_cdblen /* marker packet */ u_int16_t req_flags; @@ -254,17 +264,31 @@ typedef struct { ispds_t req_dataseg[ISP_RQDSEG]; } ispreq_t; +/* + * A request packet can also be a marker packet. + */ +#define SYNC_DEVICE 0 +#define SYNC_TARGET 1 +#define SYNC_ALL 2 + +/* + * There are no (for all intents and purposes) non-sparc SBus machines + */ +#ifdef __sparc__ +#define ISP_SBUSIFY_ISPREQ(isp, rqp) \ + if ((isp)->isp_bustype == ISP_BT_SBUS) { \ + _ISP_SWAP8((rqp)->req_target, (rqp)->req_lun_trn); \ + } +#else +#define ISP_SBUSIFY_ISPREQ(a, b) +#endif + #define ISP_RQDSEG_T2 3 typedef struct { isphdr_t req_header; u_int32_t req_handle; -#if BYTE_ORDER == BIG_ENDIAN - u_int8_t req_target; - u_int8_t req_lun_trn; -#else u_int8_t req_lun_trn; u_int8_t req_target; -#endif u_int16_t req_scclun; u_int16_t req_flags; u_int16_t _res2; @@ -299,13 +323,8 @@ typedef struct { typedef struct { isphdr_t req_header; u_int32_t req_handle; -#if BYTE_ORDER == BIG_ENDIAN - u_int8_t req_target; - u_int8_t req_lun_trn; -#else u_int8_t req_lun_trn; u_int8_t req_target; -#endif u_int16_t req_cdblen; u_int16_t req_flags; u_int16_t _res1; @@ -323,26 +342,6 @@ typedef struct { typedef struct { isphdr_t req_header; - u_int32_t _res1; -#if BYTE_ORDER == BIG_ENDIAN - u_int8_t req_target; - u_int8_t req_lun_trn; - u_int8_t _res2; - u_int8_t req_modifier; -#else - u_int8_t req_lun_trn; - u_int8_t req_target; - u_int8_t req_modifier; - u_int8_t _res2; -#endif -} ispmarkreq_t; - -#define SYNC_DEVICE 0 -#define SYNC_TARGET 1 -#define SYNC_ALL 2 - -typedef struct { - isphdr_t req_header; u_int32_t req_handle; u_int16_t req_scsi_status; u_int16_t req_completion_status; @@ -439,33 +438,18 @@ typedef struct { * Version One format. */ typedef struct { -#if BYTE_ORDER == BIG_ENDIAN - u_int8_t _reserved0; - u_int8_t icb_version; -#else u_int8_t icb_version; u_int8_t _reserved0; -#endif u_int16_t icb_fwoptions; u_int16_t icb_maxfrmlen; u_int16_t icb_maxalloc; u_int16_t icb_execthrottle; -#if BYTE_ORDER == BIG_ENDIAN - u_int8_t icb_retry_delay; - u_int8_t icb_retry_count; -#else u_int8_t icb_retry_count; u_int8_t icb_retry_delay; -#endif u_int8_t icb_nodename[8]; u_int16_t icb_hardaddr; -#if BYTE_ORDER == BIG_ENDIAN - u_int8_t _reserved1; - u_int8_t icb_iqdevtype; -#else u_int8_t icb_iqdevtype; u_int8_t _reserved1; -#endif u_int8_t icb_portname[8]; u_int16_t icb_rqstout; u_int16_t icb_rspnsin; @@ -502,6 +486,7 @@ typedef struct { #define RQRSP_ADDR3247 2 #define RQRSP_ADDR4863 3 + #define ICB_NNM0 7 #define ICB_NNM1 6 #define ICB_NNM2 5 @@ -527,33 +512,17 @@ typedef struct { typedef struct { u_int16_t pdb_options; -#if BYTE_ORDER == BIG_ENDIAN - u_int8_t pdb_sstate; - u_int8_t pdb_mstate; -#else u_int8_t pdb_mstate; u_int8_t pdb_sstate; -#endif -#if BYTE_ORDER == BIG_ENDIAN -#define BITS2WORD(x) \ - (x)[1] << 16 | (x)[2] << 8 | (x)[3] -#else -#define BITS2WORD(x) \ - (x)[0] << 16 | (x)[3] << 8 | (x)[2] -#endif +#define BITS2WORD(x) (x)[0] << 16 | (x)[3] << 8 | (x)[2] u_int8_t pdb_hardaddr_bits[4]; u_int8_t pdb_portid_bits[4]; u_int8_t pdb_nodename[8]; u_int8_t pdb_portname[8]; u_int16_t pdb_execthrottle; u_int16_t pdb_exec_count; -#if BYTE_ORDER == BIG_ENDIAN - u_int8_t pdb_retry_delay; - u_int8_t pdb_retry_count; -#else u_int8_t pdb_retry_count; u_int8_t pdb_retry_delay; -#endif u_int16_t pdb_resalloc; u_int16_t pdb_curalloc; u_int16_t pdb_qhead; @@ -563,13 +532,8 @@ typedef struct { u_int16_t pdb_features; /* PLOGI, Common Service */ u_int16_t pdb_pconcurrnt; /* PLOGI, Common Service */ u_int16_t pdb_roi; /* PLOGI, Common Service */ -#if BYTE_ORDER == BIG_ENDIAN - u_int8_t pdb_initiator; /* PLOGI, Class 3 Control Flags */ - u_int8_t pdb_target; -#else u_int8_t pdb_target; u_int8_t pdb_initiator; /* PLOGI, Class 3 Control Flags */ -#endif u_int16_t pdb_rdsiz; /* PLOGI, Class 3 */ u_int16_t pdb_ncseq; /* PLOGI, Class 3 */ u_int16_t pdb_noseq; /* PLOGI, Class 3 */ @@ -624,23 +588,17 @@ typedef struct { typedef struct { isphdr_t le_header; u_int32_t le_reserved2; -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t le_lun; u_int8_t le_rsvd; u_int8_t le_ops; /* Modify LUN only */ u_int8_t le_tgt; /* Not for FC */ -#endif u_int32_t le_flags; /* Not for FC */ -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t le_status; u_int8_t le_rsvd2; u_int8_t le_cmd_count; u_int8_t le_in_count; u_int8_t le_cdb6len; /* Not for FC */ u_int8_t le_cdb7len; /* Not for FC */ -#endif u_int16_t le_timeout; u_int16_t le_reserved[20]; } lun_entry_t; @@ -676,21 +634,15 @@ typedef struct { typedef struct { isphdr_t in_header; u_int32_t in_reserved2; -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t in_lun; /* lun */ u_int8_t in_iid; /* initiator */ u_int8_t in_rsvd; u_int8_t in_tgt; /* target */ -#endif u_int32_t in_flags; -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t in_status; u_int8_t in_rsvd2; u_int8_t in_tag_val; /* tag value */ u_int8_t in_tag_type; /* tag type */ -#endif u_int16_t in_seqid; /* sequence id */ u_int8_t in_msg[IN_MSGLEN]; /* SCSI message bytes */ u_int16_t in_reserved[IN_RSVDLEN]; @@ -700,11 +652,8 @@ typedef struct { typedef struct { isphdr_t in_header; u_int32_t in_reserved2; -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t in_lun; /* lun */ u_int8_t in_iid; /* initiator */ -#endif u_int16_t in_rsvd; u_int32_t in_rsvd2; u_int16_t in_status; @@ -729,19 +678,13 @@ typedef struct { typedef struct { isphdr_t na_header; u_int32_t na_reserved2; -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t na_lun; /* lun */ u_int8_t na_iid; /* initiator */ u_int8_t na_rsvd; u_int8_t na_tgt; /* target */ -#endif u_int32_t na_flags; -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t na_status; u_int8_t na_event; -#endif u_int16_t na_seqid; /* sequence id */ u_int16_t na_reserved[NA_RSVDLEN]; } na_entry_t; @@ -755,11 +698,8 @@ typedef struct { typedef struct { isphdr_t na_header; u_int32_t na_reserved2; -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t na_lun; /* lun */ u_int8_t na_iid; /* initiator */ -#endif u_int16_t na_rsvd; u_int16_t na_flags; u_int16_t na_rsvd2; @@ -782,21 +722,15 @@ typedef struct { typedef struct { isphdr_t at_header; u_int32_t at_reserved2; -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t at_lun; /* lun */ u_int8_t at_iid; /* initiator */ u_int8_t at_cdblen; /* cdb length */ u_int8_t at_tgt; /* target */ -#endif u_int32_t at_flags; -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t at_status; /* firmware status */ u_int8_t at_scsi_status; /* scsi status */ u_int8_t at_tag_val; /* tag value */ u_int8_t at_tag_type; /* tag type */ -#endif u_int8_t at_cdb[ATIO_CDBLEN]; /* received CDB */ u_int8_t at_sense[SUGGSENSELEN]; /* suggested sense data */ } at_entry_t; @@ -824,21 +758,15 @@ typedef struct { typedef struct { isphdr_t at_header; u_int32_t at_reserved2; -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t at_lun; /* lun */ u_int8_t at_iid; /* initiator */ -#endif u_int16_t at_rxid; /* response ID */ u_int16_t at_flags; u_int16_t at_status; /* firmware status */ -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t at_reserved1; u_int8_t at_taskcodes; u_int8_t at_taskflags; u_int8_t at_execodes; -#endif u_int8_t at_cdb[ATIO2_CDBLEN]; /* received CDB */ u_int32_t at_datalen; /* allocated data len */ u_int16_t at_scclun; @@ -870,21 +798,15 @@ typedef struct { typedef struct { isphdr_t ct_header; u_int32_t ct_reserved; -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t ct_lun; /* lun */ u_int8_t ct_iid; /* initiator id */ u_int8_t ct_rsvd; u_int8_t ct_tgt; /* our target id */ -#endif u_int32_t ct_flags; -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t ct_status; /* isp status */ u_int8_t ct_scsi_status; /* scsi status */ u_int8_t ct_tag_val; /* tag value */ u_int8_t ct_tag_type; /* tag type */ -#endif u_int32_t ct_xfrlen; /* transfer length */ u_int32_t ct_resid; /* residual length */ u_int16_t ct_timeout; @@ -946,11 +868,8 @@ typedef struct { typedef struct { isphdr_t ct_header; u_int32_t ct_reserved; -#if BYTE_ORDER == BIG_ENDIAN -#else u_int8_t ct_lun; /* lun */ u_int8_t ct_iid; /* initiator id */ -#endif u_int16_t ct_rxid; /* response ID */ u_int16_t ct_flags; u_int16_t ct_status; /* isp status */ |