📄 message.h
字号:
#ident "@(#)message.h 1.1 92/07/30 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
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -