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

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

?? evmdm642_edma_aic23.c

?? 使用DM642 來進行scaling 有說明檔
?? C
?? 第 1 頁 / 共 2 頁
字號:
        MCASP_FMKS(XMASK, XMASK0, NOMASK),
        
        MCASP_FMKS(XFMT, XDATDLY, 0BIT)         |
        MCASP_FMKS(XFMT, XRVRS, MSBFIRST)       |
        MCASP_FMKS(XFMT, XPAD, ZERO)            |
        MCASP_FMKS(XFMT, XPBIT, DEFAULT)        |
        MCASP_FMKS(XFMT, XSSZ, 32BITS)          |
        MCASP_FMKS(XFMT, XBUSEL, DAT)           |
        MCASP_FMKS(XFMT, XROT, NONE),

        MCASP_FMKS(AFSXCTL, XMOD, BURST)        |
        MCASP_FMKS(AFSXCTL, FXWID, BIT) |
        MCASP_FMKS(AFSXCTL, FSXM, EXTERNAL)     |
        MCASP_FMKS(AFSXCTL, FSXP, ACTIVEHIGH),

        MCASP_FMKS(ACLKXCTL, CLKXP, FALLING)    |
        MCASP_FMKS(ACLKXCTL, ASYNC, ASYNC)      |
        MCASP_FMKS(ACLKXCTL, CLKXM, EXTERNAL)   |
        MCASP_FMKS(ACLKXCTL, CLKXDIV, OF(0)),
  
        MCASP_FMKS(AHCLKXCTL, HCLKXM, EXTERNAL) |
        MCASP_FMKS(AHCLKXCTL, HCLKXP, RISING)   |     
        MCASP_FMKS(AHCLKXCTL, HCLKXDIV, OF(0)),

        MCASP_FMKS(XTDM, XTDMS31, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS30, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS29, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS28, INACTIVE)     |       
        MCASP_FMKS(XTDM, XTDMS27, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS26, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS25, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS24, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS23, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS22, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS21, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS20, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS19, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS18, INACTIVE)     |      
        MCASP_FMKS(XTDM, XTDMS17, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS16, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS15, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS14, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS13, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS12, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS11, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS10, INACTIVE)     |
        MCASP_FMKS(XTDM, XTDMS9, INACTIVE)      |
        MCASP_FMKS(XTDM, XTDMS8, INACTIVE)      |
        MCASP_FMKS(XTDM, XTDMS7, INACTIVE)      |
        MCASP_FMKS(XTDM, XTDMS6, INACTIVE)      |
        MCASP_FMKS(XTDM, XTDMS5, INACTIVE)      |
        MCASP_FMKS(XTDM, XTDMS4, INACTIVE)      |
        MCASP_FMKS(XTDM, XTDMS3, INACTIVE)      |
        MCASP_FMKS(XTDM, XTDMS2, INACTIVE)      |
        MCASP_FMKS(XTDM, XTDMS1, INACTIVE)      |
        MCASP_FMKS(XTDM, XTDMS0, ACTIVE),

        MCASP_FMKS(XINTCTL, XSTAFRM, DISABLE)   |
        MCASP_FMKS(XINTCTL, XDATA, DISABLE)     |
        MCASP_FMKS(XINTCTL, XLAST, DISABLE)     |
        MCASP_FMKS(XINTCTL, XDMAERR, DISABLE)   |
        MCASP_FMKS(XINTCTL, XCKFAIL, DISABLE)   |
        MCASP_FMKS(XINTCTL, XSYNCERR, DISABLE)  |
        MCASP_FMKS(XINTCTL, XUNDRN, DISABLE),

        MCASP_FMKS(XCLKCHK, XMAX, DEFAULT)      |
        MCASP_FMKS(XCLKCHK, XMIN, DEFAULT)      |
        MCASP_FMKS(XCLKCHK, XPS, DEFAULT)       
    }; 

    MCASP_ConfigSrctl configSrctl = {
        MCASP_FMKS(SRCTL, DISMOD, HIGH)         |
        MCASP_FMKS(SRCTL, SRMOD, XMT),

        MCASP_FMKS(SRCTL, DISMOD, HIGH)         |
        MCASP_FMKS(SRCTL, SRMOD, RCV),

        MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE),

        MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE),

        MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE),

        MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE),

        MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE),

        MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE)

