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

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

?? vportdis.c

?? DM642上用的TH8200采集芯片的配套驅動
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* DSP/BIOS standard include files */
#include <std.h>
#include <mem.h>
#include <que.h>    
#include <tsk.h>

/* Chip-support library include files */
#include <csl.h>
#include <csl_edma.h>
#include <csl_vphal.h>         
#include <csl_irq.h>

/* IOM/GIO driver model include files */
#include <iom.h>
#include <fvid.h>                       

/* video driver specif-ic include files */
#include <vport.h>
#include <vportdis.h>
#include <edc.h>
#include "_vport.h"

/* debug include files */
/* to minimize code size and cycle count overhead of the driver */             
/* error checking is only performed at debug time               */
#include <assert.h>


/* mini-driver API functions */
static Int mdBindDev(Ptr *devp, Int devid, Ptr devParams);
static Int mdControlChan(Ptr chanp, Uns cmd, Ptr args);
static Int mdCreateChan(Ptr *chanp, Ptr devp, String name, Int mode,
        Ptr chanParams, IOM_TiomCallback cbFxn, Ptr cbArg);
static Int mdDeleteChan(Ptr chanp);
static Int mdSubmitChan(Ptr chanp, IOM_Packet *packet);


/* local functions */
static Int _configChan(Ptr chanp, Ptr args);
static Int _configEDMA(Ptr chanp, VPORTDIS_Params *params);
static Int _configPort(Ptr chanp, Ptr args);
static Int _configRegs(Ptr chanp, VPORTDIS_Params *params);
static void displayEdmaISR(Int tcc);
static void displayISR(int portNum);
static Int _displayStart(Ptr chanp);
static Int _displayStop(Ptr chanp);
static Int _dundRecover(Ptr chanp);
static Int _setVIntCb(Ptr chanp, Ptr args);


/* global and static variables */
IOM_Fxns VPORTDIS_Fxns = {
	mdBindDev,    
	(IOM_TmdUnBindDev)IOM_mdNotImpl,
	mdControlChan,
	mdCreateChan,
	mdDeleteChan,
	mdSubmitChan
};

/**************************************************************
 * Static allocation and initialization of port objects       *
 * as display supports only 1 channel, the same channel       *
 * object for capture is used here for the whoel port         *
 **************************************************************/
_VPORT_ChanObj chanObjs[_VP_PORT_CNT] = {
    {0, 0, 0, _VP_BASE_PORT0, EDMA_CHA_VP0EVTYA, EDMA_CHA_VP0EVTUA, 
        EDMA_CHA_VP0EVTVA, _VP_YDSTA0_ADDR, _VP_CBDST0_ADDR, _VP_CRDST0_ADDR}, 
    {0, 1, 0, _VP_BASE_PORT1, EDMA_CHA_VP1EVTYA, EDMA_CHA_VP1EVTUA, 
        EDMA_CHA_VP1EVTVA,  _VP_YDSTA1_ADDR, _VP_CBDST1_ADDR, _VP_CRDST1_ADDR}, 
    {0, 2, 0, _VP_BASE_PORT2, EDMA_CHA_VP2EVTYA, EDMA_CHA_VP2EVTUA, 
        EDMA_CHA_VP2EVTVA, _VP_YDSTA2_ADDR, _VP_CBDST2_ADDR, _VP_CRDST2_ADDR },
};     



/*
 *  ======== mdBindDev ========
 *  Register all external devices to video port display driver 
 */
static Int mdBindDev(Ptr *devp, Int devid, Ptr devParams)
{
   Int portNum = devid;
   volatile Int i;
   volatile Int* base = (volatile Int *)chanObjs[portNum].base;                       
   
   
   assert(portNum < _VP_PORT_CNT);
   base[_VP_VPCTL_OFFSET] = 
             VP_VPCTL_VPRST_RESET << _VP_VPCTL_VPRST_SHIFT;
   for(i = 0; i < 100000; i ++);      
    *devp = &chanObjs[portNum];                                                                                           
   return mdControlChan(&chanObjs[portNum], 
           VPORT_CMD_CONFIG_PORT, devParams);
}


/*
 *  ======== mdControlChan ========
 */
