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

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

?? vportdis.c

?? TI公司DSP的VP口用于顯示高清視頻流或高清圖片的驅動程序源碼!
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*
 *  Copyright 2003 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.
 *  
 */
/* "@(#) DDK 1.10.00.23 07-02-03 (ddk-b12)" */
/* 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>
#include <csl_cache.h>
#include <csl_dat.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 _getlastActiveLine(VPORTDIS_Params* params);
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;

        /* allocate EDMA PaRAM and RLD entries */
        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[4 * j] = EDMA_allocTable(-1)) == EDMA_HINV 
             || (chan->hRld[4 * j + 1] =EDMA_allocTable(-1)) == EDMA_HINV 
             || (chan->hRld[4 * j + 2] =EDMA_allocTable(-1)) == EDMA_HINV 
             || (chan->hRld[4 * j + 3] =EDMA_allocTable(-1)) == EDMA_HINV 
             ||  (chan->tcc[j] = EDMA_intAlloc(chan->edmaChanNum[j])) == -1){
                retVal = IOM_EALLOC;
                retVal = IOM_EALLOC;
            }/* if((chan->...*/ 
        }/* for(j = 0; j < NUM_EDMA_CHANS; j++) {...*/
        
        /* if EDMA resources are allocated successfully, go ahead */
        /* and configure the channel                              */
        if(retVal == IOM_COMPLETED && (void *)chanParams != INV) {
            retVal = mdControlChan(chan, VPORT_CMD_CONFIG_CHAN, chanParams); 
        }
        if(! retVal) {
             /* configured the channel successfully, return handle */
             *chanp = chan;
        }else {
            /* failed, free all resources and return error */
            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_disableChannel(chan->hEdma[j]);
            EDMA_clearChannel(chan->hEdma[j]);
            EDMA_close(chan->hEdma[j]);
            EDMA_freeTable(chan->hRld[4 * j]);
            EDMA_freeTable(chan->hRld[4 * j + 1]);
            EDMA_freeTable(chan->hRld[4 * j + 2]);
            EDMA_freeTable(chan->hRld[4 * j + 3]);
            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 
        && packet->cmd != FVID_FREE 
        && packet->cmd != FVID_EXCHANGE){        
        /* other commands not supported */
        return IOM_ENOTIMPL;    
    }
    
    if(packet->cmd != FVID_ALLOC) {/* FVID_FREE or FVID_EXCHANGE */
        viop = *(void **)packet->addr; /* pointer of a video I/O packet */
        if(chan->queEmpty) {
            /* check to make sure it is not to at the end of a frame */
            /* to avoid any race condition                           */
            volatile Int* base = (volatile Int *)chan->base;
            short lineNum = (base[_VP_VDSTAT_OFFSET] & _VP_VDSTAT_VDYPOS_MASK)
                           >> _VP_VDSTAT_VDYPOS_SHIFT;
            /* make sure we are at least five lines before completion */
            /* to prevent EDMA reload happening while it is being modified */
            if(lineNum <= chan->lastLineNum - 5) {
                Int offset = chan->nextEDMARlds << 1;
                chan->nextViop = viop;
                /* now modify the EDMA rld entries */
                if(chan->mergeFlds){
                    EDMA_RSETH(chan->hRld[offset], SRC, 
                        viop->frame.iFrm.y1);
                    EDMA_RSETH(chan->hRld[offset + 1], SRC, 
                        viop->frame.iFrm.y2);
                    if(!(chan->mode & _VPORT_MASK_RAW)){
                        EDMA_RSETH(chan->hRld[4 + offset], SRC, 
                          viop->frame.iFrm.cb1);     
                        EDMA_RSETH(chan->hRld[5 + offset], SRC, 
                          viop->frame.iFrm.cb2);                         
                        EDMA_RSETH(chan->hRld[8 + offset], SRC, 
                          viop->frame.iFrm.cr1);     
                        EDMA_RSETH(chan->hRld[9 + offset], SRC, 
                          viop->frame.iFrm.cr2);              
                    }           
                } else {
                    EDMA_RSETH(chan->hRld[offset], SRC, 
                        viop->frame.iFrm.y1);
                    if(!(chan->mode & _VPORT_MASK_RAW)){
                        EDMA_RSETH(chan->hRld[4 + offset], SRC, 
                          viop->frame.iFrm.cb1);     
                        EDMA_RSETH(chan->hRld[8 + offset], SRC, 
                          viop->frame.iFrm.cr1);                         
                    }                                           
                } /* if(chan->mergeFlds) */
            } else {
                QUE_enqueue(&chan->qIn, (QUE_Handle)viop);                    
            }
            chan->queEmpty = FALSE;                   
        }
        else {
            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)) {
        chan->lastLineNum = _getlastActiveLine(params);
        /* 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;
}                     

static const Int fillValue[4] = {
0, 0, 0x80808080, 0x80808080
};
/*

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一级片在线观看| 久久99精品国产麻豆婷婷洗澡| 老司机一区二区| 亚洲成在线观看| 亚洲欧洲成人av每日更新| 日本精品一级二级| 久久久久国产一区二区三区四区| 色婷婷综合视频在线观看| 国产精品白丝jk黑袜喷水| 亚洲视频图片小说| 国产精品成人免费 | 欧美剧在线免费观看网站| 91丝袜美腿高跟国产极品老师 | 欧美视频在线一区二区三区 | 日韩精品成人一区二区三区| 综合电影一区二区三区| 精品国产成人在线影院| 国产精品一区二区在线观看不卡| 久久精品人人做人人综合| 久久精品人人爽人人爽| 欧美三级三级三级爽爽爽| 日韩一区二区三区四区五区六区| 久久精品国产99久久6| 99久免费精品视频在线观看| 免费在线一区观看| 美女脱光内衣内裤视频久久网站| 久久久久青草大香线综合精品| 日韩午夜精品电影| 欧美亚一区二区| 91精品国产91综合久久蜜臀| 在线电影院国产精品| 日韩一区欧美一区| 2020日本不卡一区二区视频| 欧美国产一区在线| 欧美激情一区三区| 一区二区三区成人| 国产精品99久久久久久久女警| 国产一区二区三区在线观看精品 | 97se亚洲国产综合在线| 99国产精品国产精品久久| 奇米精品一区二区三区四区| 琪琪久久久久日韩精品| 美女mm1313爽爽久久久蜜臀| 福利一区福利二区| 这里只有精品电影| 日韩一区二区不卡| 国产精品福利av| 一级女性全黄久久生活片免费| 成人中文字幕在线| 91国偷自产一区二区三区成为亚洲经典 | 久99久精品视频免费观看| 日韩电影免费在线| 日本韩国精品在线| 国产日韩欧美不卡| 蜜臀91精品一区二区三区| 国产二区国产一区在线观看| 欧美一区三区二区| 欧美国产国产综合| 成人黄色片在线观看| 精品sm在线观看| 婷婷综合另类小说色区| 99久久久无码国产精品| 日韩精品中文字幕在线不卡尤物| 天天色图综合网| 欧美亚洲禁片免费| 国产亚洲一区二区三区四区| 日本在线不卡一区| 激情综合色播五月| 日韩一区二区三区视频| 高清久久久久久| 欧美三级电影精品| thepron国产精品| 亚洲免费观看高清完整版在线观看 | 久久久综合激的五月天| 麻豆精品国产91久久久久久| www亚洲一区| 免费在线一区观看| 久久亚洲综合av| 91成人在线免费观看| 国产亚洲自拍一区| 99国产精品一区| 一区二区三区日韩在线观看| 精品成人私密视频| 国产一区二区美女诱惑| 亚洲福利国产精品| 在线亚洲+欧美+日本专区| 奇米888四色在线精品| 日本一二三四高清不卡| 99免费精品在线观看| 久久精品国产免费看久久精品| 欧美探花视频资源| 成人h精品动漫一区二区三区| 久久精品欧美日韩精品| 亚洲免费视频中文字幕| 日韩欧美国产一二三区| 久久精品久久久精品美女| 2023国产精品| 韩国理伦片一区二区三区在线播放| 一区二区三区免费| 久久久国产综合精品女国产盗摄| 91免费国产视频网站| 午夜av一区二区| 久久久精品tv| 欧美一区二区三区在线视频 | 成人精品免费网站| 一区二区三区中文字幕| 久久亚洲一区二区三区四区| 欧美一区二区三区影视| 欧美日韩精品一区二区三区| 99精品久久只有精品| 日韩精品一二三| 一区二区在线观看免费视频播放| 69p69国产精品| 在线综合亚洲欧美在线视频| 欧美精品亚洲二区| 国产精品一区二区视频| 精品一区二区三区久久| 国产精品一区一区三区| 国产在线不卡视频| 日韩av在线播放中文字幕| 亚洲人精品午夜| 一区二区三区在线观看国产| 亚洲永久免费av| 成人av影院在线| 成人中文字幕电影| 色综合久久久久久久| 欧美男人的天堂一二区| 精品国产乱码久久久久久1区2区 | 精品一区免费av| 蜜桃在线一区二区三区| 国产91综合一区在线观看| 高清beeg欧美| 6080日韩午夜伦伦午夜伦| 欧美日韩电影在线播放| 日韩欧美一区二区在线视频| 欧美韩国一区二区| 亚洲国产wwwccc36天堂| 国产在线国偷精品免费看| 日韩电影在线观看电影| 成人一区二区三区在线观看| 欧美性xxxxx极品少妇| 久久久久久一级片| 日韩精品一区国产麻豆| 日韩精品一区在线| 1区2区3区欧美| 福利一区二区在线| 国产v综合v亚洲欧| 精品免费一区二区三区| 日韩精品一区二| 午夜视频一区在线观看| 成人免费三级在线| 国产精品久久久久久妇女6080| 亚洲综合在线观看视频| eeuss鲁片一区二区三区 | 欧美午夜一区二区三区| 久久综合九色综合97婷婷女人| 偷拍与自拍一区| 精品视频一区三区九区| 久久先锋资源网| av日韩在线网站| 精品国产一区二区三区久久久蜜月| 日本一区二区视频在线| 亚洲免费资源在线播放| 91污在线观看| 国产精品久久二区二区| av在线不卡网| 亚洲国产aⅴ天堂久久| 99热在这里有精品免费| 亚洲婷婷在线视频| 国产乱码精品一区二区三区av | 成人精品免费看| 91影视在线播放| 亚洲国产精品精华液网站| 91精品欧美久久久久久动漫| 精品亚洲成a人| 中文字幕亚洲一区二区av在线| www.激情成人| 亚洲人成精品久久久久久 | 精品写真视频在线观看| 欧美婷婷六月丁香综合色| 天天av天天翘天天综合网色鬼国产| 欧美成人一区二区| 色综合久久综合| 肉肉av福利一精品导航| 日韩欧美久久一区| 国产99久久久精品| 亚洲免费在线看| 日韩一级欧美一级| 99国产精品视频免费观看| 亚洲欧美日韩久久精品| 欧美日韩日日夜夜| 高清av一区二区| 免费在线观看不卡| 成人欧美一区二区三区| 日韩欧美视频在线| 国产成人在线视频网址| 国产精品一级在线| 精品在线观看视频| 亚洲精选视频免费看| 日韩一卡二卡三卡|