/*      MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE),

        MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE),

        MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE),

        MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE),

        MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE),

        MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE),

        MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE),

        MCASP_FMKS(SRCTL, DISMOD, 3STATE)       |
        MCASP_FMKS(SRCTL, SRMOD, INACTIVE) */
};

    MCASP_Config mcaspCfg;

    mcaspCfg.global = &configGbl;
    mcaspCfg.receive = &configRcv;
    mcaspCfg.transmit = &configXmt;
    mcaspCfg.srctl = &configSrctl;

    
    /* If no device parameters are passed, use the defaults. */
    if (params == NULL) {
        params = &EVMDM642_EDMA_AIC23_DEVPARAMS;
    }

    /* Check if the version is supported by the driver. */
    if(params->versionId != EVMDM642_EDMA_AIC23_VERSION_1){
        /* Unsupported version */
        return(IOM_EBADARGS);
    }

    /* Set the McASP */ 
    genericParams.mcaspCfgPtr = &mcaspCfg;

    genericParams.irqId = params->irqId;
    genericParams.enableClkg = params->enableClkg;
    genericParams.enableHclkg = params->enableHclkg;
    genericParams.enableFsyncg = params->enableFsyncg;
    genericParams.cacheCalls = params->cacheCalls;
    genericParams.inEvtIrqId = params->inEvtIrqId;
    genericParams.outEvtIrqId = params->outEvtIrqId;
    genericParams.evtCallback = params->evtCallback;
    genericParams.inEvtIntrMask  = params->inEvtIntrMask;
    genericParams.outEvtIntrMask  = params->outEvtIntrMask;
    /* Set the interrupt mask */
    genericParams.edmaIntrMask = params->edmaIntrMask;

    /* Set codec parameters */
    if (!AIC23_setParams(&(params->aic23Config))) {
        return (IOM_EALLOC);
    }

    /* Call the generic mdBindDev to claim mcasp port MCASPPORT */
    return (C6X1X_EDMA_MCASP_FXNS.mdBindDev)(devp, MCASPPORT, &genericParams);
}

/*
 * ======== mdCreateChan ========
 * This function creates and configures a device channel.
 */
static Int mdCreateChan(Ptr *chanp, Ptr devp, String name, Int mode,
                        Ptr chanParams, IOM_TiomCallback cbFxn, Ptr cbArg)
{
    Int result;
    C6X1X_EDMA_MCASP_ChanParams genericParams;

    EDMA_Config edmaCfg = {
        EDMA_FMKS(OPT, PRI, HIGH)             |
        EDMA_FMKS(OPT, ESIZE, 32BIT)          |
        EDMA_FMKS(OPT, 2DS, NO)               |
        EDMA_FMKS(OPT, SUM, NONE)             |
        EDMA_FMKS(OPT, 2DD, NO)               |
        EDMA_FMKS(OPT, DUM, NONE)             |
        EDMA_FMKS(OPT, TCINT, YES)            |
        EDMA_FMK (OPT, TCC, NULL)             |
        EDMA_FMKS(OPT, LINK, YES)             |
        EDMA_FMKS(OPT, FS, YES),

        EDMA_FMK(SRC, SRC, NULL),

        EDMA_FMKS(CNT, FRMCNT, DEFAULT)       |
        EDMA_FMKS(CNT, ELECNT, DEFAULT),

        EDMA_FMK(DST, DST, NULL),

        EDMA_FMKS(IDX, FRMIDX, DEFAULT)       |
        EDMA_FMKS(IDX, ELEIDX, DEFAULT),

        EDMA_FMKS(RLD, ELERLD, DEFAULT)       |
        EDMA_FMK(RLD, LINK, NULL)
    };      

    /* Set ELECNT, ELERLD to the active serializers */
    /* FRMCNT will be 1 pair of SRCTL and set in C6x1x_edma_mcasp driver */
    EDMA_FSETA(&edmaCfg.cnt, CNT, ELECNT, 1);   
    EDMA_FSETA(&edmaCfg.rld, RLD, ELERLD, 1); 

    if (mode == IOM_INPUT) {
        EDMA_FSETSA(&edmaCfg.opt, OPT, DUM, INC);
        /* Select EDMA channel 13 for rcv here */
        genericParams.edmaChan = 13;
    } else {

        EDMA_FSETSA(&edmaCfg.opt, OPT, SUM, INC);

        /* Select EDMA channel 12 for xmt here */
        genericParams.edmaChan = 12;
    }

    genericParams.edmaCfgPtr = &edmaCfg;
    /* 
     * for loopback, no need to sync to external frame sync, 
     * set to 5 to run loop edma job long enough for sync real xmt & rcv job
     */  
    genericParams.tdmChans = 1;
    
    result = (C6X1X_EDMA_MCASP_FXNS.mdCreateChan)(chanp, devp, name, mode,
                                                &genericParams, cbFxn, cbArg);
    return (result);
}

