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

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

?? camera.c

?? au1200的在wince5.0下的攝像頭驅(qū)動.
?? C
?? 第 1 頁 / 共 4 頁
字號:
/******************************************************* 
        Clean Up Function (cleans memory, channel allocation etc)
 ********************************************************/

void CAM_Cleanup( CAMERA_RUNTIME *cim_cleanup)
{
    CAMERA  *cim_ptr;
    DWORD   frame_size;
    int     i; 

    cim_ptr    = cim_cleanup->cmos_camera;
    frame_size = cim_ptr->frame_width*cim_ptr->frame_height;

    DEBUGMSG(ZONE_TRACE, (TEXT("CAM: CAM_Cleanup: cleaning mode %s\r\n"),
                         cim_ptr->camera_mode));

	for ( i= 0; i < cim_ptr->dbdma_channel; i++ )
	{
		if ( cim_cleanup->ChannelArray[i] )
		{
			DEBUGMSG(ZONE_TRACE, (TEXT("CAM: Releasing ChannelArray[%d]\r\n"), i));

            HalStopMdlDMA(cim_cleanup->ChannelArray[i], NULL);
            HalFreeDMAChannel(cim_cleanup->ChannelArray[i]);
            cim_cleanup->ChannelArray[i] = NULL;
		}
	}
    cim_cleanup->cmos_camera = 0; // mark the camera "unconfigured"

    DEBUGMSG(ZONE_TRACE, (TEXT("CAM: DMA Channel and Memory Cleared Now!\r\nCAM: Ready to be reused\r\n"))); 
}

/****************************************************************************
            DMA Channel COnfiguration
	    External Camera configuration using SMBus
	    Au1200 Comtrol Block configuration
 ****************************************************************************/