static Int mdControlChan(Ptr chanp, Uns cmd, Ptr args)
{
    Int retVal = IOM_COMPLETED;
    _VPORT_ChanObj* chan = (_VPORT_ChanObj *)chanp;
    
    /* command dispatcher */
    switch (cmd){
        case VPORT_CMD_START:
        retVal = _displayStart(chanp);
        break;
        case VPORT_CMD_STOP:
        retVal = _displayStop(chanp);
        break;
        case VPORT_CMD_CONFIG_CHAN:
        retVal = _configChan(chanp, args);
        break;
        
        case VPORT_CMD_SET_VINTCB:
        _setVIntCb(chanp, args);
        break;
        case VPORT_CMD_DUND_RECOVER:
        retVal = _dundRecover(chanp);
        break;
        case VPORT_CMD_CONFIG_PORT:
        retVal = _configPort(chanp, args);
        break;
        default:
        if(chan->edcFxns!=INV) {
            retVal =  chan->edcFxns->ctrl(chan->edcHandle, 
                cmd-VPORT_CMD_EDC_BASE,(Arg)args);
        }else {
            retVal = IOM_ENOTIMPL;
        }
   }    
   return retVal;
}              


/*
 *  ======== mdCreateChan ========
 *  create a channel
 */
static Int  mdCreateChan(Ptr *chanp, Ptr devp, String name, Int mode,
              Ptr chanParams, IOM_TiomCallback cbFxn, Ptr cbArg)
{
    _VPORT_ChanObj* chan;
    Int retVal = IOM_COMPLETED;   
    Int j;     

    if(mode != IOM_OUTPUT){
        return IOM_EBADARGS;
    }
    
    chan = (_VPORT_ChanObj *)devp;
    if(chan->edcFxns != INV) {
        /* open external device */
        chan->edcHandle 
           = chan->edcFxns->open(name, (Arg)INV);
    } 
    if(! (chan->status & _VPORT_OPENED)) {
        chan->status |= _VPORT_OPENED;
        
        chan->vIntMask = 0;
        QUE_new(&chan->qIn);
        QUE_new(&chan->qOut);
        chan->cbFxn = cbFxn;
        chan->vIntFxn = (VPORT_IntCallBack)INV;
        chan->queEmpty = FALSE;   
        chan->cbArg = (Arg)cbArg;
        chan->packetIOM = INV;     
        chan->vIntCbArg = (Int)INV;        
        chan->bufSz = 0;
        for(j = 0; j < _VPORT_NUM_EDMA_CHANS 
          && retVal == IOM_COMPLETED; j ++ ) {
            if((chan->hEdma[j] = 
             EDMA_open(chan->edmaChanNum[j], EDMA_OPEN_RESET)) == EDMA_HINV
             || (chan->hRld[2 * j] = EDMA_allocTable(-1)) == EDMA_HINV 
             || (chan->hRld[2 * j + 1] =EDMA_allocTable(-1)) == EDMA_HINV 
             || (chan->tcc[j] = EDMA_intAlloc(chan->edmaChanNum[j])) == -1){
                retVal = IOM_EALLOC;
            }/* if((chan->...*/ 
        }/* for(j = 0; j < NUM_EDMA_CHANS; j++) {...*/
        /* if EDMAs are not allocated successfully, */
        /* delete the channel just created          */
        if(retVal == IOM_COMPLETED && (void *)chanParams != INV) {
            retVal = mdControlChan(chan, VPORT_CMD_CONFIG_CHAN, chanParams); 
        }
        if(! retVal) {
             /* configure the channel */
             *chanp = chan;
        }else {
            mdDeleteChan(chan);
            *chanp = INV;
        }               
    } /*if(!chan->opened) */
    return retVal;
}               

/*
 *  ======== mdDeleteChan ========
 *  delete the channel
 */

static Int  mdDeleteChan(Ptr chanp)
{
    _VPORT_ChanObj* chan = (_VPORT_ChanObj* )chanp;
    Int j;
    volatile Int* base;
    
    if(chan->status & _VPORT_OPENED) {
        chan->status = 0;
        mdControlChan(chanp, VPORT_CMD_STOP, NULL);
        for(j = 0; j < _VPORT_NUM_EDMA_CHANS; j ++) {
            EDMA_close(chan->hEdma[j]);
            EDMA_freeTable(chan->hRld[2 * j]);
            EDMA_freeTable(chan->hRld[2 * j + 1]);
            EDMA_intFree(chan->tcc[j]);
        }      
        for(j = 0; j < chan->numFrms ; j ++) {
            MEM_free(chan->segId, chan->viops[j].frame.iFrm.y1, chan->bufSz);
        }        
        
        base = (volatile Int *)chan->base;
        /* reset display */
        base[_VP_VDCTL_OFFSET] |= 
            VP_VDCTL_RSTCH_RESET << _VP_VDCTL_RSTCH_SHIFT;
        /* reset video port */
        base[_VP_VPCTL_OFFSET] |= 
            VP_VPCTL_VPRST_RESET << _VP_VPCTL_VPRST_SHIFT;
        
        chan->status = 0;
        /* close external device */
        if(chan->edcFxns != INV) {
            chan->edcFxns->close(chan->edcHandle);
        }
        
    }    
    return IOM_COMPLETED;
}


/*
 *  ======== mdSubmitChan ========
 */
