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

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

?? tskprocess.c

?? DM642多媒體原版程序代碼,用于圖象,語音算法.
?? C
字號:
#include <std.h>
#include <tsk.h>
#include <stdio.h>
#include <csl.h>
#include <csl_cache.h>
#include <csl_dat.h>
#include <chan.h>
#include <scom.h>
#include <utl.h>
#include <ialg.h>

#include "fvid.h"
#include "celljpegenc_ti.h"
#include "celljpegdec_ti.h"
#include "appmain.h"
#include "appThreads.h"
#include "tskProcess.h"
#include "appBiosObjects.h"

IJPEGENC_Params   jpegencParams;
IJPEGDEC_Params   jpegdecParams;


#pragma DATA_SECTION(jpg_img,   ".user_data_ext")
#pragma DATA_ALIGN( jpg_img,   128)
unsigned char jpg_img[128 * 2000];

#pragma DATA_ALIGN(dec_out_y, 128);
#pragma DATA_ALIGN(dec_out_u, 128);
#pragma DATA_ALIGN(dec_out_v, 128);
unsigned char dec_out_y[720 * 576];
unsigned char dec_out_u[360 * 288];
unsigned char dec_out_v[360 * 288];


static Void checkMsg();


ThrProcess thrProcess;

void tskProcessInit()
{
    int chanNum;
    ICELL_Obj  *cell;
    ICC_Handle  inputIcc;
    ICC_Handle  outputIcc;

    /*----------------------------------------------------*/
    /* Call JPEG specific user initialization if any.     */
    /*----------------------------------------------------*/

    JPEGENC_TI_init();
    JPEGDEC_TI_init();

    /*----------------------------------------------------*/
    /* Set up params for all XDAIS algorithms.            */
    /*----------------------------------------------------*/

    jpegencParams = IJPEGENC_PARAMS;
    jpegdecParams = IJPEGDEC_PARAMS;

    for (chanNum = 0; chanNum < PROCESSNUMCHANNELS ; chanNum++)
    {
        /*
         * JPEGENC: create an input and output linear ICC:
         * The address to the ICC's will be set in the thrProcessRun()
         * function via the ICC_setBuf().
         */
        ICELL_Obj   defaultCell = ICELL_DEFAULT;

        cell = &thrProcess.cellListEncode[(chanNum*PROCESSNUMCELLS) + 0];
        *cell                = defaultCell;
        cell->name           = "JPEGENC";
        cell->cellFxns       = &JPEGENC_CELLFXNS;
        cell->algFxns        = (IALG_Fxns *)&JPEGENC_IJPEGENC;
        cell->algParams      = (IALG_Params *)&IJPEGENC_PARAMS;
        cell->scrBucketIndex = THRIOSSCRBUCKET;

        inputIcc  = (ICC_Handle)ICC_linearCreate(NULL, 0);
        UTL_assert( inputIcc != NULL);

        outputIcc = (ICC_Handle)ICC_linearCreate(NULL, 0);
        UTL_assert( outputIcc != NULL);

        // Only one input and one output ICC are needed.
        CHAN_regCell( cell, &inputIcc, 1, &outputIcc, 1 );

        // Setup Encode Parameters
        thrProcess.cellListEncode[(chanNum*PROCESSNUMCELLS) + 0].algParams =
                                                (IALG_Params *)&IJPEGENC_PARAMS;

        UTL_logDebug1("JPEGEncoder registerd Channel Number: %d", chanNum);

        /*
         * JPEGDEC: create an input and output linear ICC:
         * The address to the ICC's will be set in the thrProcessRun()
         * function via the ICC_setBuf().
         */
        cell = &thrProcess.cellListDecode[(chanNum*PROCESSNUMCHANNELS) + 0];
        *cell                = defaultCell;
        cell->name           = "JPEGDEC";
        cell->cellFxns       = &JPEGDEC_CELLFXNS;
        cell->algFxns        = (IALG_Fxns *)&JPEGDEC_IJPEGDEC;
        cell->algParams      = (IALG_Params *)&IJPEGDEC_PARAMS;
        cell->scrBucketIndex = THRIOSSCRBUCKET;

        inputIcc  = (ICC_Handle)ICC_linearCreate(NULL, 0);
        UTL_assert( inputIcc != NULL);

        outputIcc = (ICC_Handle)ICC_linearCreate(NULL, 0);
        UTL_assert( outputIcc != NULL);

        // Only one input and one output ICC are needed.
        CHAN_regCell( cell, &inputIcc, 1, &outputIcc, 1 );

        // Setup Decode Parameters
        thrProcess.cellListDecode[(chanNum*PROCESSNUMCELLS) + 0].algParams =
                                               (IALG_Params *)&IJPEGDEC_PARAMS;

        UTL_logDebug1("JPEGDecoder registerd Channel Number: %d", chanNum);
    }

    memset(dec_out_y, 0x0,  sizeof(dec_out_y));
    memset(dec_out_u, 0x80, sizeof(dec_out_u));
    memset(dec_out_v, 0x80, sizeof(dec_out_v));

    CACHE_clean(CACHE_L2ALL, 0, 0);
    CACHE_clean(CACHE_L2ALL, 0, 0);
}