int Camera_Config(CAMERA_RUNTIME* cim_config )
{
    int i;
    CAMERA * const cim_config_ptr = cim_config->cmos_camera;
    const DWORD frame_size = cim_config_ptr->frame_width * cim_config_ptr->frame_height;

	int     ErrorCheck         = 0;
	DWORD   nCameraModeConfig  = 0;
	DWORD   nClearSetInterrupt = 0;

	DEBUGMSG(ZONE_TRACE, (TEXT("CAM: Camera_Config: width %d, height %d, ch %d, DPS mode %d\r\n"), 
	            cim_config_ptr->frame_width,
                cim_config_ptr->frame_height,
                cim_config_ptr->dbdma_channel,
                cim_config_ptr->au1200_dpsmode));
	
    /*************************************************
	    Setting up DBDMA Channel
     *************************************************/
	
	// To get rid of hard-coded number from Transfer Size,
	// transfer size will be calulated on the fly:

    //      In YCbCr 4:2:2 data size is twice the frame size
    //      Y=Frame Size
    //      Cb=Frame Size/2
    //      Cr=Frame Size/2
    //      Total size of Frame: Y+Cb+Cr effectively 2*FrameSize

	if ( cim_config_ptr->au1200_dpsmode == CIM_CONFIG_RAW )
	{
        if ( cim_config_ptr->cmos_output_format == CMOS_CCIR656 )
		{
		    cim_config->nTransferSize[0] = frame_size * 2;
		    DEBUGMSG(ZONE_TRACE, (TEXT("CAM: FIFO-A YCbCR Transfer Size in Raw mode %d \r\n"),
                        cim_config->nTransferSize[0]));
		}
		else
		{
	        cim_config->nTransferSize[0] = frame_size;
		    DEBUGMSG(ZONE_TRACE, (TEXT("CAM: FIFO-A RGB Transfer Size in Raw mode %d \r\n"), 
                        cim_config->nTransferSize[0]));
		}
    }
	else if ( cim_config_ptr->au1200_dpsmode == CIM_CONFIG_BAYER )
	{
	    DEBUGMSG(ZONE_TRACE, (TEXT("CAM: Bayer Mode (Planar) Memory Size Calculation\r\n")));

	    /* FIFO A Hold Red Pixels which is Total Pixels/4 */
	    cim_config->nTransferSize[0] = frame_size / 4;
	    cim_config->nTransferSize[1] = frame_size / 2;
	    cim_config->nTransferSize[2] = frame_size / 4;
	    DEBUGMSG(ZONE_TRACE, (TEXT("CAM: Transfer Size of FIFO-A %d FIFO-B %d & FIFO-C in Bayer Mode %d\r\n"), 
                        cim_config->nTransferSize[0],
	                    cim_config->nTransferSize[1],
                        cim_config->nTransferSize[2]));
    }
	else
	{
	    DEBUGMSG(ZONE_TRACE, (TEXT("CAM: CCIR656 (Planar) Mode Memory Size Calculation\r\n")));

	    cim_config->nTransferSize[0] = frame_size;
	    cim_config->nTransferSize[1] = frame_size / 2;
	    cim_config->nTransferSize[2] = frame_size / 2;
	    DEBUGMSG(ZONE_TRACE, (TEXT("CAM: Transfer Size of FIFO-A %d FIFO-B %d & FIFO-C in CCIR656 Mode %d\r\n"), 
                        cim_config->nTransferSize[0],
	                    cim_config->nTransferSize[1],
                        cim_config->nTransferSize[2]));
	}

    // Make sure that if cleanup is necessary, it won't be cleaning garbage.
    for ( i=0; i< cim_config->cmos_camera->dbdma_channel;i++ )
    {
        cim_config->ChannelArray[i] = NULL;
    }
    
    ErrorCheck++; // we're initted now; error returns must clean up.
    for ( i=0; i<cim_config->cmos_camera->dbdma_channel; i++ )
	{
		/* Allocate Channel */
        cim_config->ChannelArray[i] = HalAllocateDMAChannel();
        if (cim_config->ChannelArray[i] == NULL) {
            RETAILMSG(1, (L"CAM: Cannot allocate a DMA channel for FIFO-%c\r\n", 'A'+i));
            goto error_ch_alloc;
        }
        if (!HalInitDmaChannel(cim_config->ChannelArray[i], DMA_CIM_FIFOA+i, 0, FALSE)) {
            RETAILMSG(1, (L"CAM: Cannot init the DMA channel for FIFO-%c\r\n", 'A'+i));
            goto error_ch_alloc;
        }
		DEBUGMSG(ZONE_TRACE, (TEXT("CAM: Channel # %d Allocated\r\n"), i));
	}
    DEBUGMSG(ZONE_TRACE, (TEXT("CAM: DMA Successful\r\n")));
	
	/****** END DBDMA****************/

	/********************************
		Configure CMOS CAMERA        
	**********************************/

	DEBUGMSG(ZONE_TRACE, (TEXT("CAM: CMOS Camera configuration \n")));
    {
        SMBUS_TRANSFER xfr;
        HANDLE h = CreateFile(L"SMB1:", 0, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);

        if (h == INVALID_HANDLE_VALUE)
        {
            DEBUGMSG(ZONE_TRACE, (L"CAM: cannot open a handle to the SMBus\r\n"));
            goto error_ch_alloc;
        }

        xfr.Address = cim_config_ptr->device_addr;
        xfr.DataSize = 1;
        for ( i=0; i < cim_config_ptr->cmd_size; i++ )
        {
            int nwr = 0;
            xfr.Register = cim_config_ptr->config_cmd[i][0];
            xfr.Data[0] = cim_config_ptr->config_cmd[i][1];
            if (!DeviceIoControl(h, IOCTL_SMBUS_WRITEDATA, &xfr, sizeof(SMBUS_TRANSFER), NULL, 0, &nwr, NULL))
            {
                DEBUGMSG(ZONE_ERROR, (TEXT("CAM: SMBUS: Camera count cannot be initialized -1 %d\r\n"), i));
                break;
            }

            if ( i == 0 )
                Sleep(1);
        }

        CloseHandle(h);

        if ( i != cim_config_ptr->cmd_size )
        {
            DEBUGMSG(ZONE_ERROR, (TEXT("CAM: External CMOS camera not present or not properly connected!\r\n")));
            goto error_ch_alloc;
        }
	}
    DEBUGMSG(ZONE_TRACE, (TEXT("CAM: CMOS camera configuration sucessful\r\n")));


	/********************************
	    Configure CAMERA Interface        
	**********************************/

	/* Enable the Camera Module*/
	pCim->enable  = CIM_ENABLE_EN;
	pCim->capture = CIM_CAPTURE_CLR;
	
	/* Config Register Setting */
    nCameraModeConfig = CIM_CONFIG_DPS_N(cim_config_ptr->au1200_dpsmode) | 
                        CIM_CONFIG_FS                                    |
					    CIM_CONFIG_BAY_N(cim_config_ptr->au1200_baymode) | 
                        CIM_CONFIG_BYT                                   |
					    CIM_CONFIG_LEN_N(CIM_CONFIG_LEN_10BIT);
    switch (cim_config_ptr->au1200_dpsmode) {
      case 1: break;
      case 0: nCameraModeConfig |= CIM_CONFIG_PM; break;
      default: nCameraModeConfig |= CIM_CONFIG_FS_N(CIM_CONFIG_FIELD2); break;
    }

	pCim->config = nCameraModeConfig;

	nClearSetInterrupt= CIM_INSTAT_CD  | CIM_INSTAT_FD  |
						CIM_INSTAT_UFA | CIM_INSTAT_OFA |
						CIM_INSTAT_UFB | CIM_INSTAT_OFB |
						CIM_INSTAT_UFB | CIM_INSTAT_OFC;

	// Clear Sticky Bit in the Interrupt Status Register.
	pCim->instat = nClearSetInterrupt;

	// Set Interrupt Bits in Interrupt Enable Register.
	pCim->inten = nClearSetInterrupt;

	DEBUGMSG(ZONE_TRACE, (TEXT("CAM: Config register => 0x%08X \r\n"), pCim->config));

    Sleep(6);

	return 0;

error_ch_alloc:

	if ( ErrorCheck )
	{
		CAM_Cleanup(cim_config);
	}
    return -1;
}


