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

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

?? vportdis.c

?? DSP DM642 視頻端口顯示驅動程序
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*
 *  Copyright 2004 by Texas Instruments Incorporated.
 *  All rights reserved. Property of Texas Instruments Incorporated.
 *  Restricted rights to use, duplicate or disclose this code are
 *  granted through contract.
 *  
 */

/* 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;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
高潮精品一区videoshd| 在线视频欧美区| 欧美日韩亚州综合| 国产亚洲欧洲一区高清在线观看| 亚洲男女一区二区三区| 国产精品一二三四五| 欧美精品丝袜中出| 夜夜嗨av一区二区三区网页| 国产二区国产一区在线观看| 日韩一级欧美一级| 亚洲午夜三级在线| 99re在线视频这里只有精品| 精品电影一区二区三区| 日本美女一区二区三区视频| 欧美丝袜丝交足nylons| 亚洲人成亚洲人成在线观看图片| 国产成人在线看| 精品国产凹凸成av人导航| 爽好久久久欧美精品| 精品视频在线视频| 一区二区三区免费| 91蝌蚪porny九色| 亚洲视频你懂的| 北条麻妃国产九九精品视频| 欧美国产欧美综合| 成人在线一区二区三区| 国产欧美一区视频| 国产成人8x视频一区二区| 久久久美女艺术照精彩视频福利播放| 日韩av中文字幕一区二区| 51精品视频一区二区三区| 日韩电影在线一区| 日韩一级视频免费观看在线| 理论片日本一区| 精品福利一区二区三区免费视频| 精品无人码麻豆乱码1区2区| 欧美va亚洲va香蕉在线| 久久66热偷产精品| 久久久91精品国产一区二区精品 | 国产一区二区0| 欧美成人欧美edvon| 国产真实乱对白精彩久久| 国产亚洲一区二区三区四区| jlzzjlzz亚洲日本少妇| 亚洲精品视频在线观看免费| 欧美日韩三级一区| 日韩 欧美一区二区三区| 精品国产青草久久久久福利| 国产v日产∨综合v精品视频| 中文字幕亚洲一区二区va在线| 99精品在线观看视频| 亚洲午夜激情av| 欧美一区二区久久久| 国产美女在线精品| 亚洲欧美日本韩国| 7777精品久久久大香线蕉| 韩日av一区二区| 亚洲欧美综合网| 91精品国产综合久久精品麻豆| 久久99久久99小草精品免视看| 国产日韩一级二级三级| 色综合久久综合网欧美综合网| 午夜久久久久久久久| 精品av久久707| 91美女福利视频| 精品一区二区综合| 亚洲男人天堂av网| 精品久久久久久久久久久久包黑料 | 《视频一区视频二区| 欧美日韩在线播放一区| 国产一区二区剧情av在线| 一区二区三区四区视频精品免费| 日韩欧美一级二级| 色成年激情久久综合| 久久99久久99| 天天综合天天综合色| 欧美激情一区二区三区蜜桃视频| 欧美丝袜第三区| 99久久精品99国产精品| 轻轻草成人在线| 亚洲激情校园春色| 国产日韩亚洲欧美综合| 717成人午夜免费福利电影| jvid福利写真一区二区三区| 激情伊人五月天久久综合| 一区二区免费视频| 亚洲国产精品二十页| 日韩欧美国产一区二区在线播放| 欧美主播一区二区三区| 成人国产视频在线观看| 久久激五月天综合精品| 午夜精品一区二区三区电影天堂| 国产精品福利av| 欧美一区二区三区精品| 91尤物视频在线观看| 风流少妇一区二区| 亚洲午夜羞羞片| 国产精品女主播av| www日韩大片| 亚洲欧美一区二区久久| 日韩欧美一区在线观看| 美女脱光内衣内裤视频久久影院| 亚洲第一福利一区| 久久精品国产亚洲5555| 成人网在线播放| 欧美在线影院一区二区| 日韩免费成人网| 国产精品欧美一区二区三区| 亚洲香蕉伊在人在线观| 麻豆精品久久精品色综合| caoporen国产精品视频| 91极品视觉盛宴| 久久综合色婷婷| 亚洲免费av高清| 精品一区二区在线看| 99国产欧美久久久精品| 日韩三级免费观看| 亚洲视频在线观看一区| 精品一区二区在线免费观看| 一本大道久久精品懂色aⅴ| 日韩欧美一区中文| 一区二区三区精品视频在线| 九色综合国产一区二区三区| 色综合久久久久综合体| 精品福利二区三区| 亚洲韩国一区二区三区| 国产91在线观看| 制服丝袜成人动漫| 亚洲婷婷综合色高清在线| 美腿丝袜亚洲三区| 在线一区二区视频| 国产人成一区二区三区影院| 日韩高清欧美激情| 色天天综合久久久久综合片| 久久久电影一区二区三区| 全部av―极品视觉盛宴亚洲| 欧美自拍丝袜亚洲| 国产精品久久久久久久久果冻传媒| 免费黄网站欧美| 欧美人xxxx| 日韩理论在线观看| 国产成人h网站| 日韩欧美在线一区二区三区| 亚洲午夜三级在线| 91美女福利视频| 国产精品视频看| 国产在线麻豆精品观看| 91 com成人网| 亚洲高清免费视频| 在线观看亚洲一区| 亚洲精品高清视频在线观看| 国产成人综合网站| 精品91自产拍在线观看一区| 三级一区在线视频先锋 | 麻豆91精品91久久久的内涵| 欧美性大战xxxxx久久久| 国产精品动漫网站| 成人午夜电影小说| 国产欧美日韩在线视频| 国产一区999| 久久伊人中文字幕| 国产一区二区三区免费观看| 精品日韩在线观看| 精品一区二区在线看| 精品久久久久久久久久久久久久久久久| 日韩不卡一二三区| 欧美一区二区三区播放老司机 | 青青国产91久久久久久| 欧美日韩一区二区在线视频| 亚洲精品自拍动漫在线| 91久久精品一区二区三区| 一区二区三区在线观看网站| 99精品在线免费| 亚洲综合视频网| 在线成人午夜影院| 麻豆精品在线播放| 久久久久久久综合日本| 国产福利精品一区| 国产精品的网站| 91网上在线视频| 亚洲午夜私人影院| 欧美一区二区三区视频在线| 热久久一区二区| 国产清纯白嫩初高生在线观看91 | 狠狠狠色丁香婷婷综合激情| 国产欧美日韩三级| 91在线看国产| 婷婷国产在线综合| www国产精品av| 99久久99久久综合| 午夜精品久久久久久久99樱桃| 欧美一级片免费看| 国产999精品久久| 一区二区三区电影在线播| 欧美一区二区三区爱爱| 高清成人免费视频| 亚洲成av人综合在线观看| www日韩大片| 一本色道a无线码一区v| 日韩av电影天堂|