static Int  mdSubmitChan(Ptr chanp, IOM_Packet *packet)
{

    _VPORT_ChanObj* chan = (_VPORT_ChanObj *)chanp;
    FVID_Frame* viop;                             
    Int retVal = IOM_PENDING;
    Uint32 gie = IRQ_globalDisable();     
    
    
    if(packet->cmd != FVID_ALLOC) {/* FVID_FREE or FVID_EXCHANGE */
        viop = *(void **)packet->addr; /* pointer of a video I/O packet */
        if(chan->queEmpty) {
            /* don't put it into queue, update the rld register directly */
            chan->queEmpty = FALSE;                   
        }
        QUE_enqueue(&chan->qIn, (QUE_Handle)viop);        
        retVal = packet->status = IOM_COMPLETED;
    }
    if(packet->cmd != FVID_FREE) { /* FVID_ALLOC or FVID_EXCHANGE */
        if(chan->packetIOM == INV){
            if((viop = (FVID_Frame *)QUE_dequeue(&chan->qOut))
                !=(FVID_Frame *)&chan->qOut) {
                /* only when there is no outstanding pending request */
                *(void **)packet->addr = (void *)viop;
                packet->size = sizeof(FVID_Frame);
                retVal = packet->status = IOM_COMPLETED;
            }
            else {
                chan->packetIOM = packet;
                retVal = packet->status = IOM_PENDING;
            }
        }else retVal = IOM_EINUSE;    
                    
    }    
    IRQ_globalRestore(gie);
    return retVal;
}


/*
 *  ========  _configChan ========
 */
static Int _configChan(Ptr chanp, Ptr args)
{
    _VPORT_ChanObj* chan = (_VPORT_ChanObj *)chanp;
    VPORTDIS_Params*   params = (VPORTDIS_Params* )args; 
    Int retVal;           
    
    
    if(!(chan->status & _VPORT_CFGED)) {
        /* configure video port channel A/B control register */
        _configRegs(chanp, params);
        /* configure EDMA and frame buffer */
        retVal = _configEDMA(chanp, params);
    } else {
        retVal = IOM_EINUSE;
    }    
    return retVal;
}                     


/*
 *  ======== _configEDMA ========
 */