/***************************************************************
 *              Init Module
 ***************************************************************/

////////////////////////////////////////////////////////////////////////
//              Driver Entry
////////////////////////////////////////////////////////////////////////

BOOL WINAPI
DllEntry(HINSTANCE DllInstance, INT Reason, LPVOID Reserved)
{
    switch ( Reason )
    {
        case DLL_PROCESS_ATTACH:
            DEBUGREGISTER(DllInstance);
            DEBUGMSG(ZONE_TRACE, (TEXT("CAM: DllEntry: DLL_PROCESS_ATTACH\r\n")));
            break;

        case DLL_PROCESS_DETACH:
            DEBUGMSG(ZONE_TRACE, (TEXT("CAM: DllEntry: DLL_PROCESS_DETACH\r\n")));
            break;

        default:
            break;
    }

    // return TRUE for success, FALSE for failure
    return TRUE;
}

////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////
//              Windows CE Device Driver Entry Points
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////

////////////////////////////////////////////////////////////////////////
//              Initialize Device
////////////////////////////////////////////////////////////////////////

BOOL CAM_Deinit(DWORD hDeviceContext);

DWORD
CAM_Init(DWORD pContext)
{
    DEVICE_CONTEXT *pDevice = 0;
    PHYSICAL_ADDRESS    PhysAddr;

    DEBUGMSG(ZONE_TRACE, (TEXT("CAM: CAM_Init(%s)\r\n"), pContext));

    // Allocate device context.
    pDevice = LocalAlloc(LPTR, sizeof(DEVICE_CONTEXT));

    if ( ! pDevice )
    {
        DEBUGMSG(ZONE_ERROR, (TEXT("CAM_Init: Failed to allocate device context\r\n")));
        goto error_exit;
    }
    memset(pDevice, 0, sizeof(*pDevice));

    // Map Camera Interface Module registers.
    PhysAddr.HighPart = 0;
    PhysAddr.LowPart  = CIM_PHYS_ADDR;
    pCim = MmMapIoSpace(PhysAddr, sizeof(AU1200_CIM), FALSE);
    if ( pCim == NULL )
    {
        DEBUGMSG(ZONE_ERROR, (TEXT("CAM_Init: MmMapIoSpace 0x%08X Failed!\r\n"),
                        CIM_PHYS_ADDR));
        goto error_exit;
    }

    DEBUGMSG(ZONE_TRACE, (TEXT("CAM_Init: CIM:  physical 0x%08X => virtual 0x%08X\r\n"),
                    PhysAddr.LowPart, pCim));

    // Map board contol registers.
    PhysAddr.HighPart = 0;
    PhysAddr.LowPart  = BCSR_PHYSADDR;
    pBcsr = MmMapIoSpace(PhysAddr, sizeof(BCSR), FALSE);
    if ( pBcsr == NULL )
    {
        DEBUGMSG(ZONE_ERROR, (TEXT("CAM_Init: MmMapIoSpace 0x%08X Failed!\r\n"),
                        BCSR_PHYSADDR));
        goto error_exit;
    }

    DEBUGMSG(ZONE_TRACE, (TEXT("CAM_Init: BCSR: physical 0x%08X => virtual 0x%08X\r\n"),
                    PhysAddr.LowPart, pBcsr));

    // Hook the interrupt.
    if ((pDevice->hInterruptEvent = CreateEvent(NULL, FALSE, FALSE, NULL)) == INVALID_HANDLE_VALUE)
    {
        DEBUGMSG(ZONE_ERROR, (TEXT("CAM_Init: cannot create the interrupt event!\r\n")));
        pDevice->hInterruptEvent = 0; // so it looks like we didn't even try to create it
        goto error_exit;
    }
    if ((pDevice->dwSysintr = InterruptConnect(Internal, 0, HWINTR_CIM, 0)) == SYSINTR_NOP)
    {
        DEBUGMSG(ZONE_ERROR, (TEXT("CAM_Init: cannot allocate a sysintr for the CIM!\r\n")));
        goto error_exit;
    }
    if (!InterruptInitialize(pDevice->dwSysintr, pDevice->hInterruptEvent, NULL, 0))
    {
        DEBUGMSG(ZONE_ERROR, (TEXT("CAM_Init: cannot init the CIM interrupt!\r\n")));
        goto error_exit;
    }

    // Initialize global flags.
    pDevice->bPowerIsOn    = FALSE;
    pDevice->dwCurrentMode = 0;

    // Done.
    return((DWORD) pDevice);

error_exit:

    if ( pDevice )
    {
        // This also frees the allocated memory for pDevice:
        CAM_Deinit((DWORD) pDevice);
    }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品一区在线| 国产夜色精品一区二区av| 国产一区二区三区在线观看免费| 国产精品美女视频| 欧美一级专区免费大片| 99久久综合99久久综合网站| 蜜桃视频免费观看一区| 亚洲色图20p| 久久久精品中文字幕麻豆发布| 色婷婷久久久亚洲一区二区三区 | av中文字幕一区| 日韩国产成人精品| 最新成人av在线| 久久久久九九视频| 欧美一级淫片007| 欧美视频完全免费看| 91在线云播放| 国产成人精品一区二| 男男视频亚洲欧美| 亚洲在线观看免费视频| 亚洲免费毛片网站| 国产精品欧美一区喷水| 久久久久久久久免费| 91麻豆精品国产91久久久更新时间| 色悠久久久久综合欧美99| 成人精品免费网站| 国产丶欧美丶日本不卡视频| 蜜桃av噜噜一区二区三区小说| 亚洲午夜精品网| 亚洲影院在线观看| 亚洲精品高清视频在线观看| 18欧美亚洲精品| 日本一区二区三区视频视频| 久久久久久一级片| 精品盗摄一区二区三区| 日韩欧美一区电影| 91精品久久久久久久99蜜桃| 9191国产精品| 欧美精品高清视频| 欧美乱妇23p| 5858s免费视频成人| 91精品国产综合久久精品| 欧美精品久久久久久久久老牛影院| 欧美日韩亚洲国产综合| 欧美三级一区二区| 91麻豆精品91久久久久同性| 91精品国产综合久久精品麻豆| 欧美一区二区三区影视| 日韩片之四级片| 欧美不卡一区二区三区| 精品国精品国产尤物美女| 久久综合久久99| 久久亚洲一区二区三区四区| 亚洲国产高清aⅴ视频| 国产精品久久久一本精品| 亚洲视频每日更新| 亚洲国产日韩精品| 麻豆成人在线观看| 国产精品1区2区| 99精品桃花视频在线观看| 欧美在线播放高清精品| 欧美日本在线一区| 精品三级在线看| 中文字幕av一区二区三区免费看 | 午夜精品在线视频一区| 美腿丝袜在线亚洲一区| 国产成人精品亚洲777人妖| 成人久久18免费网站麻豆| 色视频欧美一区二区三区| 欧美日韩国产一级片| 精品福利av导航| 国产精品污污网站在线观看| 亚洲欧美国产三级| 免费成人结看片| 国产成人综合在线播放| 日本高清无吗v一区| 欧美一区二区啪啪| 国产欧美日韩精品在线| 亚洲小少妇裸体bbw| 精品一区二区精品| 一本到高清视频免费精品| 91麻豆精品国产91久久久资源速度| 久久综合狠狠综合久久综合88| 亚洲欧美日韩国产手机在线 | 国产欧美日本一区视频| 亚洲天堂av老司机| 精品一区二区成人精品| 色偷偷一区二区三区| 精品日韩在线一区| 一区二区三区中文字幕电影| 九色porny丨国产精品| 色婷婷久久久综合中文字幕| 精品国产一区二区三区久久久蜜月| 日韩伦理av电影| 老色鬼精品视频在线观看播放| caoporm超碰国产精品| 欧美mv和日韩mv的网站| 亚洲午夜电影在线| 成人动漫视频在线| 欧美va亚洲va国产综合| 亚洲va欧美va天堂v国产综合| 国产91精品在线观看| 91麻豆精品国产91久久久久久久久 | 1024成人网| 免播放器亚洲一区| 在线免费观看不卡av| 国产日产欧美精品一区二区三区| 日本伊人精品一区二区三区观看方式| 99久久99久久久精品齐齐| 2019国产精品| 99天天综合性| 久久久久久久久蜜桃| 日韩国产精品91| 欧美三级电影在线看| 国产精品成人免费| 国产一区二区三区黄视频| 日韩亚洲欧美一区| 亚洲国产日日夜夜| 欧美在线免费视屏| 亚洲黄色在线视频| caoporm超碰国产精品| 国产欧美日韩卡一| 国产毛片精品国产一区二区三区| 日韩一区二区三| 三级久久三级久久久| 欧美日韩免费视频| 1024精品合集| 91小视频免费看| 亚洲毛片av在线| 9i在线看片成人免费| 国产精品视频一区二区三区不卡| 国产乱子伦视频一区二区三区 | 色就色 综合激情| 亚洲欧美综合在线精品| 97se狠狠狠综合亚洲狠狠| 国产精品美女久久久久久久网站| 成人免费看视频| 亚洲日本va午夜在线影院| 不卡高清视频专区| 18涩涩午夜精品.www| 色婷婷综合久久久中文一区二区| 国产精品国模大尺度视频| 波多野结衣精品在线| 中文字幕不卡的av| 91一区二区三区在线播放| 亚洲精品视频在线看| 欧美亚洲国产一区在线观看网站| 一区二区三区四区中文字幕| 91激情五月电影| 五月天激情综合| 精品国内二区三区| 国产高清成人在线| 中文字幕在线视频一区| 一本色道久久加勒比精品| 亚洲一区二区三区四区不卡| 91麻豆精品久久久久蜜臀| 国模娜娜一区二区三区| 中文无字幕一区二区三区 | 欧美一级片在线| 激情综合网天天干| 中文乱码免费一区二区| 一本色道亚洲精品aⅴ| 日韩黄色免费电影| xfplay精品久久| 色综合色狠狠综合色| 亚洲大片免费看| 精品国产精品网麻豆系列| 亚洲卡通欧美制服中文| 国产日韩精品一区二区三区在线| 亚洲精品国产第一综合99久久 | 欧美这里有精品| 成人av电影免费观看| 一区二区三区丝袜| 欧美一三区三区四区免费在线看| 久88久久88久久久| 亚洲va欧美va国产va天堂影院| 成人av免费在线播放| 久久久综合精品| 91免费精品国自产拍在线不卡 | 亚洲一区二区三区三| 日韩精品一区二区在线| 波多野结衣91| 美女性感视频久久| 综合电影一区二区三区| 日韩一级免费一区| 95精品视频在线| 裸体一区二区三区| 亚洲色图视频网| 久久综合丝袜日本网| 欧美午夜不卡视频| 国产盗摄视频一区二区三区| 午夜在线电影亚洲一区| 国产网站一区二区| 日韩一区二区在线观看视频| 成人av网站免费| 国产乱理伦片在线观看夜一区| 亚洲va国产va欧美va观看| 中文字幕色av一区二区三区| 精品少妇一区二区三区在线视频| 欧美怡红院视频|