24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 155  |  回复: 0
当前主题已经存档。

haojing8117

新虫 (初入文坛)

[交流] 【求助】求急!关于DSP6000成像的编程问题

我现在想让以下的程序实现这样的功能:满足108《=cb《=123和135<=cr<=156的像素为白色,其余显示黑色的,(程序中的斜体加粗的部分)但是运行以后出现错误:expected a statement.请各位高手指点一下
/*
*  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)" */
#include
#include   
#include    
#include

#include
#include //使用CSL库,要用到的一些头文件,可参考CSL


#include   //视频驱动头文件
#include
#include
#include
#include
#include
#include    

#include

#include "colorbar.h"
#include "evmdm642_vcapparams.h"
#include "evmdm642_vdisparams.h"   

/* heap IDs defined in the BIOS configuration file */
extern Int EXTERNALHEAP;//在DSP/BIOS中已定义


/*
* ======== main ========
*/
main()
{
    /******************************************************/
    /* open CSL DAT module for fast copy                  */
    /******************************************************/
    CSL_init(); //调用任何CSL库中的函数,必须先在此调用该函数                                             
    CACHE_clean(CACHE_L2ALL, 0, 0);//清洗Cache
    CACHE_setL2Mode(CACHE_256KCACHE); //设置Cache模式      
    CACHE_enableCaching(CACHE_EMIFA_CE00);//使能EMIFA CE0空间
    CACHE_enableCaching(CACHE_EMIFA_CE01);//使能EMIFA CE1空间
    DAT_open(DAT_CHAANY, DAT_PRI_LOW, DAT_OPEN_2D);//打开数据传输
}

