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

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

?? cmmd_atapi.c

?? STi5518機頂盒ATAPI源代碼!絕對超值!
?? C
?? 第 1 頁 / 共 3 頁
字號:
/************************************************************************Source file name : cmmd_atapi.cDescription: Implementation of the ATA Command Interface intermediate module            following the API Design Document v0.9.0 of the ATAPI driver.             COPYRIGHT (C) STMicroelectronics  2000************************************************************************//*Includes-------------------------------------------------------------*/#include <string.h>#include "stlite.h"#include "statapi.h"#include "hal_atapi.h"#include "ata.h"/*Private Types--------------------------------------------------------*//*Private Constants----------------------------------------------------*//*Private Variables----------------------------------------------------*//*Private Macros-------------------------------------------------------*/#define PACKET_TIMEOUT      0x00100000#define TAG_BIT_MASK   0xF8#define  REL_BIT_MASK  0x04#define  IO_BIT_MASK   0x02 #define  CD_BIT_MASK   0x01#define  SERV_BIT_MASK   0x10#define  PACKET_INT_TIMEOUT   500000/*Private functions prototypes-----------------------------------------*/static void GetPktStatus(ata_ControlBlock_t *Ata_p,STATAPI_PktStatus_t *Stat_p);/*Functions------------------------------------------------------------*//************************************************************************Name: ata_packet_NoDataDescription: executes a non data packet. The device is already selected              no parameters check is performed. We totally trust on the caller Parameters: Two params:            Ata_p : Pointer to the ATA control block            Cmd_p : Pointer to a command structureReturn:     TRUE:  Extended error is set            FALSE: No error                     ************************************************************************/BOOL ata_packet_NoData(ata_ControlBlock_t *Ata_p, ata_Cmd_t *Cmd_p){    DU8 Status,Reason,LowCyl,HighCyl;    U32 TimeOut,i;                /* First we write the registers */       hal_RegOutByte(Ata_p->HalHndl,ATA_REG_FEATURE, Cmd_p->Feature);   hal_RegOutByte(Ata_p->HalHndl,ATA_REG_SECCOUNT, Cmd_p->SecCount);   hal_RegOutByte(Ata_p->HalHndl,ATA_REG_SECNUM, Cmd_p->SecNum);   hal_RegOutByte(Ata_p->HalHndl,ATA_REG_CYLLOW, Cmd_p->CylLow);   hal_RegOutByte(Ata_p->HalHndl,ATA_REG_CYLHIGH, Cmd_p->CylHigh);   hal_RegOutByte(Ata_p->HalHndl,ATA_REG_DEVHEAD, Cmd_p->DevHead);      if(WaitForBit(Ata_p->HalHndl,ATA_REG_ALTSTAT,DRDY_BIT_MASK,DRDY_BIT_MASK))   {       Ata_p->LastExtendedErrorCode= 0x5B;         GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);                  return TRUE;              }       /* Finally write the command */   hal_RegOutByte(Ata_p->HalHndl,ATA_REG_COMMAND, Cmd_p->CommandCode);              WAIT400NS;      /* Now Check the Status */    Status= hal_RegInByte(Ata_p->HalHndl,ATA_REG_ALTSTAT);        /* Command packet transfer...*/    /* Check for protocol failures, the device should        have BSY=1 now, but a number of strange things can happen:       1) the device may not set BSY=1 or DRQ=1 for a while       2) the device may go directly to DRQ status,       3) the device may reject the command (maybe is not really          an  ATAPI device or has some error)    */    TimeOut= PACKET_TIMEOUT;        while(TRUE)    {        if(Status & BSY_BIT_MASK)        {           break; /* BSY=1 that's OK! */        }else        {           if( Status & DRQ_BIT_MASK )             {             break;  /* BSY=0 & DRQ=1 That's OK */           }           if( Status & ERR_BIT_MASK)           {             /* Error,that's not OK */             break;           }         }        if(TimeOut==0)        {            /* Error */            break;        }                TimeOut--;        Status= hal_RegInByte(Ata_p->HalHndl,ATA_REG_ALTSTAT);    }        /* Command packet transfer....                          */    /* Poll Alternate Status for BSY=0                      */    if(WaitForBit(Ata_p->HalHndl,ATA_REG_ALTSTAT,BSY_BIT_MASK,0))    {       Ata_p->LastExtendedErrorCode= 0x51;       GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);       return TRUE;    }        /* Command packet transfer....                          */    /* Check for protocol failures.. clear interrupts       */               hal_ClearInterrupt(Ata_p->HalHndl);                /* Command packet transfer....                                 Read the primary status register abd other ATAPI registers                */              Status= hal_RegInByte(Ata_p->HalHndl,ATA_REG_STATUS);            Reason= hal_RegInByte(Ata_p->HalHndl,ATA_REG_SECCOUNT);         LowCyl= hal_RegInByte(Ata_p->HalHndl,ATA_REG_CYLLOW);            HighCyl= hal_RegInByte(Ata_p->HalHndl,ATA_REG_CYLHIGH);                /* Command packet transfer....                                  check status must have BSY=0 DRQ-1     */                if((Status & (BSY_BIT_MASK | DRQ_BIT_MASK))!= DRQ_BIT_MASK)     {        Ata_p->LastExtendedErrorCode= 0x52;        GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);        return TRUE;     }                    /* Transfer the packet     */                  for(i=0;i<Ata_p->Handles[Ata_p->DeviceSelected].PktSize;i++)      {      hal_RegOutWord(Ata_p->HalHndl,Cmd_p->Pkt[i]);       }                #if  ATAPI_USING_INTERRUPTS   if(hal_AwaitInt(Ata_p->HalHndl,PACKET_INT_TIMEOUT))   {      Ata_p->LastExtendedErrorCode= 0x53;      GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);      return TRUE;   }      #else    WAIT400NS;    if(WaitForBitPkt(Ata_p->HalHndl,ATA_REG_ALTSTAT,BSY_BIT_MASK,0))    {       Ata_p->LastExtendedErrorCode= 0x54;       GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);       return TRUE;    }   #endif /* ATAPI_USING_INTERRUPTS */        Status= hal_RegInByte(Ata_p->HalHndl,ATA_REG_STATUS);       Reason= hal_RegInByte(Ata_p->HalHndl,ATA_REG_SECCOUNT);         if( (Status & (BSY_BIT_MASK | DRQ_BIT_MASK |SERV_BIT_MASK| ERR_BIT_MASK))        | (Reason & REL_BIT_MASK))    {       Ata_p->LastExtendedErrorCode= 0x55;       GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);       return TRUE;     }            GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);    Ata_p->LastExtendedErrorCode= 0x00;    return FALSE;}/************************************************************************Name: ata_packet_PioInDescription: executes a command with data transfer from the device              to the host via PIO.             The device is already selected, no parameters check             is performed. We totally trust on the caller               Parameters: Two params:            Ata_p : Pointer to the ATA control block            Cmd_p : Pointer to a command structureReturn:     TRUE:  Extended error is set            FALSE: No error                     ************************************************************************/BOOL ata_packet_PioIn(ata_ControlBlock_t *Ata_p, ata_Cmd_t *Cmd_p){    DU8 Status,Reason,LowCyl,HighCyl;    U32 TimeOut,i;    BOOL Error=FALSE;    U32 WordCount,ByteCount;        U16 *Data_p;        /* First we write the registers */       hal_RegOutByte(Ata_p->HalHndl,ATA_REG_FEATURE, Cmd_p->Feature);   hal_RegOutByte(Ata_p->HalHndl,ATA_REG_SECCOUNT, Cmd_p->SecCount);   hal_RegOutByte(Ata_p->HalHndl,ATA_REG_SECNUM, Cmd_p->SecNum);   hal_RegOutByte(Ata_p->HalHndl,ATA_REG_CYLLOW, Cmd_p->CylLow);   hal_RegOutByte(Ata_p->HalHndl,ATA_REG_CYLHIGH, Cmd_p->CylHigh);   hal_RegOutByte(Ata_p->HalHndl,ATA_REG_DEVHEAD, Cmd_p->DevHead);      if(WaitForBitPkt(Ata_p->HalHndl,ATA_REG_ALTSTAT,DRDY_BIT_MASK,DRDY_BIT_MASK))   {       Ata_p->LastExtendedErrorCode= 0x5B;         GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);                  return TRUE;              }       /* Finally write the command */   hal_RegOutByte(Ata_p->HalHndl,ATA_REG_COMMAND, Cmd_p->CommandCode);      WAIT400NS;      /* Now Check the Status */    Status= hal_RegInByte(Ata_p->HalHndl,ATA_REG_ALTSTAT);        /* Command packet transfer...*/    /* Check for protocol failures, the device should        have BSY=1 now, but a number of strange things can happen:       1) the device may not set BSY=1 or DRQ=1 for a while       2) the device may go directly to DRQ status,       3) the device may reject the command (maybe is not really          an  ATAPI device or has some error)    */    TimeOut= PACKET_TIMEOUT;        while(TRUE)    {        if(Status & BSY_BIT_MASK)        {           break; /* BSY=1 that's OK! */        }else        {           if( Status & DRQ_BIT_MASK )             {             break;  /* BSY=0 & DRQ=1 That's OK */           }           if( Status & ERR_BIT_MASK)           {             /* Error,that's not OK */             break;           }         }        if(TimeOut==0)        {            /* Error */            break;        }                TimeOut--;        Status= hal_RegInByte(Ata_p->HalHndl,ATA_REG_ALTSTAT);    }        /* Command packet transfer....                          */    /* Poll Alternate Status for BSY=0                      */    if(WaitForBitPkt(Ata_p->HalHndl,ATA_REG_ALTSTAT,BSY_BIT_MASK,0))    {       Ata_p->LastExtendedErrorCode= 0x51;       GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);       return TRUE;    }        /* Command packet transfer....                          */    /* Check for protocol failures.. clear interrupts       */               hal_ClearInterrupt(Ata_p->HalHndl);                /* Command packet transfer....                                 Read the primary status register and other ATAPI registers                */              Status= hal_RegInByte(Ata_p->HalHndl,ATA_REG_STATUS);            Reason= hal_RegInByte(Ata_p->HalHndl,ATA_REG_SECCOUNT);         LowCyl= hal_RegInByte(Ata_p->HalHndl,ATA_REG_CYLLOW);            HighCyl= hal_RegInByte(Ata_p->HalHndl,ATA_REG_CYLHIGH);                /* Command packet transfer....                                  check status must have BSY=0 DRQ-1     */                if((Status & (BSY_BIT_MASK | DRQ_BIT_MASK))!= DRQ_BIT_MASK)     {        Ata_p->LastExtendedErrorCode= 0x52;        GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);        return TRUE;     }                    /* Transfer the packet     */                  for(i=0;i<Ata_p->Handles[Ata_p->DeviceSelected].PktSize;i++)      {      hal_RegOutWord(Ata_p->HalHndl,((U16 *)Cmd_p->Pkt)[i]);     }           WAIT400NS;           /* --------------- Transfer Loop--------------- */   *Cmd_p->BytesRW=0;    Data_p =(U16*) Cmd_p->DataBuffer;      while (Error==FALSE)        {         #if  ATAPI_USING_INTERRUPTS     if(hal_AwaitInt(Ata_p->HalHndl,PACKET_INT_TIMEOUT))     {        Ata_p->LastExtendedErrorCode= 0x53;        GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);        Error= TRUE;        break;     }       #else     WAIT400NS;     if(WaitForBitPkt(Ata_p->HalHndl,ATA_REG_ALTSTAT,BSY_BIT_MASK,0))     {        Ata_p->LastExtendedErrorCode= 0x54;        GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);        Error= TRUE;        break;     }   #endif /* ATAPI_USING_INTERRUPTS */                              Status= hal_RegInByte(Ata_p->HalHndl,ATA_REG_STATUS);           Reason= hal_RegInByte(Ata_p->HalHndl,ATA_REG_SECCOUNT);        LowCyl= hal_RegInByte(Ata_p->HalHndl,ATA_REG_CYLLOW);           HighCyl= hal_RegInByte(Ata_p->HalHndl,ATA_REG_CYLHIGH);                    if( (Status & (BSY_BIT_MASK | DRQ_BIT_MASK)) == 0)       {            /* end of transfer lets quit*/           Ata_p->LastExtendedErrorCode= 0x00;           GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);           Error=FALSE;           break;       }              if( (Status & (BSY_BIT_MASK | DRQ_BIT_MASK)) != DRQ_BIT_MASK)       {           Ata_p->LastExtendedErrorCode= 0x55;           GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);           Error=TRUE;           break;       }       if( (Reason & (TAG_BIT_MASK | REL_BIT_MASK))            || (Reason &  CD_BIT_MASK))       {           Ata_p->LastExtendedErrorCode= 0x5C;           GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);           Error=TRUE;           break;       }       if( (Reason & IO_BIT_MASK )==0)       {           /* Wrong direction, we expect a IO = 1 */            Ata_p->LastExtendedErrorCode= 0x5D;           GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);           Error=TRUE;           break;       }       /* Data Transfer Loop....          get the byte count and check for zero       */       ByteCount= (HighCyl<<8) | LowCyl;       if(ByteCount<1)       {           Ata_p->LastExtendedErrorCode= 0x60;           GetPktStatus(Ata_p,Cmd_p->Stat.PktStat);           Error=TRUE;           break;       }       

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费高清在线一区| 亚洲一区视频在线观看视频| 5858s免费视频成人| 91麻豆swag| 欧美综合一区二区| 欧美午夜免费电影| 在线综合亚洲欧美在线视频| 欧美一区二区三区在线电影| 精品久久五月天| 久久久不卡影院| 国产精品毛片无遮挡高清| 国产精品久久久久影院亚瑟 | 亚洲国产另类精品专区| 五月天婷婷综合| 韩国精品久久久| 成人免费福利片| 在线观看网站黄不卡| 欧美一区二区三区人| 2022国产精品视频| 亚洲黄色免费网站| 琪琪久久久久日韩精品| 粗大黑人巨茎大战欧美成人| 91福利社在线观看| 日韩欧美国产一区二区在线播放 | 五月婷婷久久综合| 国产乱色国产精品免费视频| 成人动漫一区二区| 欧美精品18+| 国产精品久久免费看| 午夜国产精品影院在线观看| 国产乱码精品一品二品| 在线看一区二区| 久久久久国产一区二区三区四区 | 色8久久人人97超碰香蕉987| 欧美一区永久视频免费观看| 国产亚洲美州欧州综合国| 亚洲精品第1页| 国产精品羞羞答答xxdd| 欧美这里有精品| 久久久美女艺术照精彩视频福利播放| 亚洲免费观看高清在线观看| 免费观看久久久4p| 色8久久精品久久久久久蜜| 久久蜜桃av一区精品变态类天堂| 一区二区三区免费网站| 国产精品18久久久久久久久| 欧美三级电影精品| 亚洲欧洲日韩在线| 国产麻豆欧美日韩一区| 91麻豆精品国产91久久久| 国产精品高潮久久久久无| 国产在线不卡一卡二卡三卡四卡| 欧美日韩精品一二三区| 国产精品久久久久毛片软件| 国产乱子轮精品视频| 欧美一级免费大片| 亚洲成年人影院| 99re8在线精品视频免费播放| 国产视频一区二区在线| 奇米影视一区二区三区| 欧美日韩亚洲不卡| 夜夜嗨av一区二区三区网页| 99久久婷婷国产综合精品电影 | 国产乱码精品一品二品| 欧美成人激情免费网| 午夜精品久久久久久久久久久| 91国产视频在线观看| 国产偷国产偷亚洲高清人白洁| 精品一区免费av| 精品国产一区二区三区四区四| 日韩电影免费在线看| 日韩一区二区在线看片| 美女脱光内衣内裤视频久久网站 | 中文一区二区在线观看| 国产乱码精品一区二区三区av| 精品99999| 国产在线一区观看| 国产日韩欧美在线一区| 成人性生交大片免费看中文网站| 中文字幕乱码亚洲精品一区| 成a人片国产精品| 亚洲最新视频在线播放| 欧美日韩成人激情| 美腿丝袜在线亚洲一区| 亚洲精品一区二区精华| 国产精品中文有码| 中文字幕中文字幕一区| 欧美亚洲愉拍一区二区| 香蕉久久夜色精品国产使用方法| 欧美一区二区三级| 国产一区二区三区不卡在线观看| 中文字幕不卡的av| 色女孩综合影院| 日本不卡一区二区三区高清视频| 精品人伦一区二区色婷婷| 岛国精品一区二区| 亚洲综合另类小说| 欧美成人一区二区| www.av精品| 视频一区免费在线观看| 久久久久久毛片| 日本高清不卡一区| 精品影视av免费| 一区二区三区毛片| 精品国产伦一区二区三区观看方式 | 亚洲精品老司机| 欧美日韩1234| 成人激情图片网| 亚洲成av人在线观看| 精品国产不卡一区二区三区| 99riav久久精品riav| 日本怡春院一区二区| 国产嫩草影院久久久久| 欧美色老头old∨ideo| 国产精品影视天天线| 午夜精品免费在线观看| 国产精品免费免费| 精品免费99久久| 欧美三片在线视频观看| 成人av网站免费观看| 麻豆久久久久久| 亚洲国产日日夜夜| 国产精品乱人伦| 精品国产乱码91久久久久久网站| 色欧美片视频在线观看| 国产乱色国产精品免费视频| 亚洲二区在线视频| 亚洲特级片在线| 久久精品一区二区三区av| 欧美男男青年gay1069videost| 懂色av一区二区在线播放| 另类综合日韩欧美亚洲| 午夜不卡在线视频| 亚洲欧美区自拍先锋| 欧美国产日本视频| 久久综合九色综合97婷婷女人 | 国产麻豆一精品一av一免费 | 国内久久精品视频| 日韩高清电影一区| 日欧美一区二区| 亚洲一区电影777| 亚洲综合一区在线| 亚洲精品久久7777| 亚洲一区在线观看视频| 亚洲精品成人精品456| 亚洲色图一区二区| 亚洲三级在线免费观看| 中文字幕在线观看不卡| ...中文天堂在线一区| 日韩伦理av电影| 亚洲精品v日韩精品| 亚洲美女免费视频| 亚洲一区av在线| 日韩av电影天堂| 蜜臀av一区二区在线观看| 免费观看成人av| 国产一二精品视频| 国产二区国产一区在线观看| 国产69精品久久99不卡| 国产成人综合亚洲网站| 成人黄色大片在线观看| av中文字幕亚洲| 欧美视频在线观看一区| 这里是久久伊人| 久久亚洲综合色| 中文字幕在线不卡国产视频| 亚洲精品免费在线| 视频一区视频二区中文| 国产精品一区一区| 色综合中文字幕国产| 色综合av在线| 日韩一级在线观看| 亚洲国产经典视频| 亚洲午夜激情网页| 国模一区二区三区白浆| 91丨porny丨国产| 欧美肥大bbwbbw高潮| 久久久激情视频| 一区二区欧美在线观看| 麻豆免费精品视频| 91免费视频大全| 日韩精品一区二区三区视频播放| 日本一区二区视频在线| 亚洲高清在线精品| 国产很黄免费观看久久| 欧美视频在线播放| 国产欧美日韩三级| 亚洲成av人片| 成人午夜电影久久影院| 欧美精品久久久久久久久老牛影院 | 精品捆绑美女sm三区| 亚洲另类中文字| 国产精品一区在线观看乱码 | 久久久久久久久久久久久久久99| 一区二区三区在线视频免费观看| 麻豆freexxxx性91精品| 91蜜桃在线观看| 日韩精品中文字幕一区二区三区| 中文字幕色av一区二区三区| 久久精品国产精品青草|