/*
 * ======== mdControlChan ========
 * Control the channel.
 */
static Int mdControlChan(Ptr chanp, Uns cmd, Ptr args)
{
	Uint32 sampleRate = (Uint32) args;
	Int result = 0;

	if (cmd == IOM_CNTL_AUDIO_SETSAMPLERATE) {
		AIC23_setSampleRate(sampleRate);	
		result = 1;
	}
	
	// Maybe should always call underlying? 
	else {
		// Call underlying mdControlChan
	    result = (C6X1X_EDMA_MCASP_FXNS.mdControlChan)(chanp, cmd, args);
	}

    return (result);
}

/*
 * ======== EVMDM642_EDMA_AIC23_init ========
 * This function initializes the driver's structures.
 */
Void EVMDM642_EDMA_AIC23_init()
{
    /* Pass some IOM fxns straight to the generic driver */
//    EVMDM642_EDMA_AIC23_FXNS.mdControlChan =
//        C6X1X_EDMA_MCASP_FXNS.mdControlChan;
    EVMDM642_EDMA_AIC23_FXNS.mdDeleteChan =
        C6X1X_EDMA_MCASP_FXNS.mdDeleteChan;
    EVMDM642_EDMA_AIC23_FXNS.mdSubmitChan =
        C6X1X_EDMA_MCASP_FXNS.mdSubmitChan;
    EVMDM642_EDMA_AIC23_FXNS.mdUnBindDev =
        C6X1X_EDMA_MCASP_FXNS.mdUnBindDev;

    C6X1X_EDMA_MCASP_init();
}