static Int _configEDMA(Ptr chanp, VPORTDIS_Params *params)
{
    _VPORT_ChanObj* chan = (_VPORT_ChanObj *)chanp;
    Int i;
    EDMA_Config  cfgEdma;
    Int thrld;
    Int edmaChans;
    Int8* curAddr;
    
    if(chan->status & _VPORT_CFGED) {
        assert(params->numFrmBufs  >= 2 
            && params->numFrmBufs <= VPORT_MAX_NUM_FRMBUFS);
        chan->numFrms = params->numFrmBufs;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人在线看| 亚洲图片欧美视频| 精品美女在线播放| 日韩一区二区不卡| 欧美一区二区福利在线| 欧美日韩一二区| 欧美军同video69gay| 91.麻豆视频| 日韩一级免费观看| 国产三级久久久| 自拍偷拍欧美精品| 一区二区三区成人| 石原莉奈一区二区三区在线观看| 亚洲精品国产第一综合99久久 | 成人激情开心网| 成人做爰69片免费看网站| 国产成人超碰人人澡人人澡| 高清久久久久久| 97精品电影院| 欧美日韩大陆一区二区| 51午夜精品国产| 久久人人97超碰com| 国产精品欧美久久久久无广告 | 成人午夜看片网址| 色婷婷综合久久久中文字幕| 欧美日韩中文字幕一区二区| 日韩一区二区免费在线观看| 国产精品免费视频观看| 亚洲国产精品综合小说图片区| 美国十次了思思久久精品导航| 国产成人精品www牛牛影视| 91久久一区二区| 欧美大片在线观看一区二区| 国产精品久久看| 香蕉久久一区二区不卡无毒影院| 国产一区亚洲一区| 色94色欧美sute亚洲13| xvideos.蜜桃一区二区| 中文字幕一区二区不卡| 日产国产高清一区二区三区| 成人成人成人在线视频| 欧美一区二区女人| 日韩伦理电影网| 国内精品国产三级国产a久久| 色欧美88888久久久久久影院| 日韩欧美美女一区二区三区| 一区二区三区中文在线| 国产成人丝袜美腿| 欧美群妇大交群中文字幕| 国产精品毛片久久久久久| 免费在线观看日韩欧美| 色噜噜狠狠色综合欧洲selulu| 精品女同一区二区| 天天综合天天综合色| 99re这里只有精品视频首页| 久久精品无码一区二区三区| 丝袜美腿高跟呻吟高潮一区| 一本色道久久加勒比精品| 国产女同性恋一区二区| 韩国三级电影一区二区| 在线综合+亚洲+欧美中文字幕| 亚洲免费电影在线| av电影天堂一区二区在线| 久久久777精品电影网影网 | 欧美在线观看视频一区二区三区| 久久精品夜色噜噜亚洲a∨| 日本不卡123| 欧美乱妇一区二区三区不卡视频| 亚洲精品视频在线看| 99久久夜色精品国产网站| 国产欧美一区二区精品秋霞影院| 久久99久国产精品黄毛片色诱| 欧美电影一区二区| 日韩电影网1区2区| 91精品国产手机| 日韩二区三区四区| 日韩三级av在线播放| 天堂在线一区二区| 欧美一卡2卡3卡4卡| 蜜臀av一级做a爰片久久| 欧美一区二区三区在线电影| 日本在线不卡视频| 日韩视频一区二区三区| 精品在线播放免费| 久久久久99精品一区| 国产成人免费在线视频| 国产欧美精品日韩区二区麻豆天美| 国产成人精品免费视频网站| 欧美国产精品中文字幕| 色综合久久综合| 亚洲成年人网站在线观看| 欧美妇女性影城| 激情小说欧美图片| 国产精品色哟哟| 在线精品视频一区二区三四| 午夜精品福利一区二区蜜股av| 欧美一区二区三区思思人| 久久精品二区亚洲w码| 国产日产精品一区| 一道本成人在线| 日韩二区三区四区| 日本一区免费视频| 欧美日免费三级在线| 国产在线麻豆精品观看| 中文字幕佐山爱一区二区免费| 欧美日韩国产一级| 国产乱码精品一区二区三区av| 亚洲国产激情av| 欧美日韩精品专区| 国产91对白在线观看九色| 一区二区三区美女视频| 欧美va亚洲va| 99精品久久久久久| 青青草国产精品亚洲专区无| 亚洲欧美一区二区久久 | 欧美岛国在线观看| 成人短视频下载| 精品影视av免费| 亚洲码国产岛国毛片在线| 日韩精品中文字幕在线不卡尤物| 成人午夜电影久久影院| 午夜亚洲福利老司机| 日本一区二区三区免费乱视频| 欧美二区乱c少妇| 99久久99精品久久久久久| 蜜桃视频在线一区| 一区二区三区在线观看网站| 久久综合久久综合久久| 欧美视频一区二| 成人激情文学综合网| 精品无码三级在线观看视频| 亚洲尤物视频在线| 中文字幕亚洲在| 精品国产精品网麻豆系列| 欧美日本视频在线| 在线免费观看日韩欧美| 国产99久久久久久免费看农村| 日韩电影免费在线| 午夜精品免费在线观看| 亚洲麻豆国产自偷在线| 1000部国产精品成人观看| 久久久久久久久久久电影| 日韩精品一区二区在线观看| 欧美午夜在线一二页| 在线精品亚洲一区二区不卡| 97超碰欧美中文字幕| 成人免费va视频| 国产乱色国产精品免费视频| 精品一区二区三区免费视频| 视频一区二区国产| 日本欧美在线观看| 亚洲成av人片一区二区梦乃| 亚洲欧美成aⅴ人在线观看 | 一区二区三区在线播放| 国产精品私人影院| 国产精品第五页| 国产精品国产精品国产专区不蜜 | 欧美日韩一区精品| 欧美主播一区二区三区| 欧美在线观看禁18| 欧美蜜桃一区二区三区| 91麻豆精品国产91久久久久久 | 久久综合久久99| 久久婷婷综合激情| 日本一区二区动态图| 国产精品伦理在线| 亚洲国产你懂的| 日本在线不卡一区| 国产老妇另类xxxxx| 成人精品小蝌蚪| 一本色道久久综合亚洲aⅴ蜜桃| 欧美综合在线视频| 欧美一级电影网站| 国产亚洲欧美一级| 一色屋精品亚洲香蕉网站| 亚洲午夜久久久久久久久久久| 丝袜亚洲另类欧美| 国产精品亚洲视频| 色综合中文字幕| 欧美日本一区二区| 国产午夜精品在线观看| 亚洲精品一二三四区| 美女一区二区视频| av一区二区三区| 6080亚洲精品一区二区| 国产亚洲人成网站| 亚洲乱码国产乱码精品精可以看| 亚洲gay无套男同| 国产伦精品一区二区三区免费| av不卡在线播放| 7777精品伊人久久久大香线蕉超级流畅| 91超碰这里只有精品国产| 国产欧美日韩视频一区二区| 亚洲精品国产视频| 国产精品综合网| 欧美亚洲高清一区二区三区不卡| 精品国产一区二区亚洲人成毛片| 国产精品久久久99| 精品制服美女丁香| 欧美日韩中文字幕精品|