/*
* ======== tskVideoLoopback ========
* video loopback function.
*/
void tskVideoLoopback()
{
    Int i;
    int m_nWork;
    Int status;
    FVID_Handle disChan; //设置设备句柄
    Int frames = 0;
    FVID_Frame *disFrameBuf;
       /*设置显示的行数 VGA制式为480,PAL制为576*/

    Int numLinesDis = EVMDM642_vDisParamsChan.imgVSizeFld1;
     /*设置采集的行数 PAL制为576*/

    Int numLinesCap = EVMDM642_vCapParamsChan.fldYStop1 -
       EVMDM642_vCapParamsChan.fldYStrt1+1;
       /*判断是显示区域大,还是采集区域大,取其小者*/   
   
    Int numLines = (numLinesDis > numLinesCap) ? numLinesCap : numLinesDis;

#ifdef _LOOPBACK
    FVID_Handle capChan;
    /*设置采集像素数 PAL制为720*/

    Int numPixels = EVMDM642_vCapParamsChan.fldXStop1 -
       EVMDM642_vCapParamsChan.fldXStrt1+1;
    FVID_Frame *capFrameBuf;
     /*设置采集行的增量 PAL制为720*/

    Int capLinePitch = EVMDM642_vCapParamsChan.fldXStop1 -
       EVMDM642_vCapParamsChan.fldXStrt1+1;
        /*设置显示行的增量 VGA制为640*/
    Int disLinePitch = EVMDM642_vDisParamsChan.imgHSizeFld1;


#ifdef _PIP
    VPORTCAP_Params EVMDM642_vCapParamsChan2 = EVMDM642_vCapParamsChan;
    FVID_Handle capChan2;
    FVID_Frame *capFrameBuf2;
    Int yPitch = capLinePitch >> 1;
    Int cPitch = ((capLinePitch >> 2) + 7) & (~ 7);
#endif
#endif               


    numLines *= 2; /* both fields */ //如果输出为PAL制,前面numLinesCap不要*2,这里再*2
    /******************************************************/
    /* allocate both capture and display frame buffers    */
    /* in external heap memory                            */
    /******************************************************/
        EVMDM642_vCapParamsChan.segId = EXTERNALHEAP;
        EVMDM642_vDisParamsChan.segId = EXTERNALHEAP;
        EVMDM642_vDisParamsSAA7105.hI2C = EVMDM642_I2C_hI2C;
        EVMDM642_vCapParamsSAA7115.hI2C = EVMDM642_I2C_hI2C;

    /******************************************************/
    /* initialization of capture driver                   */
    /******************************************************/
#ifdef _LOOPBACK
    capChan = FVID_create("/VP0CAPTURE/A/0",
            IOM_INPUT, &status, (Ptr)&EVMDM642_vCapParamsChan, NULL);

#ifdef _PIP
    EVMDM642_vCapParamsChan2.scale = VPORT_SCALING_ENABLE;
        EVMDM642_vCapParamsChan2.fldOp = VPORT_FLDOP_FLD1;        
        EVMDM642_vCapParamsChan2.thrld >>=1;
    capChan2 = FVID_create("/VP1CAPTURE/A/1",
            IOM_INPUT, &status, (Ptr)&EVMDM642_vCapParamsChan2, NULL);
#endif         

#endif         
    /******************************************************/
    /* initialization of display driver                   */
    /******************************************************/
    disChan = FVID_create("/VP2DISPLAY", IOM_OUTPUT,
        &status, (Ptr)&EVMDM642_vDisParamsChan, NULL);

   
    /******************************************************/
    /* configure video encoder & decoder                  */
    /******************************************************/
    for ( m_nWork=0;m_nWork<6;m_nWork++ )
    {
            FVID_control(disChan, VPORT_CMD_EDC_BASE + EDC_CONFIG,
                (Ptr)&EVMDM642_vDisParamsSAA7105);
#ifdef _LOOPBACK
            FVID_control(capChan, VPORT_CMD_EDC_BASE + EDC_CONFIG,
                (Ptr)&EVMDM642_vCapParamsSAA7115);
#ifdef _PIP
            EVMDM642_vCapParamsSAA7115.aFmt = SAA7115_AFMT_COMPOSITE;
            FVID_control(capChan2, VPORT_CMD_EDC_BASE+EDC_CONFIG,
                (Ptr)&EVMDM642_vCapParamsSAA7115);
#endif
#endif
        }

    /******************************************************/
    /* start capture & display operation                  */   
    /******************************************************/
    FVID_control(disChan, VPORT_CMD_START, NULL);
#ifdef _LOOPBACK
    FVID_control(capChan, VPORT_CMD_START, NULL);
#ifdef _PIP
    FVID_control(capChan2, VPORT_CMD_START, NULL);
#endif   
#endif   
   
    /********************************************************/
    /* request a frame buffer from display & capture driver */
    /********************************************************/
    FVID_alloc(disChan, &disFrameBuf);
#ifdef _LOOPBACK
    FVID_alloc(capChan, &capFrameBuf);
#ifdef _PIP
    FVID_alloc(capChan2, &capFrameBuf2);
#endif      
#endif
    frames ++;


    while(1){/* loop forever */
#ifdef _LOOPBACK
        /* copy data from capture buffer to display buffer */
        /***************************************************/

      for(i = 0; i < numLines; i ++)
      
      
        
       {if(*((capFrameBuf->frame.iFrm.cb1)+i)<=123&&*((capFrameBuf->frame.iFrm.cb1)+i)>=108)
        
        if(*((capFrameBuf->frame.iFrm.cr1)+i)<=156&&*((capFrameBuf->frame.iFrm.cr1)+i)>=135)
        {
         *((capFrameBuf->frame.iFrm.cr1)+i)=128;
         *((capFrameBuf->frame.iFrm.cb1)+i)=128;
         *((capFrameBuf->frame.iFrm.y1)+i)=180;
        else
        {*((capFrameBuf->frame.iFrm.cr1)+i)=129;
         *((capFrameBuf->frame.iFrm.cb1)+i)=129;
         *((capFrameBuf->frame.iFrm.y1)+i)=16;
        }
       }
        else
        {*((capFrameBuf->frame.iFrm.cr1)+i)=129;
         *((capFrameBuf->frame.iFrm.cb1)+i)=129;
         *((capFrameBuf->frame.iFrm.y1)+i)=16;
         }
       }      
                                           
                  
                  
         
        
           DAT_copy(capFrameBuf->frame.iFrm.y1 + i * capLinePitch,
                    disFrameBuf->frame.iFrm.y1 + i * disLinePitch,
                     numPixels);
            DAT_copy(capFrameBuf->frame.iFrm.cb1 + i * (capLinePitch >> 1),
                     disFrameBuf->frame.iFrm.cb1 + i * (disLinePitch >> 1),
                    numPixels>>1);

            DAT_copy(capFrameBuf->frame.iFrm.cr1 + i * (capLinePitch >> 1),
                   disFrameBuf->frame.iFrm.cr1 + i * (disLinePitch >> 1),
                    numPixels>>1);
        }
#ifdef _PIP  
        for(i = 0; i < (numLines>>1); i ++) {
            DAT_copy(capFrameBuf2->frame.iFrm.y1 + i * yPitch,
                     disFrameBuf->frame.iFrm.y1 + i * disLinePitch
                     + (disLinePitch >> 1),
                     (numPixels>>1));
            DAT_copy(capFrameBuf2->frame.iFrm.cb1 + i * cPitch,
                     disFrameBuf->frame.iFrm.cb1 + i * (disLinePitch >> 1)
                     + (disLinePitch >>2 ),
                     (numPixels >> 2));

            DAT_copy(capFrameBuf2->frame.iFrm.cr1 + i * cPitch,
                     disFrameBuf->frame.iFrm.cr1 + i * (disLinePitch >> 1)
                     +(disLinePitch >> 2),
                     (numPixels >> 2));
                     
            sobel_
        }
#endif
        DAT_wait(DAT_XFRID_WAITALL);
        FVID_exchange(capChan, &capFrameBuf);//采集一帧视频,更新内存

#ifdef _PIP
        FVID_exchange(capChan2, &capFrameBuf2);
#endif
#else
        fillFrmBuf(&disFrameBuf->frame.iFrm, EVMDM642_vDisParamsChan.imgHSizeFld1,
          EVMDM642_vDisParamsChan.imgVSizeFld1
            + EVMDM642_vDisParamsChan.imgVSizeFld2,
          frames % 360);
#endif
        FVID_exchange(disChan, &disFrameBuf); //显示一帧视频。
      
        frames ++;              
   }
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 haojing8117 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 各位老师好,我的一志愿为北京科技大学085601材料专硕 +7 Koxui 2026-03-28 7/350 2026-03-29 00:58 by 我是小康
[考研] 085600 材料与化工 329分求调剂 +10 Mr. Z 2026-03-25 10/500 2026-03-29 00:34 by 我是小康
[考研] 一志愿太原理工安全工程300分,求调剂 +5 0857求调剂. 2026-03-24 6/300 2026-03-28 22:04 by zhq0425
[考研] 0856求调剂 +11 zhn03 2026-03-25 12/600 2026-03-28 13:32 by 唐沐儿
[考研] 322求调剂 +5 旧吢 2026-03-24 5/250 2026-03-28 13:26 by Iveryant
[考研] 材料277求调剂 +7 min3 2026-03-24 7/350 2026-03-28 11:39 by xuxiang
[考研] 286求调剂 +4 丢掉懒惰 2026-03-27 7/350 2026-03-28 08:07 by baoball
[考研] 086502化学工程342求调剂 +6 阿姨复古不过 2026-03-27 6/300 2026-03-28 07:06 by wangy0907
[考研] 328求调剂 +7 嗯滴的基本都 2026-03-27 7/350 2026-03-28 04:19 by fmesaito
[考研] 化学调剂 +4 爱吃番茄的旭 2026-03-24 5/250 2026-03-27 17:50 by kiokin
[考研] 283求调剂(080500) +4 A child 2026-03-27 4/200 2026-03-27 15:34 by XPU李庆
[考研] 一志愿陕师大生物学071000,298分,求调剂 +5 SYA! 2026-03-23 5/250 2026-03-27 09:29 by 不吃魚的貓
[考研] 求调剂 一志愿 本科 北科大 化学 343 +6 13831862839 2026-03-24 7/350 2026-03-26 22:57 by 不吃魚的貓
[考研] 总分322求生物学/生化与分子/生物信息学相关调剂 +5 星沉uu 2026-03-26 6/300 2026-03-26 19:02 by macy2011
[考研] 生物学 296 求调剂 +4 朵朵- 2026-03-26 6/300 2026-03-26 19:01 by 不吃魚的貓
[考研] 303求调剂 +6 蓝山月 2026-03-25 6/300 2026-03-25 22:47 by 418490947
[考研] 0854人工智能方向招收调剂 +4 章小鱼567 2026-03-24 4/200 2026-03-25 13:29 by 2177681040
[考研] 一志愿河北工业大学0817化工278分求调剂 +7 jhybd 2026-03-23 12/600 2026-03-24 09:03 by jhybd
[考研] 材料/农业专业,07/08开头均可,过线就行 +3 呵唔哦豁 2026-03-23 4/200 2026-03-23 22:30 by 汪!?!
[考研] 328求调剂 +4 LHHL66 2026-03-23 4/200 2026-03-23 14:55 by lbsjt
信息提示
请填处理意见