亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? scsiseqlib.c

?? VxWorks操作系統(tǒng)內(nèi)核源代碼
?? C
?? 第 1 頁 / 共 4 頁
字號:
/* scsiSeqLib.c - SCSI sequential access device library (SCSI-2) *//* Copyright 1989-1994 Wind River Systems, Inc. */#include "copyright_wrs.h"/*modification history--------------------02k,21feb99,jdi  doc: listed errnos.02j,09jul97,dgp  doc: correct fonts per SPR 785302i,06mar97,dds  SPR 8120: fixed scsiRdTape to return the actual number of                 bytes or blocks read, 0 if end of file, or ERROR.02h,29oct96,dgp  doc: editing for newly published SCSI libraries02g,16sep96,dds  removed compiler warnings.02f,23jul96,dds  SPR 6718: added support for tranfers above 16 MB.02e,06may96,jds  more doc tweaks02d,01may96,jds  doc tweaks02c,20sep95,jds  changed scsiStatusCheck to scsiSeqStatusCheck and made it		 global02b,26jul95,jds  maxVarBlockLimit to be set by scsiPhysDevCreate (Wrt & Rd) 02a,10may95,jds  reworked for use with enhanced SCSI-2 library; added tagType,		 and priority ; removed the idea of retrying command upon		 UNIT_ATTENTION which should be managed by higher level layer.01e,28jun94,ccc  doc tweaks.01d,21jun94,ccc  changed dataAddress from NONE to NULL.01c,27apr94,jdi	 doc tweaks.01b,20apr94,jds	 enhanced scsiWrtTape and scsiRdTape to correctly handle fixed		 block transfers and variable block transfers with maxBlockLimit01a,24jan94,ccc  created to support sequential access SCSI devices.*//*DESCRIPTIONThis library contains commands common to all sequential-access SCSI devices.Sequential-access SCSI devices are usually SCSI tape devices.These routines are separated from scsi2Lib in order to create an additionallayer for better support of all SCSI sequential devices.SCSI commands in this library include:.TStab(|);lf3 lf3l l.Command			| Op Code_ERASE			| (0x19)MODE SELECT (6)		| (0x15)MODE_SENSE (6)		| (0x1a)READ (6)		| (0x08)READ BLOCK LIMITS	| (0x05)RELEASE UNIT		| (0x17)RESERVE UNIT		| (0x16)REWIND			| (0x01)SPACE			| (0x11)WRITE (6)		| (0x0a)WRITE FILEMARKS		| (0x10)LOAD/UNLOAD		| (0x1b).TEThe SCSI routines implemented here operate mostly on a SCSI_SEQ_DEVstructure.  This structure acts as an interface between this libraryand a higher-level layer.  The SEQ_DEV structure is analogous to theBLK_DEV structure for block devices.  The scsiSeqDevCreate() routine creates a SCSI_SEQ_DEV structure whose first element is a SEQ_DEV, operated upon by higher layers.  This routine publishesall functions to be invoked byhigher layers and maintains some state information (for example, block size)for tracking SCSI-sequential-device information.INCLUDE FILESscsiLib.h, scsi2Lib.hSEE ALSO: tapeFsLib, scsi2Lib,.pG "I/O System, Local File Systems"*/#define  INCLUDE_SCSI2#include "vxWorks.h"#include "ioLib.h"#include "ctype.h"#include "stdlib.h"#include "errnoLib.h"#include "taskLib.h"#include "logLib.h"#include "string.h"#include "stdio.h"#include "scsiLib.h"#include "sysLib.h"#define MODE_BUF_LENGTH 	  0xff#define SCSI_MAX_XFER_BLOCKS  0xffffff#define SCSI_READ             0x00#define SCSI_WRITE            0x01/* globals */IMPORT BOOL scsiDebug;			/* enable task level debug messages */IMPORT BOOL scsiIntsDebug;		/* enable int level debug messages *//* select timeout to use when creating a SCSI_PHYS_DEV */IMPORT UINT32 scsiSelectTimeout;IMPORT SCSI_CTRL *pSysScsiCtrl;		/* ptr to default SCSI_CTRL struct */LOCAL VOID scsiXactionFill (SCSI_TRANSACTION *, SCSI_COMMAND, BOOL, int, UINT,			    int, UINT8 *);LOCAL VOID scsiCmdFill (SCSI_SEQ_DEV *, SCSI_COMMAND , BOOL, BOOL, int);LOCAL int scsiRdTapeFixedBlocks (SCSI_SEQ_DEV *, UINT, char * );LOCAL int scsiRdTapeVariableBlocks (SCSI_SEQ_DEV *, UINT, char * );LOCAL int scsiCalcDataRead (SCSI_SEQ_DEV *, UINT);/********************************************************************************* scsiSeqDevCreate - create a SCSI sequential device** This routine creates a SCSI sequential device and saves a pointer to this* SEQ_DEV in the SCSI physical device. The following functions are* initialized in this structure:** .TS* tab(|);* l l.* sd_seqRd           | -  scsiRdTape()* sd_seqWrt          | -  scsiWrtTape()* sd_ioctl           | -  scsiIoctl() (in scsiLib)* sd_seqWrtFileMarks | -  scsiWrtFileMarks()* sd_statusChk       | -  scsiSeqStatusCheck()* sd_reset           | -  (not used)* sd_rewind          | -  scsiRewind()* sd_reserve         | -  scsiReserve()* sd_release         | -  scsiRelease()* sd_readBlkLim      | -  scsiSeqReadBlockLimits()* sd_load            | -  scsiLoadUnit()* sd_space           | -  scsiSpace()* sd_erase           | -  scsiErase()* .TE** Only one SEQ_DEV per SCSI_PHYS_DEV is allowed, unlike BLK_DEVs where an * entire list is maintained. Therefore, this routine can be called only * once per creation of a sequential device.** RETURNS: A pointer to the SEQ_DEV structure, or NULL if the command fails. * */SEQ_DEV *scsiSeqDevCreate    (    SCSI_PHYS_DEV *pScsiPhysDev  /* ptr to SCSI physical device info */    )    {    SCSI_SEQ_DEV      *pScsiSeqDev;     /* ptr to SCSI sequential dev struct */    /* check parameter for validity */    if (pScsiPhysDev == NULL)	{	errnoSet (S_scsiLib_ILLEGAL_PARAMETER);	SCSI_DEBUG_MSG ("scsiSeqDevCreate: Invalid input parameter(s).\n",				0, 0, 0, 0, 0, 0);	return ((SEQ_DEV *) NULL);	}    /* Check if sequential device alread exists */    if (pScsiPhysDev->pScsiSeqDev != NULL)	{        errnoSet (S_scsiLib_ILLEGAL_OPERATION);        SCSI_DEBUG_MSG ("scsiSeqDevCreate: SEQ_DEV already exists.\n", 							0, 0, 0, 0, 0, 0);        return ((SEQ_DEV *) NULL);        }    /* return NULL if not a sequential access device */    if (pScsiPhysDev->scsiDevType != SCSI_DEV_SEQ_ACCESS)        {        errnoSet (S_scsiLib_ILLEGAL_OPERATION);        SCSI_DEBUG_MSG ("scsiSeqDevCreate:", 0, 0, 0, 0, 0, 0);        SCSI_DEBUG_MSG ("Physical device is not a sequential device.\n",                        0, 0, 0, 0, 0, 0);        return ((SEQ_DEV *) NULL);        }    if (!pScsiPhysDev->removable)        SCSI_DEBUG_MSG ("scsiSeqDevCreate: Odd! Non removable tape!!\n",						0, 0, 0, 0, 0, 0);    pScsiSeqDev = (SCSI_SEQ_DEV *) calloc (1, sizeof (SCSI_SEQ_DEV));    if (pScsiSeqDev == NULL)	return ((SEQ_DEV *) NULL);    pScsiSeqDev->seqDev.sd_seqRd           = (FUNCPTR) scsiRdTape;    pScsiSeqDev->seqDev.sd_seqWrt          = (FUNCPTR) scsiWrtTape;    pScsiSeqDev->seqDev.sd_ioctl           = (FUNCPTR) scsiIoctl;    pScsiSeqDev->seqDev.sd_seqWrtFileMarks = (FUNCPTR) scsiWrtFileMarks;    pScsiSeqDev->seqDev.sd_rewind 	   = (FUNCPTR) scsiRewind;    pScsiSeqDev->seqDev.sd_reserve 	   = (FUNCPTR) scsiReserveUnit;    pScsiSeqDev->seqDev.sd_release 	   = (FUNCPTR) scsiReleaseUnit;    pScsiSeqDev->seqDev.sd_readBlkLim	   = (FUNCPTR) scsiSeqReadBlockLimits;    pScsiSeqDev->seqDev.sd_load 	   = (FUNCPTR) scsiLoadUnit;    pScsiSeqDev->seqDev.sd_space 	   = (FUNCPTR) scsiSpace;    pScsiSeqDev->seqDev.sd_erase 	   = (FUNCPTR) scsiErase;    pScsiSeqDev->seqDev.sd_statusChk       = (FUNCPTR) scsiSeqStatusCheck;    pScsiSeqDev->seqDev.sd_reset           = (FUNCPTR) NULL;    pScsiSeqDev->seqDev.sd_readyChanged    = TRUE;    pScsiSeqDev->pScsiPhysDev = pScsiPhysDev;    pScsiPhysDev->pScsiSeqDev = pScsiSeqDev;    /* Note: sd_blkSize and sd_mode are left uninitialized */    /* this should be the same as returning (SEQ_DEV *) pScsiSeqDev ?? */    return (&pScsiSeqDev->seqDev);    }    /********************************************************************************* scsiErase - issue an ERASE command to a SCSI device** This routine issues an ERASE command to a specified SCSI device.** RETURNS: OK, or ERROR if the command fails.*/STATUS scsiErase    (    SCSI_PHYS_DEV *pScsiPhysDev,	/* ptr to SCSI physical device */    BOOL longErase			/* TRUE for entire tape erase  */    )    {    SCSI_COMMAND eraseCommand;		/* SCSI command byte array */    SCSI_TRANSACTION scsiXaction;	/* info on a SCSI transaction */    STATUS status;			/* status of transaction */    SCSI_DEBUG_MSG ("scsiErase:\n", 0, 0, 0, 0, 0, 0);    /*     * Build the SCSI command. Do not use scsiCmdBuild, because that function     * is used only for direct access commands.     */    eraseCommand[0] = SCSI_OPCODE_ERASE;    eraseCommand[1] = (UINT8) ((pScsiPhysDev->scsiDevLUN & 0x7) << 5);    if (longErase)	eraseCommand [1] |= 0x01;	/* set long bit */    eraseCommand[2] = (UINT8) 0;    eraseCommand[3] = (UINT8) 0;    eraseCommand[4] = (UINT8) 0;    eraseCommand[5] = (UINT8) 0;    scsiXaction.cmdAddress    = eraseCommand;    scsiXaction.cmdLength     = SCSI_GROUP_0_CMD_LENGTH;    scsiXaction.dataAddress   = (UINT8 *) NULL;    scsiXaction.dataDirection = O_WRONLY;    scsiXaction.dataLength    = 0;    scsiXaction.addLengthByte = NULL;    scsiXaction.cmdTimeout    = SCSI_TIMEOUT_FULL;    scsiXaction.tagType       = SCSI_TAG_DEFAULT;    scsiXaction.priority      = SCSI_THREAD_TASK_PRIORITY;    status = (*pScsiPhysDev->pScsiCtrl->scsiTransact)	      (pScsiPhysDev, &scsiXaction);    return (status);    }/********************************************************************************* scsiTapeModeSelect - issue a MODE_SELECT command to a SCSI tape device** This routine issues a MODE_SELECT command to a specified SCSI device.** RETURNS: OK, or ERROR if the command fails.*/STATUS scsiTapeModeSelect    (    SCSI_PHYS_DEV *pScsiPhysDev,/* ptr to SCSI physical device            */    int pageFormat,             /* value of the page format bit (0-1)     */    int saveParams,             /* value of the save parameters bit (0-1) */    char *buffer,               /* ptr to output data buffer              */    int bufLength               /* length of buffer in bytes              */    )    {    SCSI_COMMAND scsiCommand;		/* SCSI command byte array */    SCSI_TRANSACTION scsiXaction;	/* info on a SCSI transaction */    STATUS status;			/* status of transaction */    SCSI_DEBUG_MSG ("scsiTapeModeSelect:\n", 0, 0, 0, 0, 0, 0);    scsiCommand[0] = SCSI_OPCODE_MODE_SELECT;    scsiCommand[1] = (UINT8) ((pScsiPhysDev->scsiDevLUN & 0x7) << 5);    scsiCommand[1] |= ((UINT8) ((pageFormat & 1) << 4) |		       (UINT8) (saveParams & 1));    scsiCommand[2] = (UINT8) 0;    scsiCommand[3] = (UINT8) 0;    scsiCommand[4] = (UINT8) (bufLength & 0xff);    scsiCommand[5] = (UINT8) 0;    scsiXaction.cmdAddress    = scsiCommand;    scsiXaction.cmdLength     = SCSI_GROUP_0_CMD_LENGTH;    scsiXaction.dataAddress   = (UINT8 *) buffer;    scsiXaction.dataDirection = O_WRONLY;    scsiXaction.dataLength    = min (0xff, bufLength);    scsiXaction.addLengthByte = NULL;    scsiXaction.cmdTimeout    = SCSI_TIMEOUT_5SEC;    scsiXaction.tagType       = SCSI_TAG_DEFAULT;    scsiXaction.priority      = SCSI_THREAD_TASK_PRIORITY;    status = (*pScsiPhysDev->pScsiCtrl->scsiTransact)	      (pScsiPhysDev, &scsiXaction);    return (status);    }/********************************************************************************* scsiTapeModeSense - issue a MODE_SENSE command to a SCSI tape device** This routine issues a MODE_SENSE command to a specified SCSI tape device.** RETURNS: OK, or ERROR if the command fails.*/STATUS scsiTapeModeSense    (    SCSI_PHYS_DEV *pScsiPhysDev,/* ptr to SCSI physical device           */    int pageControl,            /* value of the page control field (0-3) */    int pageCode,               /* value of the page code field (0-0x3f) */    char *buffer,               /* ptr to input data buffer              */    int bufLength               /* length of buffer in bytes             */    )    {    SCSI_COMMAND scsiCommand;	/* SCSI command byte array */    SCSI_TRANSACTION scsiXaction;	/* info on a SCSI transaction */    STATUS status;			/* status of transaction */    SCSI_DEBUG_MSG ("scsiModeSense: cmdAddress 0x%x\n", (int) scsiCommand,								0, 0, 0, 0, 0);    scsiCommand[0] = SCSI_OPCODE_MODE_SENSE;    scsiCommand[1] = (UINT8) ((pScsiPhysDev->scsiDevLUN & 0x7) << 5);    scsiCommand[2] = (UINT8) ((pageControl << 6) | pageCode);    scsiCommand[3] = (UINT8) 0;    scsiCommand[4] = (UINT8) (bufLength & 0xff);    scsiCommand[5] = (UINT8) 0;    scsiXaction.cmdAddress    = scsiCommand;    scsiXaction.cmdLength     = SCSI_GROUP_0_CMD_LENGTH;    scsiXaction.dataAddress   = (UINT8 *) buffer;    scsiXaction.dataDirection = O_RDONLY;    scsiXaction.dataLength    = min (0xff, bufLength);    scsiXaction.addLengthByte = MODE_SENSE_ADD_LENGTH_BYTE;    scsiXaction.cmdTimeout    = SCSI_TIMEOUT_5SEC;    scsiXaction.tagType       = SCSI_TAG_DEFAULT;    scsiXaction.priority      = SCSI_THREAD_TASK_PRIORITY;    status = (*pScsiPhysDev->pScsiCtrl->scsiTransact)	      (pScsiPhysDev, &scsiXaction);    return (status);    }/********************************************************************************* scsiReadBlockLimits - issue a READ_BLOCK_LIMITS command to a SCSI device** This routine issues a READ_BLOCK_LIMITS command to a specified SCSI device.** RETURNS: OK, or ERROR if the command fails.** NOMANUAL*/STATUS scsiReadBlockLimits    (    SCSI_PHYS_DEV * pScsiPhysDev,/* ptr to SCSI physical device          */    int    *pMaxBlockLength,     /* where to return maximum block length */    UINT16 *pMinBlockLength      /* where to return minimum block length */    )    {    SCSI_COMMAND readBlockLimitCommand;	/* SCSI command byte array */    RD_BLOCK_LIMIT_DATA readBlkLimitData; /* data structure for results */    SCSI_TRANSACTION scsiXaction;	  /* info on a SCSI transaction */    STATUS status;			  /* status of the transaction */    SCSI_DEBUG_MSG ("scsiReadBlockLimit:\n", 0, 0, 0, 0, 0, 0);    readBlockLimitCommand[0] = SCSI_OPCODE_READ_BLOCK_LIMITS;    readBlockLimitCommand[1] = (UINT8) ((pScsiPhysDev->scsiDevLUN & 0x7) << 5);    readBlockLimitCommand[2] = (UINT8) 0;    readBlockLimitCommand[3] = (UINT8) 0;    readBlockLimitCommand[4] = (UINT8) 0;    readBlockLimitCommand[5] = (UINT8) 0;    scsiXaction.cmdAddress    = readBlockLimitCommand;    scsiXaction.cmdLength     = SCSI_GROUP_0_CMD_LENGTH;    scsiXaction.dataAddress   = (UINT8 *) &readBlkLimitData;    scsiXaction.dataDirection = O_RDONLY;    scsiXaction.dataLength    = sizeof (readBlkLimitData);    scsiXaction.addLengthByte = NULL;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人av电影观看| 91精品国产综合久久精品app| 亚洲午夜三级在线| 精品国产乱码久久| 99精品视频中文字幕| 久色婷婷小香蕉久久| 亚洲美女电影在线| 国产亚洲欧美日韩日本| 欧美精品1区2区| 91亚洲午夜精品久久久久久| 国产毛片精品视频| 日韩激情视频网站| 一区二区视频在线看| 国产清纯在线一区二区www| 91精品欧美福利在线观看| 色先锋aa成人| 粉嫩欧美一区二区三区高清影视| 免费人成在线不卡| 亚洲国产成人av网| 亚洲欧洲综合另类在线| 国产欧美精品国产国产专区 | 91麻豆精品国产| 91偷拍与自偷拍精品| 中文字幕一区二| 26uuu久久综合| 日韩一级完整毛片| 欧美一区二区久久久| 欧美日韩国产在线播放网站| 91美女在线视频| 91最新地址在线播放| 成人av综合在线| 国产精品人妖ts系列视频| 国产成人在线网站| 国产欧美精品一区二区色综合| 国产精品一区在线| 欧美激情一区二区三区| 懂色av一区二区夜夜嗨| 亚洲欧美综合在线精品| 91一区一区三区| 亚洲国产另类精品专区| 欧美日韩亚洲高清一区二区| 日韩黄色片在线观看| 日韩欧美国产综合在线一区二区三区| 美腿丝袜在线亚洲一区| 亚洲精品在线三区| 国v精品久久久网| 亚洲欧美一区二区不卡| 欧美日韩中字一区| 六月丁香婷婷久久| 亚洲国产成人自拍| 91片黄在线观看| 图片区小说区国产精品视频| 日韩一区二区免费在线电影| 极品少妇xxxx精品少妇偷拍| 国产精品理伦片| 欧美写真视频网站| 激情欧美一区二区三区在线观看| 国产日韩视频一区二区三区| 99视频国产精品| 日韩黄色小视频| 国产拍欧美日韩视频二区| 91国产视频在线观看| 欧美a级一区二区| 中文文精品字幕一区二区| 欧洲一区在线电影| 精品亚洲成a人在线观看| 亚洲国产激情av| 91精品免费观看| 成人免费视频视频| 日韩和的一区二区| 国产精品国产三级国产有无不卡 | 国产不卡视频一区二区三区| 亚洲日本一区二区| 91精品免费在线观看| 成人福利电影精品一区二区在线观看| 亚洲自拍与偷拍| 久久久久久一级片| 欧美中文字幕一二三区视频| 久久成人久久鬼色| 亚洲专区一二三| 中文字幕不卡的av| 日韩你懂的电影在线观看| 99国产精品国产精品久久| 久久精品国产**网站演员| 亚洲视频一二区| 久久你懂得1024| 欧美一区二区三区爱爱| 色av成人天堂桃色av| 国产一区二区免费看| 亚洲老妇xxxxxx| 中文字幕欧美日本乱码一线二线| 欧美精品v国产精品v日韩精品 | 精品久久国产老人久久综合| 欧美性生活久久| www.色精品| 国产露脸91国语对白| 男女激情视频一区| 亚洲成av人片在线观看无码| 亚洲欧美在线aaa| 国产日韩精品一区二区三区在线| 日韩一区二区高清| 制服丝袜一区二区三区| 91福利国产成人精品照片| 成人av免费在线播放| 国产精品一品视频| 极品少妇一区二区| 蜜臀久久久久久久| 日本午夜一本久久久综合| 成人一级视频在线观看| 国产一区二区三区视频在线播放| 日本 国产 欧美色综合| 日本aⅴ亚洲精品中文乱码| 五月激情丁香一区二区三区| 亚洲18女电影在线观看| 午夜精品久久久久影视| 亚洲成人午夜电影| 五月激情综合网| 蜜臀久久久99精品久久久久久| 丝袜美腿高跟呻吟高潮一区| 国产一区二区福利视频| 国产真实乱子伦精品视频| 国产一区二区三区香蕉| 国产精品一区三区| av成人老司机| 欧洲国产伦久久久久久久| 欧美日韩在线精品一区二区三区激情 | 欧美tickling挠脚心丨vk| 欧美va在线播放| 欧美mv日韩mv国产网站app| 精品国内二区三区| 亚洲国产精品精华液ab| 亚洲欧洲精品天堂一级| 亚洲制服丝袜在线| 日本成人在线网站| 国产精品一区二区x88av| av一区二区久久| 欧美日韩一区二区欧美激情| 日韩欧美你懂的| 国产精品传媒视频| 亚洲国产三级在线| 久久不见久久见中文字幕免费| 国产精品一区二区久激情瑜伽| 91在线观看视频| 欧美一区二区在线播放| 国产喂奶挤奶一区二区三区| 1区2区3区精品视频| 亚洲 欧美综合在线网络| 国产乱子伦一区二区三区国色天香 | 国产精品久久久久天堂| 一区二区三区日韩欧美精品 | 成人美女视频在线观看18| 色综合欧美在线| 日韩欧美成人一区| 亚洲欧美成人一区二区三区| 视频一区二区中文字幕| 成人av午夜电影| 欧美videos中文字幕| 亚洲狼人国产精品| 极品少妇xxxx精品少妇偷拍 | www.亚洲免费av| 欧美一区二区性放荡片| 亚洲欧美一区二区三区国产精品| 捆绑变态av一区二区三区| 99精品国产视频| 久久亚洲综合色| 日产国产欧美视频一区精品| 成人av午夜电影| 精品国产一区二区亚洲人成毛片| 亚洲激情自拍偷拍| 国产精品一二三四五| 日韩一级大片在线观看| 亚洲亚洲人成综合网络| 成人性生交大片免费看在线播放| 91精品国产综合久久福利| 亚洲人成在线观看一区二区| 国产一区二区三区四区五区美女| 欧美人牲a欧美精品| 亚洲男人电影天堂| 成人黄色777网| 欧美韩日一区二区三区| 国产精品99久久久久久有的能看| 欧美一区二区在线免费播放| 亚洲不卡一区二区三区| 欧洲一区在线观看| 自拍视频在线观看一区二区| 高清不卡一区二区| 国产无人区一区二区三区| 国产在线视视频有精品| 日韩一区二区三区四区| 日韩va亚洲va欧美va久久| 欧美日韩一区二区三区四区五区| 亚洲青青青在线视频| 91美女在线观看| 亚洲欧洲日韩综合一区二区| 成人免费毛片a| 亚洲国产精品国自产拍av| 国产99久久久国产精品潘金网站| 国产亚洲一区字幕| 成人午夜视频在线| 中文字幕在线播放不卡一区|