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

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

?? hal_atapi.c

?? STi5518機頂盒ATAPI源代碼!絕對超值!
?? C
?? 第 1 頁 / 共 3 頁
字號:
    hal_RegOutByte (HalHndl_p,ATA_REG_CONTROL,nIEN_SET);}/************************************************************************Name:   hal_AwaitInt()Description:     This function waits for an interrupt generated any of the ata devicesParameters:    HalHndl     Handle of the HAL (for the base address)    Timeout     Timeout value for (internal) semaphore************************************************************************/BOOL hal_AwaitInt (hal_Handle_t *HalHndl_p, U32 Timeout){    clock_t     TO;    BOOL        Error = FALSE;        TO = time_plus (time_now(), Timeout);        if (semaphore_wait_timeout(&HalHndl_p->InterruptSemaphore, &TO))    {        STTBX_Print(("No interrupt received\n"));        Error = TRUE;    }        return (Error);}       /************************************************************************Name: ata_InterruptHandlerDescription:Parameters:    none************************************************************************/void ata_InterruptHandler (void){    volatile U32 Dummy;#if defined(ST_5514)    U32 intvalue = 0;#endif#if defined(ST_5514)    /* Back to PIO mode */    intvalue = ReadReg((U32)(The_HalHandle_p->BaseAddress) + HDDI_DMA_STA);    if (intcount < 15)        inttrace[intcount] = 0x100;    intcount++;    if (intcount < 15)        inttrace[intcount] = intvalue;    intcount++;    WriteReg((U32)(The_HalHandle_p->BaseAddress) + HDDI_MODE, HDDI_MODE_PIOREG);        /* Mask interrupts */    intvalue = ReadReg((U32)(The_HalHandle_p->BaseAddress) + HDDI_DMA_ITS);    if (intcount < 15)        inttrace[intcount] = intvalue;    intcount++;    WriteReg((U32)(The_HalHandle_p->BaseAddress) + HDDI_DMA_ITM,            HDDI_DMA_ITM_DEND | HDDI_DMA_ITM_IRQ | HDDI_DMA_ITM_DEVTERMOK);#endif        /* clear interrupt = read status register */    Dummy = hal_RegInByte (The_HalHandle_p,ATA_REG_ALTSTAT);    Dummy = hal_RegInByte (The_HalHandle_p,ATA_REG_STATUS);    Dummy = hal_RegInByte (The_HalHandle_p, ATA_REG_SECCOUNT); /* ?! */#if defined(ST_5514)    The_HalHandle_p->DmaAborted = FALSE;    if (intvalue & HDDI_DMA_ITS_DEND)     {        /* DMA ended */        if (intcount < 15)            inttrace[intcount++] = 0x20;    }    if ((intvalue & HDDI_DMA_ITS_DEVTERMOK) == 0)    {        /* Aborted? */        if (intcount < 15)            inttrace[intcount++] = 0x30;    }    if (intvalue & HDDI_DMA_ITS_IRQ)     {        if (intcount < 15)            inttrace[intcount++] = 0x10;        semaphore_signal(&The_HalHandle_p->InterruptSemaphore);    }    /* Unmask interrupts */    WriteReg((U32)(The_HalHandle_p->BaseAddress) + HDDI_DMA_ITM, 0);#else    semaphore_signal(&The_HalHandle_p->InterruptSemaphore);#endif}/****************************************************************************Name:        hal_ClearInterruptDescription:     Clears the pending Interrupts, and reset the semaphore counterParameters:    HalHndl     Handle of the HAL (for the base address)****************************************************************************/BOOL hal_ClearInterrupt (hal_Handle_t *HalHndl_p){    volatile U8  Dummy;        if (HalHndl_p != The_HalHandle_p)         return TRUE;        Dummy = hal_RegInByte (HalHndl_p, ATA_REG_ALTSTAT);    Dummy = hal_RegInByte (HalHndl_p, ATA_REG_STATUS);          return FALSE;}/************************************************************************Name: hal_RegOutBlockDescription:     This function works as interface to the  device's ATA  DATA register     allowing the user to  WRITE data in this register. No bus acquisition    procedure is done. User must manage this Parameters:     HalHndl     Handle of the HAL (for the base address)    data        data buffer to write    Size        Number of bytes to write    UseDMA      Whether a DMA engine should be used to transfer the                data to the data port (if available)*********************************************************************/ST_ErrorCode_t __inline hal_RegOutBlock (hal_Handle_t *HalHndl_p,                                          U16 *data,                                          U32 Size,                                         BOOL UseDMA){       DU16    *addr;    ST_ErrorCode_t error;#if defined(ATAPI_GPDMA)    STGPDMA_DmaTransfer_t       Dma;    STGPDMA_DmaTransferId_t     Tid;    STGPDMA_DmaTransferStatus_t Status;#endif#if defined(ST_5514)    U32 loop;#endif    /* Stops compiler complaining about 'error' for non-5514 platforms */    error = ST_NO_ERROR;        /* Work out where to send the data */    addr = (DU16 *)((U32)HalHndl_p->BaseAddress | RegsMasks[ATA_REG_DATA]);#if !defined(ST_5514)    memcpy((void *)addr, data, Size);#else    /* See if we have the option (and it's desired) to use GPDMA */#if defined(ATAPI_GPDMA)    if (UseDMA == TRUE)    {        Dma.TimingModel = STGPDMA_TIMING_FREE_RUNNING;        Dma.Source.TransferType = STGPDMA_TRANSFER_1D_INCREMENTING;        Dma.Source.Address = (U32)data;        Dma.Source.UnitSize = 32;        Dma.Destination.TransferType = STGPDMA_TRANSFER_0D;        Dma.Destination.Address = (U32)addr;        Dma.Destination.UnitSize = 2;        Dma.Count = Size;        Dma.Next = NULL;        /* Start DMA on channel */        do         {            error = STGPDMA_DmaStartChannel(HalHndl_p->GPDMAHandle,                                     STGPDMA_MODE_BLOCK, &Dma, 1,                                     0, /* Ignored for free running */                                    0, /* Timeout => forever */                                    &Tid,                                    &Status                                   );            if (error != ST_NO_ERROR)            {                Dma.Source.UnitSize >>= 1;                if (Dma.Source.UnitSize == 0)                {                    STTBX_Print(("hal_RegOutBlock: STGPDMA error: %u\n",                                 error));                }            }        } while ((error != ST_NO_ERROR) && (Dma.Source.UnitSize > 0));    }    else#endif    {        /* 16-bits at a time, size is in bytes, so halve */        loop = Size >> 1;        for (; loop > 0; loop--)        {            *addr = *data;                data++;        }    }#endif    return error;}/************************************************************************Name: hal_RegInBlockDescription:     This function works as interface to the device's ATA DATA register allowing    the user to  READ data in these registers. No bus acquisition procedure is    done. User must manage this Parameters:     HalHndl     Handle of the HAL (for the base address)    data        data buffer to fill    Size        Number of bytes to read    UseDMA      Whether a DMA engine should be used to transfer the data                from the data port, if available************************************************************************/ST_ErrorCode_t __inline hal_RegInBlock (hal_Handle_t *HalHndl_p,                                         U16 *data,                                         U32 Size,                                        BOOL UseDMA){       DU16    *addr;    ST_ErrorCode_t error;#if defined(ST_5514)    U32 loop;#endif        /* Stops compiler complaining about 'error' for non-5514 platforms */    error = ST_NO_ERROR;    addr = (DU16*)((U32)HalHndl_p->BaseAddress | (RegsMasks[ATA_REG_DATA]));#if !defined(ST_5514)    memcpy(data, (void *)addr, Size);#else    /* 16-bits read at a time, size is in bytes, so halve */    loop = Size >> 1;    for (; loop > 0; loop--)    {        *data = *addr;        data++;    }#endif    return error;}/****************************************************************************Name: ata_BlockMoveIntHandlerDescription:     routine that clears the pending Interrupts, and reset the semaphore     counter****************************************************************************/#ifdef BMDMA_ENABLEstatic void ata_BlockMoveIntHandler (void){    volatile U32 data;    U32         valid_bits = (1<<2)-1;    U32         expected_value = 0x3;#pragma ST_device (BMDMAReg)	volatile U8 *BMDMAReg;    BMDMAReg = (volatile U8*)BMDMA_Status;    data = *BMDMAReg;    if ((data & valid_bits) == expected_value)    {        BMDMAReg = (volatile U8*)BMDMA_IntAck;        *BMDMAReg = 1;		BMDMAReg = (volatile U8*)BMDMA_Status;		data = *BMDMAReg;        semaphore_signal(&The_HalHandle_p->BMDMA_IntSemaphore);    }    else    {             semaphore_signal(&The_HalHandle_p->BMDMA_IntSemaphore);    }}/***************************************************************Name: ATA_BMDMADescription:     Performs Block Move DMAParameters:     Source              Source address    Destination         Destination address    Size                Amount of data to be moved****************************************************************/void ATA_BMDMA (void *Source, void *Destination, U32 Size){#pragma ST_device (BMDMAReg)    volatile U8 *BMDMAReg;    BMDMAReg = (volatile U8*) BMDMA_DestAddress;  	*BMDMAReg = (U32) (Destination);  	BMDMAReg = (volatile U8*)BMDMA_SrcAddress;	*BMDMAReg = (U32) Source;	BMDMAReg = (volatile U8*)BMDMA_IntEn;	*BMDMAReg = 1;	BMDMAReg = (volatile U8*)BMDMA_Count;	*BMDMAReg = Size;        semaphore_wait(&The_HalHandle_p->BMDMA_IntSemaphore);}#endif  /* BMDMA_ENABLE *//************************************************************************Name:   hal_HardReset()Description:     Performs a hardware reset on all the devicesParameters:    HalHndl     Handle of the HAL (for the base address)************************************************************************/BOOL hal_HardReset (hal_Handle_t *HalHndl_p){    BOOL Error = FALSE;#if defined (ST_5512)    *(HalHndl_p->HWResetAddress) = ATA_HRD_RST_ASSERT;    task_delay (TWO_MS);    *(HalHndl_p->HWResetAddress) = ATA_HRD_RST_DEASSERT;    Error = FALSE;    #elif defined (ST_5508) | defined (ST_5518)    /* Instead a Hard Reset we perform another SW reset */    hal_RegOutByte(HalHndl_p,ATA_REG_CONTROL,0x0C);    task_delay(TWO_MS);    hal_RegOutByte(HalHndl_p,ATA_REG_CONTROL,0x08);    Error = TRUE;#elif defined(ST_5514)    WriteReg((U32)(HalHndl_p->BaseAddress) + HDDI_ATA_RESET, 1);    task_delay( TWO_MS / 4);       /* Wait 2*25us */        /* Clear the reset signal */    WriteReg((U32)(HalHndl_p->BaseAddress) + HDDI_ATA_RESET, 0);    /* Delay period? */    task_delay( TWO_MS * 2 );         /* Wait 2*2ms */        if (WaitForBit(HalHndl_p, ATA_REG_ALTSTAT, BSY_BIT_MASK,0))    {        STTBX_Print(("Timed out waiting for busy to be clear\n"));    }    Error = FALSE;#endif    return Error;}   /************************************************************************Name:       hal_SetDmaMode()Description:     Sets the HAL handle to use the passed modeParameters:    Mode        DMA mode to use for future transfers************************************************************************/BOOL hal_SetDmaMode (hal_Handle_t *HalHndl_p, STATAPI_DmaMode_t Mode){    CurrentDmaMode = Mode;#if defined(ST_5514)    if (Mode <= STATAPI_DMA_MWDMA_MODE_2)        DMAIsUDMA = FALSE;    else        DMAIsUDMA = TRUE;#endif    return FALSE;}/************************************************************************Name:       hal_SetPIOMode()Description:     Sets the HAL handle to use the passed modeParameters:    Mode        PIO mode to use for future transfers************************************************************************/BOOL hal_SetPioMode (hal_Handle_t *HalHndl_p, STATAPI_PioMode_t Mode){    CurrentPioMode = Mode;    return FALSE;}/************************************************************************Name:   hal_GetDmaTiming()Description:     retrieves the current Timing setings of the DMA ModeParameters:************************************************************************/BOOL hal_GetDmaTiming (hal_Handle_t *HalHndl_p, STATAPI_DmaTiming_t *Time){    /* Check parameters */    if ((Time == NULL) || (HalHndl_p != The_HalHandle_p))        return TRUE;    /* Copy data - won't actually be useful unless this is a 5514, but it is     * always present...      */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久疯狂做爰流白浆xx| 久久五月婷婷丁香社区| 欧美刺激脚交jootjob| 从欧美一区二区三区| 久久精品国产精品青草| 亚洲国产精品天堂| 亚洲欧美日韩国产手机在线| 中文字幕精品—区二区四季| 欧美精品一区二区三区四区| 欧美va日韩va| 欧美成人女星排行榜| 日韩视频在线你懂得| 欧美精品一二三四| 在线成人av影院| 欧美一区二区三区在线观看视频| 欧美区在线观看| 日韩一区二区在线观看视频 | 蜜臀av在线播放一区二区三区 | 欧美性xxxxxxxx| 欧美视频你懂的| 日韩欧美一级二级三级久久久| 欧美成人女星排名| 国产精品三级av| 亚洲图片欧美综合| 另类小说图片综合网| 国产成人综合在线观看| 波多野结衣中文一区| 一本色道亚洲精品aⅴ| 欧美精品丝袜中出| 久久久无码精品亚洲日韩按摩| 中文字幕一区二区三| 午夜激情久久久| 精品影视av免费| 91一区二区在线| 日韩精品中文字幕在线不卡尤物 | 中文字幕字幕中文在线中不卡视频| 亚洲天堂精品视频| 美女网站视频久久| youjizz国产精品| 欧美一区二区在线播放| 欧美激情一二三区| 免费在线观看视频一区| 国产99久久久国产精品潘金| 91在线精品一区二区三区| 欧美疯狂性受xxxxx喷水图片| 久久午夜老司机| 日本中文一区二区三区| 成人黄色777网| 欧美一区二区三区在线观看| 日韩一区在线播放| 另类小说一区二区三区| 在线观看一区二区视频| 日本一区二区三区在线观看| 婷婷国产v国产偷v亚洲高清| bt欧美亚洲午夜电影天堂| 日韩视频免费观看高清在线视频| 国产精品第四页| 久久99久久精品欧美| 在线观看网站黄不卡| 欧美激情一区二区在线| 日本欧美一区二区在线观看| 色婷婷精品大在线视频| 中文字幕不卡在线观看| 久草中文综合在线| 欧美高清www午色夜在线视频| 中文字幕一区二区三区av| 国产成人亚洲精品青草天美| 欧美不卡视频一区| 午夜精品久久久久影视| 色94色欧美sute亚洲线路一ni | 不卡av电影在线播放| 精品乱码亚洲一区二区不卡| 婷婷丁香激情综合| 欧美精品一级二级三级| 丝袜诱惑亚洲看片| 欧美精品在线观看一区二区| 亚洲国产日韩a在线播放| 色婷婷综合久久久中文一区二区| 国产精品理伦片| 99精品热视频| 亚洲精品成人悠悠色影视| 91蝌蚪国产九色| 一区二区三区资源| 欧美午夜视频网站| 五月综合激情网| 3atv一区二区三区| 天堂在线亚洲视频| 欧美一级夜夜爽| 韩国av一区二区三区在线观看| 日韩欧美成人激情| 国产精品99久久久久久久vr| 亚洲国产精品成人久久综合一区| www.久久久久久久久| 有码一区二区三区| 欧美日韩一二三| 久久av资源网| 国产精品久久久久影院色老大| eeuss影院一区二区三区| 一区二区三区四区蜜桃| 91精品久久久久久久91蜜桃| 国产一区欧美一区| 国产精品毛片无遮挡高清| 91美女片黄在线| 免费一级片91| 国产精品丝袜在线| 色天天综合色天天久久| 青青草原综合久久大伊人精品优势| 欧美va亚洲va在线观看蝴蝶网| 成人综合在线观看| 亚洲一区二区三区国产| 精品国产一区久久| 色八戒一区二区三区| 麻豆视频观看网址久久| 中文字幕一区免费在线观看| 欧美精品v日韩精品v韩国精品v| 久久精品国产亚洲高清剧情介绍 | 天天亚洲美女在线视频| 欧美成人一区二区三区| 波多野结衣在线aⅴ中文字幕不卡| 亚洲资源中文字幕| 久久精品亚洲精品国产欧美| 在线亚洲欧美专区二区| 精品一区二区三区的国产在线播放| 国产精品成人一区二区艾草| 3d成人h动漫网站入口| 99国产精品久久久| 精品一区二区三区在线播放视频| 亚洲免费在线视频| 精品国产青草久久久久福利| 色婷婷综合激情| 国产成人免费av在线| 日韩福利视频网| 亚洲免费毛片网站| 久久久久国产精品麻豆 | 国产一区亚洲一区| 亚洲国产aⅴ天堂久久| 中文字幕一区二区三区色视频| 精品久久久久久无| 欧美一区二区大片| 欧美三级资源在线| www.激情成人| 成人h动漫精品一区二区| 美腿丝袜亚洲一区| 亚洲成人av在线电影| 夜夜爽夜夜爽精品视频| 国产精品久线观看视频| 国产女人18毛片水真多成人如厕| 日韩美女一区二区三区四区| 日韩三级高清在线| 欧美一区二视频| 欧美一级片在线| 欧美一区二区三区喷汁尤物| 精品视频1区2区| 欧美日高清视频| 欧美日韩视频在线观看一区二区三区| 91在线视频观看| 色综合久久88色综合天天免费| 大桥未久av一区二区三区中文| 国产精品一区二区在线播放| 紧缚捆绑精品一区二区| 激情成人午夜视频| 九一九一国产精品| 国产精品羞羞答答xxdd| 国产精品一区二区久久精品爱涩| 精品一区二区免费在线观看| 精品亚洲国产成人av制服丝袜| 韩国三级在线一区| 国产一区二区三区综合| 国产精品一二三| www.日本不卡| 欧美日韩一区二区三区四区五区 | 久久精品一区二区三区不卡| 久久综合九色综合久久久精品综合| 久久蜜臀精品av| 国产精品视频一二| 亚洲高清在线精品| 日本不卡视频在线| 国产成人免费av在线| 色网综合在线观看| 日韩三级免费观看| 国产精品日产欧美久久久久| 亚洲乱码日产精品bd| 日韩成人一区二区三区在线观看| 免费人成黄页网站在线一区二区| 国产精品中文字幕日韩精品 | 久久精品国产成人一区二区三区 | 欧美日韩国产精品自在自线| 欧美一级二级在线观看| 久久久无码精品亚洲日韩按摩| 亚洲欧洲av在线| 男女激情视频一区| 97久久精品人人澡人人爽| 欧美高清精品3d| 国产精品久久久久久久午夜片| 亚洲永久精品大片| 成人综合激情网| 欧美一区二区三区色| 亚洲欧美日韩小说| 精品一区二区三区在线播放| 欧美午夜视频网站|