亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
99精品黄色片免费大全| 亚洲蜜臀av乱码久久精品蜜桃| 一区二区三区不卡视频在线观看| 亚洲一区二区三区激情| 麻豆91免费看| 色悠悠亚洲一区二区| 日韩欧美国产三级电影视频| 国产精品福利一区二区三区| 日本不卡123| 91豆麻精品91久久久久久| 精品国产a毛片| 天天色天天操综合| 一本色道久久综合亚洲91| 久久青草欧美一区二区三区| 欧美精品乱码久久久久久按摩| 蜜臀av亚洲一区中文字幕| 狠狠网亚洲精品| 欧美老女人在线| 亚洲午夜电影网| 99国产精品国产精品久久| 久久久国产午夜精品| 国产揄拍国内精品对白| 在线综合视频播放| 亚洲一区二区黄色| 色成年激情久久综合| 亚洲柠檬福利资源导航| 国产成人精品免费| 国产亚洲综合色| 国产成人免费视频网站| 26uuu色噜噜精品一区二区| 青青草原综合久久大伊人精品 | 亚洲欧美自拍偷拍色图| 国产一区二区精品在线观看| 精品国产网站在线观看| 国产一区二区女| 精品粉嫩aⅴ一区二区三区四区| 日韩av在线播放中文字幕| 欧美三区在线视频| 日韩电影在线免费| 精品女同一区二区| 久草精品在线观看| 久久综合久久99| 国产精品一区二区视频| 国产三级一区二区| 成人av在线一区二区三区| 国产欧美精品区一区二区三区| 丰满白嫩尤物一区二区| 国产精品高清亚洲| 一本高清dvd不卡在线观看| 亚洲伦理在线精品| 91欧美一区二区| 亚洲一区二区三区小说| 欧美日韩另类一区| 国产精品自拍av| 国产精品乱码妇女bbbb| 99精品久久只有精品| 亚洲永久免费视频| 7777精品伊人久久久大香线蕉超级流畅 | 午夜精品aaa| 精品国产免费视频| 成人中文字幕电影| 亚洲视频每日更新| 91精品国产一区二区三区蜜臀| 精品一区二区成人精品| 国产精品伦理在线| 在线成人小视频| 国产成人综合网| 亚洲一二三四久久| 久久久久久久久久久久久夜| 99re这里只有精品6| 日本不卡一区二区三区| 国产精品久久久久影院亚瑟| 欧美日韩国产另类一区| 国产电影一区在线| 天天色天天操综合| 国产精品久久久99| 欧美一级生活片| 一本高清dvd不卡在线观看| 日韩一区二区三区精品视频| 99久久精品国产一区二区三区 | 国产三级三级三级精品8ⅰ区| 91天堂素人约啪| 精品系列免费在线观看| 尤物av一区二区| 国产天堂亚洲国产碰碰| 欧美三级视频在线播放| 成人av免费在线播放| 精品一区二区在线视频| 亚洲国产视频一区二区| 国产精品久久免费看| 韩国一区二区视频| 依依成人综合视频| 欧美国产一区视频在线观看| 91精品麻豆日日躁夜夜躁| 91国产丝袜在线播放| 高清不卡一区二区在线| 精品在线一区二区三区| 天堂在线一区二区| 午夜视频在线观看一区二区| 亚洲欧美综合网| 中文字幕日韩av资源站| 亚洲国产激情av| 精品卡一卡二卡三卡四在线| 欧美在线观看18| 性做久久久久久久免费看| 亚洲欧美激情小说另类| 国产视频911| 91精品久久久久久蜜臀| 色综合视频一区二区三区高清| 国产成人免费网站| 激情成人综合网| 偷拍一区二区三区| 一区二区三区四区在线播放| 国产日韩高清在线| 欧美人与z0zoxxxx视频| 欧美丰满少妇xxxxx高潮对白| 不卡一区二区在线| 国产精品系列在线观看| 蜜臀av性久久久久蜜臀aⅴ流畅 | 久久精品国产久精国产爱| 亚洲综合男人的天堂| 国产三级精品视频| 日韩毛片高清在线播放| 国产日产欧美一区| 久久精品视频免费观看| 2023国产精品| 欧美v日韩v国产v| 欧美三级资源在线| 91福利资源站| 91污片在线观看| kk眼镜猥琐国模调教系列一区二区| 国产精品综合久久| 日韩av中文字幕一区二区| 理论片日本一区| 欧美在线你懂得| 9色porny自拍视频一区二区| www.亚洲国产| 国产成人av电影免费在线观看| 日本人妖一区二区| 天天综合色天天综合色h| 亚洲国产成人av网| 天堂久久久久va久久久久| 午夜伊人狠狠久久| 天天射综合影视| 欧美国产日本韩| 亚洲最新视频在线播放| 一区二区三区 在线观看视频 | 亚洲成人一二三| 蜜臀精品久久久久久蜜臀| 美女网站色91| 精品中文字幕一区二区小辣椒| 日本91福利区| thepron国产精品| 欧美日韩一区久久| 欧美一级日韩不卡播放免费| 亚洲精品一区二区在线观看| 日韩精品一区二区三区三区免费| 日本一区二区免费在线观看视频 | 亚洲成人激情自拍| 国产99久久精品| 欧美午夜不卡视频| 日韩欧美不卡一区| 国产精品福利一区二区三区| 午夜欧美视频在线观看| 久久精品国产秦先生| 成人不卡免费av| 精品视频一区二区三区免费| 日韩欧美一级二级三级| 亚洲少妇30p| 蜜臀精品一区二区三区在线观看 | 青青青伊人色综合久久| 99精品视频在线观看| 在线一区二区视频| 日韩欧美另类在线| 国产欧美日韩卡一| 午夜久久久久久| jlzzjlzz国产精品久久| 日韩午夜激情免费电影| 国产精品久久久久久久久免费丝袜 | 午夜视频久久久久久| 成人av片在线观看| 日韩一区二区三区av| 日韩美女视频19| 韩国精品久久久| 欧美日韩中字一区| 中文一区二区完整视频在线观看 | 亚洲色图都市小说| 国产在线一区二区| 欧美日本在线一区| 国产精品久久久久久久久久久免费看 | 国产精品亚洲专一区二区三区| 91精品1区2区| 综合激情成人伊人| 极品美女销魂一区二区三区免费| 在线中文字幕一区二区| 国产女主播一区| 国产综合久久久久久鬼色 | 国产一区二区三区免费播放| 欧美日韩一区二区电影| 日韩伦理av电影|