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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? tskprocess.c

?? DSP圖像采集程序源代碼
?? C
字號(hào):
#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"

#include "d:\ti\c6000\ndk\inc\netmain.h"

//#include "cap_dis_size.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 * 480];
unsigned char dec_out_u[360 * 240];
unsigned char dec_out_v[360 * 240];


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;
    ScomMessage scomMsg;
    void *inBuf[3];
    void *outBuf[3];
    int  jpg_size;
    int framenum=0;
    CHAN_Handle chanHandle;
    SCOM_Handle fromInputtoProc,fromProctoInput;
    SCOM_Handle fromOuttoProc,fromProctoOut;
    SCOM_Handle fromNettoProc,fromProctoNet;

    fromInputtoProc = SCOM_open("INTOPROC");
    fromProctoInput = SCOM_open("PROCTOIN");
    fromProctoOut   = SCOM_open("PROCTOOUT");
    fromOuttoProc   = SCOM_open("OUTTOPROC");
    fromProctoNet   = SCOM_open("PROCTONET");
    fromNettoProc   = SCOM_open("NETTOPROC");

    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 );

            //
            // Pass JPG to network task
            //
            scomMsg.sizeLinear = jpg_size;
            scomMsg.bufLinear  = jpg_img;
            SCOM_putMsg( fromProctoNet, &scomMsg );

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

            // Get our message buffer back from networking
            SCOM_getMsg(fromNettoProc, SYS_FOREVER);

            // Send the buffer to the display task
            scomMsg.bufY = (void *)dec_out_y;
            scomMsg.bufU = (void *)dec_out_u;
            scomMsg.bufV = (void *)dec_out_v;
            SCOM_putMsg( fromProctoOut, &scomMsg );

            // Get our message buffer back from display
            SCOM_getMsg(fromOuttoProc, SYS_FOREVER);
        }
    }
}