void tskProcessStart()
{
    int chanNum;
    for( chanNum=0; chanNum < PROCESSNUMCHANNELS; chanNum++ )
    {
        // open the encode channel: this causes the algorithms to be created
        CHAN_open( &thrProcess.chanListEncode[chanNum],
                   &thrProcess.cellListEncode[(chanNum*PROCESSNUMCELLS)],
                   PROCESSNUMCELLS, NULL );

        // open the decode channel: this causes the algorithms to be created
        CHAN_open( &thrProcess.chanListDecode[chanNum],
                   &thrProcess.cellListDecode[(chanNum*PROCESSNUMCELLS)],
                   PROCESSNUMCELLS, NULL );

    }
}


static Void checkMsg()
{
    CtrlMsg rxMsg;
    Int index;
    Int quality;
    ICELL_Handle handle;

    IJPEGENC_Params jpegencParams;
    int cell_no;

    // check message in "mbxProc"
    while( MBX_pend( &mbxProcess, &rxMsg, 0) )
    {
        switch (rxMsg.cmd)
        {
            case MSGFRAMECHANGE:  // frame ratio value changed
            {
                index = rxMsg.arg1;  // get the index number
                UTL_assert( (index >= 0) && (index < PROCESSNUMCHANNELS));
                // update the local value
                if (index < PROCESSNUMCHANNELS)
                    thrProcess.frameRateControl[index] = rxMsg.arg2;

                break;
            }

            case MSGQUALCHANGE: //quality rate value changed
            {
                index = rxMsg.arg1;  // get the index number
                UTL_assert( (index >= 0) && (index < PROCESSNUMCHANNELS));
                if (index < PROCESSNUMCHANNELS)
                {
                    jpegencParams =  IJPEGENC_PARAMS;
                    cell_no = rxMsg.arg2;
                    UTL_assert( (cell_no >= 0) && (cell_no < PROCESSNUMCELLS));

                    quality = rxMsg.arg3;
                    UTL_assert( (quality >= 0) &&
                                 (quality <= 100));

                    jpegencParams.quality = quality;

                    if ((quality > 0) && (quality <= 100))
                    {
                       handle = &(thrProcess.cellListEncode[index]);

                       thrProcess.cellListEncode[cell_no].cellFxns->cellControl
                       (
                           handle,
                          (IALG_Cmd) (IJPEG_SETSTATUS),
                          (IALG_Status*)(&(jpegencParams))
                       );
                    }
               }

               break;
            }

            default:
                break;
        }
    }
}


extern int SystemReady;


