video.c
上传用户:dahaojd
上传日期:2008-01-29
资源大小:14357k
文件大小:5k
源码类别:

DSP编程

开发平台:

C/C++

  1. /*
  2.  *  Copyright 2003 by Texas Instruments Incorporated.
  3.  *  All rights reserved. Property of Texas Instruments Incorporated.
  4.  *  Restricted rights to use, duplicate or disclose this code are
  5.  *  granted through contract.
  6.  *  
  7.  */
  8. /* "@(#) DDK 1.10.00.23 07-02-03 (ddk-b12)" */
  9. #include <std.h>
  10. #include <tsk.h>  
  11. #include <sem.h>   
  12. #include <gio.h>
  13. #include <csl_dat.h>
  14. #include <csl_cache.h>
  15. #include <fvid.h>
  16. #include <edc.h>
  17. #include <vport.h>
  18. #include <vportcap.h>
  19. #include <vportdis.h>
  20. #include "saa7121.h"
  21. #include <saa7115.h>    
  22. #include <evmdm642.h>
  23. #include "vcapparams.h"
  24. #include "vdisparams.h"   
  25. /* heap IDs defined in the BIOS configuration file */
  26. extern Int EXTERNALHEAP;
  27. #include "ICETEK-DM642-C.h"
  28. extern unsigned char nMemTemp[720],nUV[720];
  29. extern unsigned char imgHisto[HISTOHIGH*HISTOWIDTH];
  30. /*
  31.  * ======== main ========
  32.  */
  33. main()
  34. {
  35.     ICETEKDM642CInit();
  36.     /******************************************************/
  37.     /* open CSL DAT module for fast copy                  */
  38.     /******************************************************/
  39.     CSL_init();                                             
  40.     CACHE_clean(CACHE_L2ALL, 0, 0);
  41.     CACHE_setL2Mode(CACHE_128KCACHE);       
  42.     CACHE_enableCaching(CACHE_EMIFA_CE00);
  43.     CACHE_enableCaching(CACHE_EMIFA_CE01);
  44.     DAT_open(DAT_CHAANY, DAT_PRI_LOW, DAT_OPEN_2D);
  45. }
  46. /*
  47.  * ======== tskVideoLoopback ========
  48.  * video loopback function.
  49.  */
  50. void tskVideoLoopback()
  51. {
  52.     Int i;
  53.     unsigned int m_nID;
  54.     Int status;
  55.     FVID_Handle disChan; 
  56.     Int frames = 0;
  57.     FVID_Frame *disFrameBuf;
  58.     Int numLinesDis = EVMDM642_vDisParamsChan.imgVSizeFld1;
  59.     Int numLinesCap = EVMDM642_vCapParamsChan.fldYStop1 -
  60.        EVMDM642_vCapParamsChan.fldYStrt1+1;
  61.     
  62.     Int numLines = (numLinesDis > numLinesCap) ? numLinesCap : numLinesDis;
  63.     FVID_Handle capChan; 
  64.     Int numPixels = EVMDM642_vCapParamsChan.fldXStop1 - 
  65.        EVMDM642_vCapParamsChan.fldXStrt1+1;
  66.     FVID_Frame *capFrameBuf;
  67.     Int capLinePitch = EVMDM642_vCapParamsChan.fldXStop1 - 
  68.        EVMDM642_vCapParamsChan.fldXStrt1+1;
  69.     Int disLinePitch = EVMDM642_vDisParamsChan.imgHSizeFld1;
  70.     numLines *= 2; /* both fields */
  71.     /******************************************************/
  72.     /* allocate both capture and display frame buffers    */
  73.     /* in external heap memory                            */
  74.     /******************************************************/
  75.         EVMDM642_vCapParamsChan.segId = EXTERNALHEAP;
  76.         EVMDM642_vDisParamsChan.segId = EXTERNALHEAP;
  77.         EVMDM642_vDisParamsSAA7121.hI2C = EVMDM642_I2C_hI2C;
  78.         EVMDM642_vCapParamsSAA7115.hI2C = EVMDM642_I2C_hI2C;
  79.     /******************************************************/
  80.     /* initialization of capture driver                   */
  81.     /******************************************************/
  82.     capChan = FVID_create("/VP0CAPTURE/A/0", 
  83.             IOM_INPUT, &status, (Ptr)&EVMDM642_vCapParamsChan, NULL);
  84.     /******************************************************/
  85.     /* initialization of display driver                   */
  86.     /******************************************************/
  87.     disChan = FVID_create("/VP2DISPLAY/1", IOM_OUTPUT, 
  88.         &status, (Ptr)&EVMDM642_vDisParamsChan, NULL);
  89.     
  90.     /******************************************************/
  91.     /* configure video encoder & decoder                  */
  92.     /******************************************************/
  93.     FVID_control(disChan, VPORT_CMD_EDC_BASE + EDC_CONFIG, 
  94.         (Ptr)&EVMDM642_vDisParamsSAA7121);
  95.     FVID_control(capChan, VPORT_CMD_EDC_BASE + EDC_CONFIG, 
  96.         (Ptr)&EVMDM642_vCapParamsSAA7115);
  97.     /******************************************************/
  98.     /* start capture & display operation                  */    
  99.     /******************************************************/
  100.     FVID_control(disChan, VPORT_CMD_START, NULL);
  101.     FVID_control(capChan, VPORT_CMD_START, NULL);
  102.     
  103.     /********************************************************/
  104.     /* request a frame buffer from display & capture driver */
  105.     /********************************************************/
  106.     FVID_alloc(disChan, &disFrameBuf);
  107.     FVID_alloc(capChan, &capFrameBuf);
  108.     frames ++;
  109.     while ( 1 )
  110.     {/* loop forever */
  111.         /* copy data from capture buffer to display buffer */
  112.         /***************************************************/
  113.         for ( i=0;i<numLines;i++) 
  114.         {
  115.             m_nID=DAT_copy(capFrameBuf->frame.iFrm.y1+i*capLinePitch,nMemTemp,720);
  116. DAT_wait(m_nID);
  117.             ICETEKDM642CStatistic();
  118.             DAT_copy(nMemTemp,disFrameBuf->frame.iFrm.y1+i*disLinePitch,720);
  119.             DAT_copy(nUV,disFrameBuf->frame.iFrm.cb1 + i * (disLinePitch >> 1),360);
  120.             DAT_copy(nUV,disFrameBuf->frame.iFrm.cr1 + i * (disLinePitch >> 1),360);
  121.         }
  122.         ICETEKDM642CHistogram();
  123.         DAT_wait(DAT_XFRID_WAITALL);
  124.         DAT_copy2d(DAT_1D2D,imgHisto,
  125.          disFrameBuf->frame.iFrm.y1+410*720+30,
  126.          HISTOWIDTH,HISTOHIGH,720);
  127.         DAT_wait(DAT_XFRID_WAITALL);
  128.         FVID_exchange(capChan, &capFrameBuf);
  129.         FVID_exchange(disChan, &disFrameBuf);        
  130.         frames ++;              
  131.    }
  132. }