⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 message.h

📁 操作系统SunOS 4.1.3版本的源码
💻 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 + -