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

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

?? bspspi.c

?? 這是單板上DPRAM的驅動程序
?? C
字號:
#include <string.h>
#include "board.h"
#include "sdev.h"
#include "bsp.h"
#include "bspspi.h"
#include "uart.h"

/* SCCE Flags */
#define SPI_MASTER_ERR  (1<<(7-2))
#define SPI_TX_ERR      (1<<(7-3))
#define SPI_LACK_OF_BUF (1<<(7-5))
#define SPI_TX_BUF      (1<<(7-6))
#define SPI_RX_BUF      (1<<(7-7))

/* Rx BD Flags */
#define SPI_OVERRUN     (1<<(15-14))
#define SPI_RXMM_ERR    (1<<(15-15))

/* Tx BD Flags */
#define SPI_UNDERRUN    (1<<(15-14))
#define SPI_TXMM_ERR    (1<<(15-15)) 

void SpiStopOp(SpiCfgStruct *pCfg)
{
    S_SPIModeReg &= (~(1L<<(15-7))); /* disable SPI */
}

void SpiStartOp(SpiCfgStruct *pCfg)    
{
    ULONG SpiParamBase;
    struct spi_pram *SpiParam;
    
    if(pCfg->UseUcode==1)
    {
       SpiParamBase=pCfg->UcodeAdress+S_DPRAM_BASE;
       SpiParam=(struct spi_pram *)SpiParamBase;
       SpiParam->rstate=0;
       SpiParam->rbptr=SpiParam->rbase;
       SpiParam->tstate=0;
       SpiParam->tbptr=SpiParam->tbase;
    }
    
    if(pCfg->UseUcode==0)
    {
		CPM_CMD(INIT_RX_PARAMS|SPI_CH_NUM);
		CPM_CMD(INIT_TX_PARAMS|SPI_CH_NUM);
    }

    S_SPIModeReg |= (1L<<(15-7)); /* enable SPI */
}

void SpiClearBuf(DataBufStruct *pData)
{
    int i;
    pData->CurRecvBD=pData->CurSendBD=0;     
    for(i=0;i<pData->MaxRecvBD;i++)
    pData->pBaseRecvBD[i].status = BD_EMPTY|BD_INTR;
    if(i>0)pData->pBaseRecvBD[i-1].status |= BD_WRAP;
    for(i=0;i<pData->MaxSendBD;i++)
    pData->pBaseSendBD[i].status = BD_INTR|BD_LAST;
    if(i>0)pData->pBaseSendBD[i-1].status |= BD_WRAP;
}

static void SpiIsr(void* pDataBuf)
{
    USHORT starBD,tempstate;
    USHORT Events = S_SPIEventReg;

    S_SPIEventReg = Events;
    if((Events & SPI_LACK_OF_BUF ) || (Events & SPI_RX_BUF))
    {
        ((DataBufStruct*)pDataBuf)->DrvInfo.TotalRecvInt++;
        if((((DataBufStruct*)pDataBuf)->RecvEv!=NULL)
            &&(((DataBufStruct*)pDataBuf)->RecvTid!=NULL) )
        {    
            ev_send(((DataBufStruct*)pDataBuf)->RecvTid,
                       ((DataBufStruct*)pDataBuf)->RecvEv);
        }
        if((((DataBufStruct*)pDataBuf)->RecvQID!=NULL))
        {    
            q_send(((DataBufStruct *)pDataBuf)->RecvQID,
                   ((DataBufStruct *)pDataBuf)->RecvMessage);
        }
    }
    if (Events & SPI_TX_BUF)
    {
        ((DataBufStruct*)pDataBuf)->DrvInfo.TotalSendInt++;
        if((((DataBufStruct*)pDataBuf)->SendEv!=NULL)
            &&(((DataBufStruct*)pDataBuf)->SendTid!=NULL) )
        {
            ev_send(((DataBufStruct*)pDataBuf)->SendTid,
                       ((DataBufStruct*)pDataBuf)->SendEv);
        }
        if((((DataBufStruct*)pDataBuf)->SendQID!=NULL))
        {    
            q_send(((DataBufStruct *)pDataBuf)->SendQID,
                   ((DataBufStruct *)pDataBuf)->SendMessage);
        }
    }
}/* End of SpiIsr */

