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. /*
  30.  * ======== main ========
  31.  */
  32. main()
  33. {
  34.     ICETEKDM642CInit();
  35.     /******************************************************/
  36.     /* open CSL DAT module for fast copy                  */
  37.     /******************************************************/
  38.     CSL_init();                                             
  39.     CACHE_clean(CACHE_L2ALL, 0, 0);
  40.     CACHE_setL2Mode(CACHE_128KCACHE);       
  41.     CACHE_enableCaching(CACHE_EMIFA_CE00);
  42.     CACHE_enableCaching(CACHE_EMIFA_CE01);
  43.     DAT_open(DAT_CHAANY, DAT_PRI_LOW, DAT_OPEN_2D);
  44. }
  45. /*
  46.  * ======== tskVideoLoopback ========
  47.  * video loopback function.
  48.  */
  49. void tskVideoLoopback()
  50. {
  51.     Int i;
  52.     unsigned int m_nID;
  53.     Int status;
  54.     FVID_Handle disChan; 
  55.     Int frames = 0;
  56.     FVID_Frame *disFrameBuf;
  57.     Int numLinesDis = EVMDM642_vDisParamsChan.imgVSizeFld1;
  58.     Int numLinesCap = EVMDM642_vCapParamsChan.fldYStop1 -
  59.        EVMDM642_vCapParamsChan.fldYStrt1+1;
  60.     
  61.     Int numLines = (numLinesDis > numLinesCap) ? numLinesCap : numLinesDis;
  62.     FVID_Handle capChan; 
  63.     Int numPixels = EVMDM642_vCapParamsChan.fldXStop1 - 
  64.        EVMDM642_vCapParamsChan.fldXStrt1+1;
  65.     FVID_Frame *capFrameBuf;
  66.     Int capLinePitch = EVMDM642_vCapParamsChan.fldXStop1 - 
  67.        EVMDM642_vCapParamsChan.fldXStrt1+1;
  68.     Int disLinePitch = EVMDM642_vDisParamsChan.imgHSizeFld1;
  69.     numLines *= 2; /* both fields */
  70.     /******************************************************/
  71.     /* allocate both capture and display frame buffers    */
  72.     /* in external heap memory                            */
  73.     /******************************************************/
  74.         EVMDM642_vCapParamsChan.segId = EXTERNALHEAP;
  75.         EVMDM642_vDisParamsChan.segId = EXTERNALHEAP;
  76.         EVMDM642_vDisParamsSAA7121.hI2C = EVMDM642_I2C_hI2C;
  77.         EVMDM642_vCapParamsSAA7115.hI2C = EVMDM642_I2C_hI2C;
  78.     /******************************************************/
  79.     /* initialization of capture driver                   */
  80.     /******************************************************/
  81.     capChan = FVID_create("/VP0CAPTURE/A/0", 
  82.             IOM_INPUT, &status, (Ptr)&EVMDM642_vCapParamsChan, NULL);
  83.     /******************************************************/
  84.     /* initialization of display driver                   */
  85.     /******************************************************/
  86.     disChan = FVID_create("/VP2DISPLAY/1", IOM_OUTPUT, 
  87.         &status, (Ptr)&EVMDM642_vDisParamsChan, NULL);
  88.     
  89.     /******************************************************/
  90.     /* configure video encoder & decoder                  */
  91.     /******************************************************/
  92.     FVID_control(disChan, VPORT_CMD_EDC_BASE + EDC_CONFIG, 
  93.         (Ptr)&EVMDM642_vDisParamsSAA7121);
  94.     FVID_control(capChan, VPORT_CMD_EDC_BASE + EDC_CONFIG, 
  95.         (Ptr)&EVMDM642_vCapParamsSAA7115);
  96.     /******************************************************/
  97.     /* start capture & display operation                  */    
  98.     /******************************************************/
  99.     FVID_control(disChan, VPORT_CMD_START, NULL);
  100.     FVID_control(capChan, VPORT_CMD_START, NULL);
  101.     
  102.     /********************************************************/
  103.     /* request a frame buffer from display & capture driver */
  104.     /********************************************************/
  105.     FVID_alloc(disChan, &disFrameBuf);
  106.     FVID_alloc(capChan, &capFrameBuf);
  107.     frames ++;
  108.     while ( 1 )
  109.     {/* loop forever */
  110.         /* copy data from capture buffer to display buffer */
  111.         /***************************************************/
  112.         for ( i=0;i<numLines;i++) 
  113.         {
  114.             m_nID=DAT_copy(capFrameBuf->frame.iFrm.y1+i*capLinePitch,nMemTemp,720);
  115. DAT_wait(m_nID);
  116.             if ( i>numLines-MHIGH ) ICETEKDM642CMedianFilter();
  117.             DAT_copy(nMemTemp,disFrameBuf->frame.iFrm.y1+i*disLinePitch,720);
  118.             DAT_copy(nUV,disFrameBuf->frame.iFrm.cb1 + i * (disLinePitch >> 1),360);
  119.             DAT_copy(nUV,disFrameBuf->frame.iFrm.cr1 + i * (disLinePitch >> 1),360);
  120.         }
  121.         DAT_wait(DAT_XFRID_WAITALL);
  122.         FVID_exchange(capChan, &capFrameBuf);
  123.         FVID_exchange(disChan, &disFrameBuf);        
  124.         frames ++;              
  125.    }
  126. }