?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲免费在线观看视频| 成人精品国产一区二区4080| 洋洋av久久久久久久一区| 国产精品天美传媒沈樵| 国产清纯美女被跳蛋高潮一区二区久久w | 亚洲成人福利片| 亚洲国产一区二区在线播放| 亚洲黄色免费网站| 亚洲午夜精品在线| 首页亚洲欧美制服丝腿| 日韩激情一二三区| 蜜臀精品久久久久久蜜臀| 日本不卡高清视频| 久久成人免费网| 欧美一区二区高清| 亚洲一区二区三区在线看| 一区二区三区日韩欧美精品| 樱桃国产成人精品视频| 亚洲午夜久久久久久久久电影网| 亚洲成人av一区| 青娱乐精品视频| 国模冰冰炮一区二区| 国产成人精品网址| 99久久综合99久久综合网站| 色婷婷精品久久二区二区蜜臀av| 欧美日韩免费观看一区三区| 日韩一区二区三区高清免费看看| 精品国产91亚洲一区二区三区婷婷| 精品国产乱码久久久久久影片| 久久精品一区二区| 亚洲男人的天堂网| 天天av天天翘天天综合网 | 最近日韩中文字幕| 亚洲二区在线视频| 久久精品国产第一区二区三区| 国产在线精品一区二区不卡了| 国产成人自拍高清视频在线免费播放| 粉嫩高潮美女一区二区三区| 91碰在线视频| 91精品国产免费久久综合| 久久久久久久久97黄色工厂| 亚洲欧洲国产专区| 日韩精品电影在线| 国产.精品.日韩.另类.中文.在线.播放 | 轻轻草成人在线| 高清不卡一二三区| 欧美亚日韩国产aⅴ精品中极品| 欧美一级国产精品| 天堂一区二区在线| 国产99精品国产| 欧美吻胸吃奶大尺度电影| 精品国产人成亚洲区| 亚洲品质自拍视频| 国产一区二区按摩在线观看| 在线观看欧美黄色| 国产三级三级三级精品8ⅰ区| 亚洲激情五月婷婷| 国产福利电影一区二区三区| 欧美性猛交xxxxxx富婆| 久久精品日产第一区二区三区高清版 | 欧美成人性福生活免费看| 中文字幕一区二区三区在线观看| 日韩高清不卡在线| 91视频你懂的| 久久精品亚洲乱码伦伦中文 | 国精产品一区一区三区mba桃花| 91天堂素人约啪| 久久久久久久网| 天天影视色香欲综合网老头| 91在线观看视频| 久久久精品国产免大香伊 | 在线观看国产一区二区| 国产日韩精品一区二区浪潮av| 亚洲高清免费在线| 成人av片在线观看| 久久久久久久久久看片| 免费欧美高清视频| 欧美日韩国产高清一区二区| 亚洲欧洲日韩在线| 大白屁股一区二区视频| 日韩精品一区二区三区老鸭窝| 一区二区三区**美女毛片| 国产成人精品综合在线观看 | 一区2区3区在线看| 白白色 亚洲乱淫| 国产亚洲综合性久久久影院| 美女国产一区二区三区| 精品视频免费在线| 亚洲乱码一区二区三区在线观看| 日韩午夜激情免费电影| 亚洲第一搞黄网站| 欧美制服丝袜第一页| 亚洲卡通欧美制服中文| 91在线高清观看| 国产精品国产三级国产三级人妇| 国模大尺度一区二区三区| 精品欧美黑人一区二区三区| 日本欧美肥老太交大片| 欧美日韩成人高清| 天天综合色天天综合色h| 欧美日韩精品一区二区三区| 亚洲一区二区在线免费观看视频| 一本一本大道香蕉久在线精品 | 国产午夜久久久久| 韩国精品久久久| 欧美mv日韩mv亚洲| 精品一二线国产| 国产亚洲精品7777| 国产不卡在线视频| 中文字幕av不卡| 成人a级免费电影| 国产精品成人在线观看| 91小宝寻花一区二区三区| 亚洲女同ⅹxx女同tv| 在线观看精品一区| 日韩影院在线观看| 精品福利一区二区三区免费视频| 国产一区二区免费视频| 国产欧美一区二区精品仙草咪| 丰满亚洲少妇av| 亚洲人成人一区二区在线观看| 日本黄色一区二区| 亚洲成人777| 欧美不卡在线视频| 国产乱妇无码大片在线观看| 日本一区二区视频在线观看| 99精品久久只有精品| 亚洲精选在线视频| 777午夜精品视频在线播放| 久久99久久久欧美国产| 久久亚洲一级片| 99国产精品国产精品毛片| 亚洲精品视频免费观看| 91精选在线观看| 国产乱人伦偷精品视频不卡| 综合av第一页| 欧美日韩精品专区| 国产精品1区2区3区在线观看| 国产精品无码永久免费888| 色播五月激情综合网| 日韩国产欧美视频| 欧美激情一区二区三区四区| 在线观看亚洲成人| 激情图片小说一区| 中文字幕一区av| 欧美一区二区三区影视| 成人午夜激情影院| 天天综合日日夜夜精品| 欧美国产视频在线| 欧美久久婷婷综合色| 国产精品99久久久久久久vr| 亚洲精品欧美综合四区| 五月婷婷久久丁香| 欧美激情一区在线观看| 欧美视频在线不卡| 国产精品中文字幕日韩精品 | www.一区二区| 美国十次了思思久久精品导航| 国产欧美一区二区精品性| 欧美日韩免费视频| 国产91高潮流白浆在线麻豆| 亚洲愉拍自拍另类高清精品| 久久亚洲一区二区三区四区| 欧美日韩在线不卡| 成人午夜大片免费观看| 日韩电影在线一区二区三区| 国产精品久久午夜| 日韩免费在线观看| 91高清在线观看| 国产成a人亚洲精品| 亚洲成在人线免费| 综合久久久久久| 久久噜噜亚洲综合| 欧美精品日日鲁夜夜添| 91亚洲精品乱码久久久久久蜜桃| 美腿丝袜亚洲三区| 亚洲小说春色综合另类电影| 国产精品三级av在线播放| 日韩视频国产视频| 欧美日韩视频在线第一区| 成人免费看的视频| 国产综合久久久久影院| 日韩高清在线观看| 一区二区在线观看视频 | 久久精品二区亚洲w码| 亚洲一区二区视频在线观看| 中文字幕在线不卡国产视频| 久久久影院官网| 日韩美女视频在线| 成人免费毛片aaaaa**| 久久婷婷国产综合国色天香| 久久精品国产亚洲a| 91福利小视频| 亚洲三级小视频| 成人av在线播放网址| 久久久久久99久久久精品网站| 亚洲高清免费一级二级三级| 一本久久a久久免费精品不卡| 国产日产欧美一区| 粉嫩一区二区三区在线看|