void SpiInit(void *pDataBuf, SpiCfgStruct *cfg )
{
    int i,clkdiv;
    USHORT temp_ushort;
    BuffDescType   *temp_bufdes;
    char *pRecvBuf,*pSendBuf;
    PDA *pda= (PDA *)(GetIMMR() & IO_MAP_MASK);
    DataBufStruct*  pData=(DataBufStruct *)pDataBuf;
    SpiCfgStruct*   pCfg =(SpiCfgStruct *)(pData+1);
    int BrgClk=BspCpuClkRate()*1000000;
    ULONG SpiParamBase;
    struct spi_pram *SpiParam=NULL;


/*-------------------------<< Initial data >>-------------------------------*/
    memmove(pCfg,cfg,sizeof(*cfg));
    memset(pData, 0, sizeof(DataBufStruct));
    
    if(pCfg->UseUcode==1)                
    {
 
       SpiParamBase=pCfg->UcodeAdress+S_DPRAM_BASE;
       SpiParam=(struct spi_pram *)SpiParamBase;
     }
    else
       SpiParamBase=S_SPI_BASE;
    
    
    pCfg->ch=0;
    if( pCfg->BaudRate<(BrgClk/16/64))pCfg->BaudRate=(BrgClk/16/64);
    if( pCfg->BaudRate>(BrgClk/4))pCfg->BaudRate=(BrgClk/4);
    pData->MaxRecvBD=pCfg->MaxRecvBD;
    pData->MaxSendBD=pCfg->MaxSendBD;
    pData->MaxBufLen=pCfg->MaxBufLen;
    pData->RecvErrMask=(SPI_OVERRUN|SPI_RXMM_ERR);
    pData->SendErrMask=(SPI_UNDERRUN|SPI_TXMM_ERR);
    pData->UncachedBuffer=pRecvBuf=pCfg->UncachedBuffer;
    pSendBuf=(char*)(pRecvBuf+( pData->MaxRecvBD)*(pData->MaxBufLen));

/*-------------------------<< stop SCCx operation >>----------------------*/
    SpiStopOp(pCfg);
/*----------------------<< init SCCx >>-----------------------------------*/
    RxFunctionCode(SpiParamBase) = MOT + DMA_SPACE;
    TxFunctionCode(SpiParamBase) = MOT + DMA_SPACE; 
    MaxRxBufferLgth(SpiParamBase) = pData->MaxBufLen;
    
    /* rx */
    temp_ushort=(unsigned short)dpram_alloc(0,pData->MaxRecvBD*BD_LEN);
    if(temp_ushort==NULL)bsp_fatal(BSPF_DPRAM_ALLOC_ERR);
    RxBDBaseAddr(SpiParamBase) = temp_ushort-0X2000;
    temp_bufdes=pData->pBaseRecvBD=(BuffDescType *)((char *)pda + temp_ushort);
    for(i=0;i<pData->MaxRecvBD;i++)
    {
        temp_bufdes[i].status=BD_EMPTY|BD_INTR;
        temp_bufdes[i].length=0;
        temp_bufdes[i].address=pRecvBuf+i*pData->MaxBufLen;
    }
    if(i>0)temp_bufdes[i-1].status|=BD_WRAP;

    /* tx */
    temp_ushort=(unsigned short)dpram_alloc(0,pData->MaxSendBD*BD_LEN);
    if(temp_ushort==NULL)bsp_fatal(BSPF_DPRAM_ALLOC_ERR);
    TxBDBaseAddr(SpiParamBase) = temp_ushort-0X2000;
    temp_bufdes=pData->pBaseSendBD=(BuffDescType *)((char *)pda+temp_ushort);
    for(i=0;i<pData->MaxSendBD;i++)
    {
        temp_bufdes[i].status=BD_INTR|BD_LAST;
        temp_bufdes[i].length=pData->MaxBufLen;
        temp_bufdes[i].address=pSendBuf+i*pData->MaxBufLen;
    }
    if(i>0)temp_bufdes[i-1].status|=BD_WRAP;

    S_SDMA_ConfigReg = 1;
    S_SPIEventReg = 0xFF;
    S_SPIMaskReg = SPI_SPIE_BSY | SPI_SPIE_TXB | SPI_SPIE_RXB;
    SPLX(S_CP_IntMaskReg |= EN_SPI;)
    clkdiv = BrgClk/(pCfg->BaudRate*4) - 1;
    if(clkdiv >= 16 )
    {
        clkdiv=BrgClk/(16*pCfg->BaudRate*4) -1;
        S_SPIModeReg = 0x0f70 + clkdiv;       /*  CP=0, CI=0  */
    }
    else 
    {
        S_SPIModeReg = 0x0770 + clkdiv;       /*  CP=0, CI=0  */
    }
    SPLX(CpmIsrAddHandler(V_SPI, SpiIsr, (void*)pData);)
         
    if(pCfg->UseUcode==0)
       SpiStartOp(pCfg);
    else if(pCfg->UseUcode==1)
    {
      *( (USHORT*)(S_SPI_BASE+0x2c) )=pCfg->UcodeAdress;
      SpiParam->rstate=0;
      SpiParam->rbptr=SpiParam->rbase;
      SpiParam->tstate=0;
      SpiParam->tbptr=SpiParam->tbase;
      SpiStartOp(pCfg);
    }
}

