亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
亚洲第一会所有码转帖| 玉米视频成人免费看| av电影在线观看不卡| 亚洲一区二区影院| 久久久噜噜噜久久人人看 | 欧美性xxxxxx少妇| 紧缚捆绑精品一区二区| 亚洲成人自拍偷拍| 国产精品乱人伦| 日韩一区二区三区三四区视频在线观看 | 欧美日产在线观看| 成人动漫一区二区| 国产乱子伦一区二区三区国色天香| 亚洲色图在线播放| 久久久久久久电影| 欧美剧情片在线观看| 91麻豆精品视频| 国产精品自拍毛片| 热久久国产精品| 偷拍自拍另类欧美| 亚洲一区二区欧美| 亚洲一区中文日韩| 一区二区中文字幕在线| 久久久亚洲国产美女国产盗摄| 在线不卡免费欧美| 欧美怡红院视频| 色吊一区二区三区| 91蜜桃在线免费视频| 不卡一二三区首页| 波多野结衣中文一区| 丁香婷婷综合色啪| 国产很黄免费观看久久| 九色|91porny| 免费在线看成人av| 免费av成人在线| 捆绑调教一区二区三区| 日韩电影一区二区三区| 天堂久久久久va久久久久| 亚洲综合精品久久| 亚洲午夜精品在线| 亚洲愉拍自拍另类高清精品| 亚洲影视在线播放| 亚洲午夜影视影院在线观看| 亚洲综合偷拍欧美一区色| 亚洲免费在线视频| 亚洲综合小说图片| 天堂av在线一区| 青青青伊人色综合久久| 奇米影视一区二区三区小说| 免费成人你懂的| 国内不卡的二区三区中文字幕| 国产一区在线精品| 国产盗摄女厕一区二区三区| 丰满放荡岳乱妇91ww| 成人app下载| 色伊人久久综合中文字幕| 欧美最新大片在线看 | 精品国产精品网麻豆系列| 日韩欧美国产麻豆| 国产午夜精品久久| 亚洲女同一区二区| 亚洲成人www| 精品一区二区久久久| 国产成人综合在线观看| aaa欧美日韩| 欧美怡红院视频| 精品精品欲导航| 国产精品免费网站在线观看| 亚洲精品伦理在线| 免费一级片91| 国产.精品.日韩.另类.中文.在线.播放| 成人精品高清在线| 欧美日韩亚洲综合一区| 精品日产卡一卡二卡麻豆| 国产精品久久久久久久蜜臀| 亚洲一区二区三区四区五区中文 | 91小宝寻花一区二区三区| 欧美亚洲高清一区| 精品国产凹凸成av人导航| 国产精品美女一区二区| 日韩黄色小视频| 国产成人激情av| 欧美日韩激情在线| 日本一区二区三区高清不卡| 亚洲永久精品国产| 国产高清久久久| 欧美喷潮久久久xxxxx| 国产欧美精品一区aⅴ影院| 一区二区三区免费| 国产成人亚洲综合色影视| 欧美性大战久久久久久久蜜臀| 精品国内片67194| 亚洲韩国精品一区| 大尺度一区二区| 欧美一区二区三区免费视频| 中文字幕欧美一| 美女任你摸久久 | 久久一二三国产| 亚洲国产综合色| 成人精品视频一区二区三区| 欧美日韩夫妻久久| 日韩毛片视频在线看| 国产一区二区三区免费| 欧美日韩在线精品一区二区三区激情| 久久免费午夜影院| 久久精品72免费观看| 欧美主播一区二区三区| 亚洲国产高清在线| 国产综合久久久久影院| 欧美日韩高清一区二区三区| 亚洲人成精品久久久久久| 国产一区二区看久久| 91精品国产入口在线| 亚洲一区中文日韩| 91视频在线看| 中文字幕成人在线观看| 蜜桃视频在线观看一区二区| 91国产免费观看| 亚洲欧洲精品一区二区精品久久久| 国产成人亚洲综合色影视| 久久午夜羞羞影院免费观看| 日韩影视精彩在线| 欧美亚洲一区三区| 一区二区三区影院| 色悠悠亚洲一区二区| 国产精品成人网| 国产99久久久国产精品潘金网站| 亚洲精品在线免费播放| 麻豆国产欧美一区二区三区| 91麻豆精品国产91久久久久久久久 | 欧美日韩午夜在线| 亚洲一区在线观看网站| 色综合久久久久久久久| 亚洲欧洲日韩av| 成人av资源在线观看| 国产精品久久久一本精品| 国产成人综合视频| 中文字幕成人在线观看| 99在线视频精品| 中文字幕五月欧美| 色视频欧美一区二区三区| 亚洲老司机在线| 91福利区一区二区三区| 亚洲成a人v欧美综合天堂| 欧美午夜一区二区三区免费大片| 亚洲精品乱码久久久久久| 欧美亚洲动漫制服丝袜| 婷婷国产在线综合| 日韩一级二级三级精品视频| 麻豆精品视频在线| 久久噜噜亚洲综合| 国产99精品国产| 中文字幕在线观看一区二区| 色综合咪咪久久| 亚洲chinese男男1069| 欧美日本不卡视频| 看电影不卡的网站| 国产亚洲福利社区一区| 91在线视频官网| 亚洲国产综合在线| 欧美精品一区二区三区很污很色的 | 亚洲综合视频在线观看| 7777精品伊人久久久大香线蕉最新版| 日韩avvvv在线播放| 精品国产精品网麻豆系列| www.欧美精品一二区| 一区二区三区四区乱视频| 欧美精品xxxxbbbb| 国精品**一区二区三区在线蜜桃| 最新欧美精品一区二区三区| 欧美视频精品在线观看| 黄色日韩三级电影| 亚洲欧美区自拍先锋| 3d成人h动漫网站入口| 国产精品99久久久久久久女警 | 精品乱人伦小说| 成人h动漫精品一区二区| 亚洲综合激情另类小说区| 精品美女被调教视频大全网站| 99久久精品费精品国产一区二区| 日韩电影一区二区三区四区| 国产精品久久久久影院色老大| 欧美性猛片xxxx免费看久爱| 国内外精品视频| 亚洲一区二区三区中文字幕 | 亚洲成人免费av| 久久蜜桃一区二区| 在线视频亚洲一区| 国产福利精品一区| 天堂一区二区在线| 国产精品国模大尺度视频| 欧美一区二区视频在线观看| 99视频在线精品| 久久av资源网| 亚洲成人久久影院| 国产精品美女久久久久av爽李琼 | 日韩视频免费观看高清完整版在线观看 | 精品粉嫩超白一线天av| 91久久香蕉国产日韩欧美9色| 精品一区二区在线观看|