?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品国产亚洲a| 国产精品一二三四五| 国产无遮挡一区二区三区毛片日本| proumb性欧美在线观看| 日本不卡的三区四区五区| 中文字幕一区二区不卡 | 日韩一区二区三区四区| 成人国产精品免费观看视频| 丝袜美腿成人在线| 亚洲日本va午夜在线影院| 久久免费电影网| 欧美久久一二区| 99精品视频一区| 国产精品一区免费视频| 奇米精品一区二区三区在线观看 | 欧美成人乱码一区二区三区| 波多野洁衣一区| 激情综合网激情| 首页综合国产亚洲丝袜| 亚洲欧美一区二区久久 | 国产午夜精品久久久久久免费视 | 亚洲欧美日韩小说| 中文字幕免费不卡在线| 精品播放一区二区| 91精品国产手机| 欧美年轻男男videosbes| 91免费小视频| 91在线视频观看| 99视频在线精品| 成人久久18免费网站麻豆| 国产成人av影院| 成人永久看片免费视频天堂| 国产精品乡下勾搭老头1| 国产一区二区在线看| 精品一区二区av| 久久99精品久久久久久久久久久久 | 欧美精选一区二区| 欧美日韩你懂的| 51精品视频一区二区三区| 精品婷婷伊人一区三区三| 欧洲人成人精品| 欧美在线视频不卡| 欧美调教femdomvk| 欧美一区二区三区免费视频| 91精品国产综合久久国产大片| 欧美精品三级日韩久久| 91麻豆精品国产91久久久使用方法 | 欧美电影影音先锋| 欧美一区日韩一区| 欧美成人国产一区二区| 亚洲精品一区二区三区精华液| 久久午夜羞羞影院免费观看| 国产欧美一区视频| 亚洲欧美色图小说| 视频一区二区中文字幕| 麻豆精品视频在线观看视频| 精品中文av资源站在线观看| 国产美女视频一区| 不卡一区在线观看| 在线观看亚洲成人| 日韩一级黄色片| 欧美激情一区二区三区不卡| 综合婷婷亚洲小说| 婷婷夜色潮精品综合在线| 美女视频一区二区| 国产精品一区二区不卡| 91免费在线视频观看| 欧美日韩1区2区| 国产亚洲综合在线| 亚洲码国产岛国毛片在线| 丝袜诱惑亚洲看片| 国产成人无遮挡在线视频| 日本高清不卡在线观看| 91麻豆精品国产| 日本一区二区免费在线观看视频 | 久草精品在线观看| 成人精品国产免费网站| 在线亚洲人成电影网站色www| 欧美精选一区二区| 国产欧美精品一区二区三区四区| 亚洲色图19p| 精品中文字幕一区二区小辣椒| 成人av午夜电影| 欧美一区二区三区思思人| 亚洲欧美一区二区视频| 蜜臀av国产精品久久久久| aaa亚洲精品| 欧美电视剧免费全集观看| 亚洲欧美日韩国产另类专区| 久久国产免费看| 色婷婷av一区| 久久精品夜夜夜夜久久| 亚洲.国产.中文慕字在线| 国产一区二区三区美女| 欧美视频中文字幕| 国产精品久久久久影院色老大| 日本伊人精品一区二区三区观看方式| 成人国产精品免费| 精品美女一区二区| 亚洲第一在线综合网站| 成人a级免费电影| 欧美成人激情免费网| 亚洲国产精品人人做人人爽| 东方aⅴ免费观看久久av| 日韩欧美专区在线| 亚洲网友自拍偷拍| 91尤物视频在线观看| 国产欧美精品在线观看| 久久99精品一区二区三区| 在线看国产日韩| 17c精品麻豆一区二区免费| 国产在线观看免费一区| 91精品国产福利| 亚洲成av人片在线观看无码| 91一区二区在线观看| 国产精品美女久久久久aⅴ| 国产一区免费电影| 精品久久久久久久久久久久包黑料| 亚洲一卡二卡三卡四卡五卡| 一本到不卡免费一区二区| 国产精品嫩草影院com| 国产一区二区三区四区五区入口| 日韩欧美一二区| 青青草国产成人99久久| 正在播放一区二区| 天天影视色香欲综合网老头| 色就色 综合激情| 一区二区三区中文字幕精品精品 | 精品福利视频一区二区三区| 天堂成人国产精品一区| 欧美久久一区二区| 日韩精品电影一区亚洲| 欧美一区二区三区四区五区| 日韩中文欧美在线| 在线电影一区二区三区| 午夜精品久久久久久| 欧美精品国产精品| 日本欧美在线看| 欧美电视剧免费全集观看| 韩国三级中文字幕hd久久精品| 精品乱人伦小说| 国产福利电影一区二区三区| 中文字幕av一区 二区| av在线一区二区| 樱花草国产18久久久久| 欧美日韩国产大片| 日韩vs国产vs欧美| 精品久久一二三区| 成人午夜电影久久影院| 亚洲视频在线一区观看| 色综合久久精品| 亚洲一级在线观看| 日韩亚洲欧美中文三级| 极品少妇一区二区| 国产精品久久久久一区二区三区| av在线这里只有精品| 亚洲一区在线电影| 日韩一区二区三区在线视频| 国产毛片精品一区| 国产精品国产自产拍高清av王其 | 粉嫩高潮美女一区二区三区| 国产精品理论片| 在线精品国精品国产尤物884a| 秋霞电影网一区二区| 国产欧美一区二区精品仙草咪| 99久久精品国产观看| 亚洲午夜久久久久久久久久久 | 亚洲综合一区二区| 5858s免费视频成人| 国产盗摄精品一区二区三区在线 | 日韩在线一二三区| 精品国产一区二区亚洲人成毛片| 不卡免费追剧大全电视剧网站| 一区二区三区在线观看国产| 91精品国产乱码| 成人精品免费网站| 五月婷婷激情综合| 国产精品视频在线看| 欧美日韩亚洲另类| 国产精品亚洲专一区二区三区| 亚洲乱码精品一二三四区日韩在线| 欧美一区二区观看视频| jiyouzz国产精品久久| 日本三级亚洲精品| 亚洲人成影院在线观看| 欧美成va人片在线观看| 91国偷自产一区二区使用方法| 久久精品国产免费| 一区二区三区欧美久久| 国产亚洲一区二区三区四区 | 激情图片小说一区| 亚洲尤物视频在线| 国产日韩av一区| 欧美卡1卡2卡| 色婷婷综合激情| 国产成人av电影| 另类小说色综合网站| 一区二区三区加勒比av| 日本一二三不卡| 欧美tickle裸体挠脚心vk|