Files
Arquivotheca.SunOS-4.1.4/sys/scsi/generic/message.h
seta75D ff309bfe1c Init
2021-10-11 18:37:13 -03:00

142 lines
3.3 KiB
C

#ident "@(#)message.h 1.1 94/10/31 SMI"
/*
* Copyright (c) 1988, 1989, 1990 Sun Microsystems, Inc.
*/
#ifndef _scsi_generic_message_h
#define scsi_generic_message_h
/*
* Defined Messages For SCSI.
*
* The following defines are derived from
* the proposed SCSI-2 specification,
* revision 8 (3/16/89).
*/
/*
* The proposed SCSI-2 specification defines
* message codes 0x00, 0x02-0x1F, as fixed
* single byte messages, 0x01 as indicating
* extended (multi-byte) messages, 0x20-0x2F
* as fixed two byte messages, and 0x80-0xFF
* as IDENTIFY messages.
*/
#define MSG_COMMAND_COMPLETE 0x00
#define MSG_SAVE_DATA_PTR 0x02
#define MSG_RESTORE_PTRS 0x03
#define MSG_DISCONNECT 0x04
#define MSG_INITIATOR_ERROR 0x05
#define MSG_ABORT 0x06
#define MSG_REJECT 0x07
#define MSG_NOP 0x08
#define MSG_MSG_PARITY 0x09
#define MSG_LINK_CMPLT 0x0A
#define MSG_LINK_CMPLT_FLAG 0x0B
#define MSG_DEVICE_RESET 0x0C
#define MSG_ABORT_TAG 0x0D
#define MSG_CLEAR_QUEUE 0x0E
#define MSG_INITIATE_RECOVERY 0x0F
#define MSG_RELEASE_RECOVERY 0x10
#define MSG_TERMINATE_PROCESS 0x11
/*
* Codes 0x12-0x1F reserved
*/
/*
* Message code 0x01 indicates an extended
* (two or more) byte message. The EXTENDED
* message byte is followed immediately by
* a message length byte and then an extended
* message code byte.
*
* Note: The EXTENDED IDENTIFY message has been
* dropped from SCSI in the proposed level 2 spec.
*
* Extended Message Codes 0x04-0x7F are reserved.
* Extended Messaqe Codes 0x80-0xFF are vendor unique.
*
*/
#define MSG_EXTENDED 0x01
# define MSG_MODIFY_DATA_PTR 0x00
# define MSG_SYNCHRONOUS 0x01
# define MSG_IDENTIFY_EXTENDED 0x02
# define MSG_WIDE_DATA_XFER 0x03
/*
* Message codes 0x20-0x2F are fixed two byte messages.
* Codes 0x24-0x2F are currently reserved.
*/
#define MSG_SIMPLE_QTAG 0x20
#define MSG_HEAD_QTAG 0x21
#define MSG_ORDERED_QTAG 0x22
#define MSG_IGNORE_WIDE_RESID 0x23
/*
* Codes 0x80-0xFF are identify messages, indicated
* by the setting of the most significant bit in the
* message (0x80).
*/
#define MSG_IDENTIFY 0x80
/*
* Initiators will set bit 6 in an Identify message
* to indicate whether or not they can accommodate
* disconnect/reconnect
*/
#define INI_CAN_DISCON 0x40
/*
* ..so we can have a compound definition
* for Initiators that can accommodate
* disconnect/reconnect
*/
#define MSG_DR_IDENTIFY (MSG_IDENTIFY|INI_CAN_DISCON)
/*
* Bit 5 of the identify message specifies that, if zero,
* that the IDENTIFY message is directed to a logical unit,
* and if one, that the IDENTIFY message is directed to a
* target routine that does not involve a logical unit.
*/
#define MSG_LUNTAR 0x20
/*
* Bits 2-0 identify either the logical unit or the target
* routine number based upon whether MSG_LUNTAR is clear
* or set.
*/
#define MSG_LUNRTN 0x07
/*
* Bits 4-3 are reserved and must be zero.
*/
#define BAD_IDENTIFY 0x18
/*
* These macros may be useful to quickly determine the
* length of a message based upon the message code.
*/
#define IS_IDENTIFY_MSG(msg) \
(((msg) & MSG_IDENTIFY) && !((msg) & BAD_IDENTIFY))
#define IS_EXTENDED_MSG(msg) ((msg) == MSG_EXTENDED)
#define IS_2BYTE_MSG(msg) (((msg) & 0xF0) == 0x20)
#define IS_1BYTE_MSG(msg) (!(IS_EXTENDED_MSG((msg))) && \
((((msg) & 0xF0) == 0) || IS_IDENTIFY_MSG((msg))))
#endif _scsi_generic_message_h