void tskProcess()
{
    int i;
    ScomMessage *pMsgBuf;
    void *inBuf[3];
    void *outBuf[3];
    int  jpg_size;
    int framenum=0;
    CHAN_Handle chanHandle;
    SCOM_Handle fromInputtoProc,fromProctoInput;
    SCOM_Handle fromOuttoProc,fromProctoOut;

    fromInputtoProc = SCOM_open("INTOPROC");
    fromProctoInput = SCOM_open("PROCTOIN");
    fromProctoOut   = SCOM_open("PROCTOOUT");
    fromOuttoProc   = SCOM_open("OUTTOPROC");

    while(1)
    {
        checkMsg();

        framenum++;

        for(i=0; i<PROCESSNUMCHANNELS; i++)
        {
            // Get Input Buffer
            pMsgBuf = SCOM_getMsg(fromInputtoProc, SYS_FOREVER);

            // If we're skipping this frame, just give the SCOM msg
            // back to the input function and continue the for loop.
            if( thrProcess.frameRateControl[i] != 0 &&
                (framenum % thrProcess.frameRateControl[i]) )
            {
                // Tell the capture routine we're done
                SCOM_putMsg(fromProctoInput,pMsgBuf);
                continue;
            }

            //
            // Handle Encode Channel
            //
            chanHandle = &thrProcess.chanListEncode[i];
            chanHandle->state = CHAN_ACTIVE;

            // Channel Input
            inBuf[0] = pMsgBuf->bufY;
            inBuf[1] = pMsgBuf->bufU;
            inBuf[2] = pMsgBuf->bufV;
            ICC_setBuf( chanHandle->cellSet[0].inputIcc[0],
                        inBuf, sizeof(void *) * 3 );

            // Channel Output
            outBuf[0] = &jpg_size;
            outBuf[1] = jpg_img;
            ICC_setBuf( chanHandle->cellSet[0].outputIcc[0],
                        outBuf, sizeof(void *) * 2 );

            // Execute Channel
            CHAN_execute( chanHandle, framenum );

            // Tell the capture routine we're done
            SCOM_putMsg( fromProctoInput, pMsgBuf );

            //
            // Handle Decode Channel
            //
            chanHandle = &thrProcess.chanListDecode[i];
            chanHandle->state = CHAN_ACTIVE;

            inBuf[0] = &jpg_size;
            inBuf[1] = jpg_img;
            ICC_setBuf( chanHandle->cellSet[0].inputIcc[0],
                        inBuf, sizeof(void *) * 2 );

            outBuf[0] = (void *)dec_out_y;
            outBuf[1] = (void *)dec_out_u;
            outBuf[2] = (void *)dec_out_v;
            ICC_setBuf( chanHandle->cellSet[0].outputIcc[0],
                        outBuf, sizeof(void *) * 3 );

            // Execute Channel
            CHAN_execute( chanHandle, framenum );

            // Send the buffer to the display task
            pMsgBuf = SCOM_getMsg(fromOuttoProc, SYS_FOREVER);

            pMsgBuf->bufY = (void *)dec_out_y;
            pMsgBuf->bufU = (void *)dec_out_u;
            pMsgBuf->bufV = (void *)dec_out_v;
            SCOM_putMsg(fromProctoOut,pMsgBuf);
        }
    }
}