int SpiRead(void *pDataBuf,void *pBuf, int MaxLen)         
{   
    return BDRead(pDataBuf,(char *)pBuf,MaxLen);
}

int SpiWrite(void *pDataBuf,void *pBuf, int MaxLen)         
{   
    int ret=BDWrite(pDataBuf,(char *)pBuf,MaxLen);
    if(ret>=0)S_SPICommandReg = BIT7;
    return ret;
}

int SpiCntrl(void *pDataBuf, int cmd, void *pParam, int maxlen)
{
    int i;
    ULONG temp_ulong;
    /*PDA *pda= (PDA *)(GetIMMR() & IO_MAP_MASK); */
    DataBufStruct *pData=(DataBufStruct *)pDataBuf;
    SpiCfgStruct*   pCfg =(SpiCfgStruct *)(pData+1);
    int BrgClk,clkdiv;
    int ret=BDCntrl(pDataBuf, cmd, pParam, maxlen);
    if(ret!=SDE_UNKNOW_CMD)return ret;
    switch(cmd)
    {
        case SDC_REINIT:
            SpiStopOp(pCfg);
            dpram_dealloc(0,(char*)pData->pBaseRecvBD,BD_LEN*pData->MaxRecvBD);
            dpram_dealloc(0,(char*)pData->pBaseSendBD,BD_LEN*pData->MaxSendBD);
            SpiInit(pDataBuf,pCfg);
            SpiStartOp(pCfg);          
            break;

        case SDC_SET_LOOPBACK_MODE:
            SpiStopOp(pCfg);
            SPLX(S_SPIModeReg |= (1L<<(15-1));)
            SpiClearBuf(pData);
            SpiStartOp(pCfg);          
            break;

        case SDC_SET_NORMAL_MODE:
            SpiStopOp(pCfg);
            SPLX(S_SPIModeReg &= ~(1L<<(15-1));)
            SpiClearBuf(pData);
            SpiStartOp(pCfg);          
            break;

        case SDC_SET_BAUDRATE:
            pCfg->BaudRate=*(int *)pParam;
            SpiStopOp(pCfg);
            BrgClk=BspCpuClkRate()*1000000;
            if( pCfg->BaudRate<(BrgClk/16/64))pCfg->BaudRate=(BrgClk/16/64);
            if( pCfg->BaudRate>(BrgClk/4))pCfg->BaudRate=(BrgClk/4);
            clkdiv = BrgClk/(pCfg->BaudRate*4) - 1;
            if(clkdiv >= 16 )
            {
                clkdiv=BrgClk/(16*pCfg->BaudRate*4) -1;
                S_SPIModeReg = 0x0f70 + clkdiv;      /*  CP=0, CI=0  */
            }
            else 
            {
                S_SPIModeReg = 0x0770 + clkdiv;      /*  CP=0, CI=0  */
            }
            SpiClearBuf(pData);
            SpiStartOp(pCfg);          
            break;
            
        default: 
            return SDE_UNKNOW_CMD;

    }/* end of switch(cmd) */
    return SDE_OK;
}