?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久亚洲一区二区三区明星换脸 | 蜜臀国产一区二区三区在线播放 | 精品美女一区二区三区| 国产亚洲欧美中文| 一区二区三区四区不卡在线| 爽好久久久欧美精品| 成人av在线播放网址| 欧美裸体bbwbbwbbw| 1024国产精品| 国产寡妇亲子伦一区二区| 欧美精品久久天天躁| 最新高清无码专区| 国产一区二区0| 日韩亚洲欧美综合| 五月天激情综合| 91福利精品第一导航| 亚洲国产电影在线观看| 国产一区二区免费在线| 日韩午夜激情视频| 天天影视网天天综合色在线播放| 91性感美女视频| 国产精品看片你懂得| 国产揄拍国内精品对白| 欧美成人r级一区二区三区| 亚洲福利国产精品| 欧美亚洲尤物久久| 亚洲主播在线观看| 91福利在线免费观看| 亚洲精品videosex极品| 97精品超碰一区二区三区| 中文av一区特黄| 成人av综合一区| 中文字幕佐山爱一区二区免费| 国产91丝袜在线观看| 国产性色一区二区| 成人免费观看视频| 国产精品二三区| 色综合久久中文字幕综合网 | 久久婷婷国产综合国色天香 | 久久精品国产99久久6| 日韩精品一区二区三区中文不卡| 日本网站在线观看一区二区三区| 91精品国产福利| 美女一区二区视频| 精品成人免费观看| 丁香六月综合激情| 自拍偷自拍亚洲精品播放| 日本电影亚洲天堂一区| 日韩在线观看一区二区| 日韩免费看的电影| 国产精品亚洲第一| 亚洲欧洲日韩女同| 欧美羞羞免费网站| 精品影视av免费| 国产精品久久久久久久午夜片| 色视频成人在线观看免| 午夜精品123| 久久夜色精品国产噜噜av| 成人精品视频.| 亚洲成人先锋电影| 久久这里都是精品| 99re这里只有精品视频首页| 偷窥少妇高潮呻吟av久久免费| 欧美变态口味重另类| 91小宝寻花一区二区三区| 亚洲亚洲精品在线观看| 国产夫妻精品视频| 在线观看网站黄不卡| 亚洲欧洲精品一区二区三区| 成人午夜精品在线| 久久五月婷婷丁香社区| 国产一区二区视频在线播放| 亚洲视频免费看| 成人国产一区二区三区精品| 国产清纯在线一区二区www| 国产一区久久久| 26uuu亚洲综合色欧美| 狠狠色狠狠色综合系列| www国产亚洲精品久久麻豆| 精品无人码麻豆乱码1区2区| 日韩免费高清视频| 黄网站免费久久| 国产欧美日韩视频一区二区| 国产91精品欧美| 最新不卡av在线| 欧美日韩一级二级三级| 男男成人高潮片免费网站| 欧美va日韩va| 丁香婷婷深情五月亚洲| 亚洲少妇30p| 欧美人妇做爰xxxⅹ性高电影| 日韩av一区二| 精品国产污网站| 国产精品99久久久久久有的能看| 中文字幕第一区综合| 奇米影视一区二区三区小说| 亚洲日本va午夜在线影院| 欧美激情一区二区三区蜜桃视频| 国产精品视频观看| 国产盗摄一区二区三区| 亚洲精品美国一| 欧美大黄免费观看| av不卡在线观看| 日韩在线一二三区| 欧美国产欧美综合| 欧美三级韩国三级日本一级| 久草精品在线观看| 亚洲色图一区二区三区| 日韩欧美国产麻豆| 丁香六月综合激情| 奇米影视7777精品一区二区| 国产精品久久久久影院色老大| 欧美日韩三级一区二区| 国产成人啪免费观看软件| 亚洲超碰97人人做人人爱| 欧美精品一区在线观看| 欧美性xxxxxx少妇| 国产黄色精品网站| 日本vs亚洲vs韩国一区三区二区 | 欧美在线视频你懂得| 免费三级欧美电影| 1区2区3区欧美| 欧美成va人片在线观看| 在线观看国产日韩| 亚洲精品成a人| 国产精品网友自拍| 亚洲天天做日日做天天谢日日欢 | 欧美一卡二卡在线| 成人免费观看av| 黄色精品一二区| 琪琪久久久久日韩精品| 亚洲伊人伊色伊影伊综合网| 亚洲国产精品激情在线观看| 日韩欧美美女一区二区三区| 日本韩国一区二区三区视频| 高清国产一区二区三区| 久久疯狂做爰流白浆xx| 丝瓜av网站精品一区二区| 亚洲最大的成人av| 亚洲私人影院在线观看| 中文字幕在线一区免费| 国产女人18毛片水真多成人如厕 | 欧美中文字幕亚洲一区二区va在线| 国产成人a级片| 国产乱人伦精品一区二区在线观看| 丝瓜av网站精品一区二区| 日韩精品一二区| 亚洲国产成人av| 天天色综合天天| 性感美女久久精品| 午夜精品久久一牛影视| 午夜伦欧美伦电影理论片| 亚洲第一综合色| 日韩国产欧美三级| 日韩国产在线观看| 精品一区二区三区免费观看| 狠狠色狠狠色综合日日91app| 国产综合色视频| 粉嫩蜜臀av国产精品网站| 成人性色生活片| 色久优优欧美色久优优| 欧美网站大全在线观看| 欧美精品少妇一区二区三区| 7777精品伊人久久久大香线蕉最新版 | 日韩欧美国产小视频| 欧美成人bangbros| 国产日韩欧美一区二区三区乱码| 国产精品丝袜一区| 亚洲欧美日韩国产中文在线| 亚洲成人资源网| 狂野欧美性猛交blacked| 国产一区二区美女| 99国产欧美久久久精品| 欧美视频精品在线观看| 日韩一区二区三区观看| 日韩免费视频一区二区| 中文字幕一区不卡| 丝袜诱惑制服诱惑色一区在线观看 | 91极品视觉盛宴| 日韩一级黄色大片| 国产欧美一区二区三区在线老狼| 亚洲乱码日产精品bd| 天天色天天操综合| 国产精品亚洲第一区在线暖暖韩国 | 东方aⅴ免费观看久久av| 99v久久综合狠狠综合久久| 欧美日本一区二区在线观看| 久久综合九色综合欧美98| 亚洲卡通欧美制服中文| 捆绑变态av一区二区三区| 91女厕偷拍女厕偷拍高清| 日韩欧美资源站| 中文字幕日韩一区| 青青草伊人久久| 色综合视频在线观看| 精品粉嫩超白一线天av| 亚洲一区免费在线观看| 成人激情文学综合网| 精品免费国产一区二区三区四区| 亚洲乱码日产精品bd|