char *SpiBspInit(int DEV, char *FreeMemPtr, SpiCfgStruct *cfg)
{
    cfg->UncachedBuffer
        =AllocUncachedBuffer((cfg->MaxRecvBD+cfg->MaxSendBD)*cfg->MaxBufLen,4);
    InstallSD(DEV,SpiRead,SpiWrite,SpiCntrl,FreeMemPtr);
    SpiInit(FreeMemPtr, cfg); 
    FreeMemPtr += sizeof(DataBufStruct)+sizeof(SpiCfgStruct);
    memcpy(FreeMemPtr,"**SpiDat",8);
    FreeMemPtr += 8;
    return FreeMemPtr;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美中文字幕一区二区三区| 欧美一区二区三区在线电影| 国产精品免费av| 国产真实精品久久二三区| 日韩精品中文字幕在线不卡尤物| 婷婷久久综合九色综合绿巨人| 欧美在线999| 一个色在线综合| 欧美最猛黑人xxxxx猛交| 亚洲午夜一区二区三区| 欧美日韩精品综合在线| 亚洲不卡av一区二区三区| 欧美日韩国产高清一区二区三区 | 日韩电影免费在线| 欧美日本一区二区在线观看| 五月天激情小说综合| 欧美精品三级日韩久久| 秋霞午夜av一区二区三区| 欧美成人女星排名| 国产综合色产在线精品| 国产午夜精品久久久久久免费视 | 国产精品美女久久福利网站| 成人小视频免费观看| 国产精品第一页第二页第三页| 97se亚洲国产综合自在线| 一区二区三区精品在线| 欧美日韩免费观看一区三区| 日日夜夜免费精品| 精品久久久久一区二区国产| 国产伦理精品不卡| 中文字幕一区二区视频| 91久久香蕉国产日韩欧美9色| 亚洲一区二区av在线| 欧美一区在线视频| 国产永久精品大片wwwapp| 欧美激情一二三区| 在线亚洲一区观看| 美女mm1313爽爽久久久蜜臀| 国产日韩欧美不卡| 在线观看网站黄不卡| 日韩在线卡一卡二| 久久精品人人做人人爽人人| 91丨九色porny丨蝌蚪| 亚洲成人av福利| 精品日韩在线观看| av在线播放成人| 午夜精品一区在线观看| 久久综合国产精品| 91在线免费播放| 天天免费综合色| 久久午夜免费电影| 色综合天天综合给合国产| 舔着乳尖日韩一区| 久久精品一区二区三区四区| 99精品国产91久久久久久| 午夜久久久久久久久久一区二区| 精品国产亚洲一区二区三区在线观看| 成人永久免费视频| 亚洲va欧美va天堂v国产综合| 精品日韩av一区二区| 99精品热视频| 麻豆91在线播放| 最近日韩中文字幕| 日韩亚洲欧美中文三级| 9色porny自拍视频一区二区| 日韩成人免费电影| 国产精品久久777777| 欧美色图在线观看| 国产高清视频一区| 亚洲超碰精品一区二区| 欧美国产成人精品| 制服丝袜亚洲播放| 9色porny自拍视频一区二区| 免费观看在线综合| 亚洲美女屁股眼交| 久久这里只精品最新地址| 91久久精品一区二区三| 国产精品69久久久久水密桃| 亚洲成年人网站在线观看| 欧美激情一区二区三区全黄 | 色激情天天射综合网| 国内成+人亚洲+欧美+综合在线| 亚洲精品欧美综合四区| 久久色成人在线| 欧美日韩国产高清一区二区| 暴力调教一区二区三区| 久久99精品国产| 亚洲成在人线在线播放| 最新国产精品久久精品| 精品国产区一区| 欧美日韩国产高清一区| 91免费观看国产| 国产精品88av| 精品一区二区三区免费观看| 亚洲成av人片在www色猫咪| |精品福利一区二区三区| 久久精品欧美一区二区三区不卡| 欧美日韩精品一区视频| 色婷婷综合久久久中文一区二区| 国产91精品久久久久久久网曝门 | 秋霞av亚洲一区二区三| 亚洲影院理伦片| 亚洲色图19p| 亚洲国产精品ⅴa在线观看| 久久综合色天天久久综合图片| 在线播放欧美女士性生活| 在线免费观看日本欧美| 99久久综合色| 成人精品一区二区三区四区 | 91精品国产欧美一区二区成人| 91蝌蚪porny九色| 成人午夜在线免费| 国产米奇在线777精品观看| 老司机精品视频一区二区三区| 午夜电影网一区| 亚洲444eee在线观看| 亚洲图片欧美综合| 亚洲欧美日韩国产中文在线| 中文字幕一区二区三区精华液| 国产三级精品三级在线专区| 久久精品男人天堂av| 欧美精品一区二区高清在线观看| 欧美日韩成人一区| 欧美伦理电影网| 91精品国模一区二区三区| 欧美挠脚心视频网站| 9191久久久久久久久久久| 欧美日韩国产区一| 这里只有精品电影| 日韩视频永久免费| 日韩欧美你懂的| 欧美精品一区二区蜜臀亚洲| 久久这里只有精品6| 久久精品亚洲麻豆av一区二区| 国产亚洲女人久久久久毛片| 久久久久久久久久久久久久久99 | 91亚洲精品一区二区乱码| 99精品国产91久久久久久 | 91免费精品国自产拍在线不卡| 99久久久国产精品免费蜜臀| 91碰在线视频| 在线视频国产一区| 欧美男男青年gay1069videost | 日韩精品中文字幕一区二区三区| 精品三级在线看| 国产区在线观看成人精品| 国产精品理论片| 一区二区三区鲁丝不卡| 亚洲成人激情av| 另类小说综合欧美亚洲| 国产99久久久国产精品潘金 | 91精品国产品国语在线不卡| 欧美变态口味重另类| 国产日韩欧美精品综合| 亚洲视频一区二区免费在线观看| 亚洲一区二区三区美女| 日韩成人精品在线| 国产精品69毛片高清亚洲| 99久久99久久免费精品蜜臀| 欧美亚一区二区| 日韩精品一区二区在线观看| 国产人成亚洲第一网站在线播放 | 亚洲欧美另类小说| 日日摸夜夜添夜夜添国产精品 | 日韩三级视频中文字幕| 国产欧美一区二区在线| 一区二区三区在线观看国产| 丝袜美腿亚洲色图| 国产一区在线精品| 91免费观看国产| 日韩午夜在线观看| 国产精品少妇自拍| 午夜欧美大尺度福利影院在线看| 国产资源在线一区| aaa亚洲精品一二三区| 欧美丰满少妇xxxbbb| 国产日韩欧美精品电影三级在线| 亚洲免费在线电影| 免费观看一级特黄欧美大片| 成人av免费在线观看| 欧美精品三级日韩久久| 国产日韩欧美精品在线| 亚洲第一电影网| 高清久久久久久| 欧美精品亚洲一区二区在线播放| 久久精品人人做人人爽97| 亚洲国产另类精品专区| 国产河南妇女毛片精品久久久| 欧洲精品在线观看| 久久九九99视频| 亚洲国产乱码最新视频| 国产成人午夜电影网| 欧美高清精品3d| 中文字幕中文字幕在线一区| 日韩黄色一级片| www.欧美日韩国产在线| 欧美变态口味重另类| 亚洲精品成人在线| 国产又黄又大久久| 欧美巨大另类极品videosbest |