camera.cpp
资源名称:SMDK2440.rar [点击查看]
上传用户:qiulin1960
上传日期:2013-10-16
资源大小:2844k
文件大小:42k
源码类别:
Windows CE
开发平台:
Windows_Unix
- #include <windows.h>
- #include <nkintr.h>
- #include <oalintr.h>
- //#include <p2.h>
- #include <pm.h>
- #include "pmplatform.h"
- #include "s2440.h"
- #include "camif.h"
- #include "camera.h"
- #define MSG_EN_1 0
- #define MSG_EN_2 0
- //#define RETAILMSG(a,b) RETAILMSG(1,b)
- #define DOTNET_DRIVER 1 // 0:PPC, 1:CE.NET
- #define CAPTURE_TIME 30
- #define DISPLAY_SCHEDULE 0
- #define U8 unsigned char
- #define U16 unsigned short
- #define U32 unsigned int
- #define PORT_A 1
- #define PORT_B 0
- // Added 25 May 2004 for debug
- #ifdef DEBUG
- #define ZONE_INIT 1
- #define ZONE_THREAD 1
- #endif
- #define YCbCrtoR(Y,Cb,Cr) (1000*Y + 1540*(Cr-128))/1000
- #define YCbCrtoG(Y,Cb,Cr) (1000*Y - 459*(Cb-128) - 183*(Cr-128))/1000
- #define YCbCrtoB(Y,Cb,Cr) (1000*Y + 1856*(Cb-128))/1000
- volatile IOPreg *s2440IOP = (IOPreg *)IOP_BASE;
- volatile CAMreg *s2440CAM = (CAMreg *)CAM_BASE;
- volatile INTreg *s2440INT = (INTreg *)INT_BASE;
- volatile CLKPWRreg *s2440PWR = (CLKPWRreg *)CLKPWR_BASE;
- volatile IICreg *s2440IIC = (IICreg *)IIC_BASE;;
- unsigned int DisplayTime = INFINITE;
- //unsigned char DisplayEnable=0;
- unsigned char buffer_num=0xff; // ping pong buffer
- unsigned char image_size = 2; // 1: QCIF, 2:CIF (default)
- //#define DRIVER_PREVIEW_ENABLE 2 // 0: onTimeTek, 1: Preview, 2:Samsung Camcorder
- unsigned char DRIVER_PREVIEW_ENABLE = 2; // 0: onTimeTek, 1: Preview, 2:Samsung Camcorder
- unsigned int frame_count=0; // for MPEG4
- DWORD Tick_GET_FRAME_CUR;
- DWORD Tick_GET_FRAME_PREV;
- DWORD Tick_COPY_FRAME;
- HANDLE CameraThread;
- HANDLE CameraEvent;
- static BOOL mInitialized = FALSE;
- unsigned char codec_flag=0;
- unsigned char rgb_flag=0;
- unsigned int y_address,cb_address,cr_address;
- unsigned int rgb_address;
- extern void Camera_Initialize();
- extern volatile IOPreg *s2440IOP;
- extern volatile IICreg *s2440IIC;
- void Virtual_Alloc(); // Virtual allocation
- void Camera_Clock(unsigned char divide); // set default value
- void Camif_Capture(int cap_a, int cap_b); // A port, B port
- void Display_Cam_Image(U32 pos_x, U32 pos_y, U32 size_x, U32 size_y, U8 port);
- void Copy_Cam_Image(U8 * pBufOut, U32 size_x, U32 size_y, U8 port);
- void Samsung_camcoder(U8 *pBufOut);
- void Samsung_camcoder_pr(U8 *pBufOut);
- void Buffer_codec_info_update();
- void Buffer_preview_info_update();
- BOOL Cam_Init();
- BOOL CamClockOn(BOOL bOnOff);
- //void CamCaptureStart(U32 mode);
- void CamInit(U32 CoDstWidth, U32 CoDstHeight, U32 PrDstWidth, U32 PrDstHeight,
- U32 WinHorOffset, U32 WinVerOffset, U32 CoFrameBuffer, U32 PrFrameBuffer);
- DWORD CameraCaptureThread(void);
- BOOL InitInterruptThread();
- CEDEVICE_POWER_STATE m_Dx;
- #ifdef DEBUG
- DBGPARAM dpCurSettings = {
- TEXT("CAMERA"), {
- TEXT("0"),TEXT("1"),TEXT("2"),TEXT("3"),
- TEXT("4"),TEXT("5"),TEXT("6"),TEXT("7"),
- TEXT("8"),TEXT("9"),TEXT("10"),TEXT("11"),
- TEXT("12"),TEXT("Function"),TEXT("Init"),TEXT("Error")},
- 0x8000 // Errors only, by default
- };
- #endif
- static void Delay(USHORT count)
- {
- volatile int i, j = 0;
- volatile static int loop = S2440FCLK/100000;
- for(;count > 0;count--)
- for(i=0;i < loop; i++) { j++; }
- }
- /********************************************************
- CalculateBurstSize - Calculate the busrt lengths
- Description:
- - dstHSize: the number of the byte of H Size.
- */
- void CalculateBurstSize(unsigned int hSize,unsigned int *mainBurstSize,unsigned int *remainedBurstSize)
- {
- unsigned int tmp;
- tmp=(hSize/4)%16;
- switch(tmp) {
- case 0:
- *mainBurstSize=16;
- *remainedBurstSize=16;
- break;
- case 4:
- *mainBurstSize=16;
- *remainedBurstSize=4;
- break;
- case 8:
- *mainBurstSize=16;
- *remainedBurstSize=8;
- break;
- default:
- tmp=(hSize/4)%8;
- switch(tmp) {
- case 0:
- *mainBurstSize=8;
- *remainedBurstSize=8;
- break;
- case 4:
- *mainBurstSize=8;
- *remainedBurstSize=4;
- default:
- *mainBurstSize=4;
- tmp=(hSize/4)%4;
- *remainedBurstSize= (tmp) ? tmp: 4;
- break;
- }
- break;
- }
- }
- /********************************************************
- CalculatePrescalerRatioShift - none
- Description:
- - none
- */
- void CalculatePrescalerRatioShift(unsigned int SrcSize, unsigned int DstSize, unsigned int *ratio,unsigned int *shift)
- {
- if(SrcSize>=64*DstSize) {
- // Uart_Printf("ERROR: out of the prescaler range: SrcSize/DstSize = %d(< 64)rn",SrcSize/DstSize);
- while(1);
- }
- else if(SrcSize>=32*DstSize) {
- *ratio=32;
- *shift=5;
- }
- else if(SrcSize>=16*DstSize) {
- *ratio=16;
- *shift=4;
- }
- else if(SrcSize>=8*DstSize) {
- *ratio=8;
- *shift=3;
- }
- else if(SrcSize>=4*DstSize) {
- *ratio=4;
- *shift=2;
- }
- else if(SrcSize>=2*DstSize) {
- *ratio=2;
- *shift=1;
- }
- else {
- *ratio=1;
- *shift=0;
- }
- }
- void Camera_Clock(unsigned char divide)
- {
- unsigned int camclk;
- // Set camera clock for camera processor
- s2440PWR->rCAMDIVN = (s2440PWR->rCAMDIVN & ~(0x1f)) | (1<<4) | (divide & 0xf); // CAMCLK is divided..
- camclk = 48000000/(((s2440PWR->rCAMDIVN&0xf) + 1)*2);
- RETAILMSG(1,(TEXT("CAM clock:%drn"),camclk));
- }
- /*
- void CamCaptureStart(unsigned int mode)
- {
- if(mode&CAM_CODEC_SCALER_CAPTURE_ENABLE_BIT) {
- s2440CAM->rCICOSCCTRL|=CAM_CODEC_SACLER_START_BIT;
- }
- if(mode&CAM_PVIEW_SCALER_CAPTURE_ENABLE_BIT) {
- s2440CAM->rCIPRSCCTRL|=CAM_PVIEW_SACLER_START_BIT;
- }
- s2440CAM->rCIIMGCPT|=(CAM_CAMIF_GLOBAL_CAPTURE_ENABLE_BIT|mode);
- }
- */
- void Camif_Capture(int cap_a, int cap_b)
- {
- //RETAILMSG(1,(_T("Camif_Capture(%d, %d)rn"), cap_a, cap_b));
- // S3C2440A
- s2440CAM->rCIIMGCPT &= ~(CAM_CAMIF_GLOBAL_CAPTURE_ENABLE_BIT);
- if(cap_b == CAPTURE_ON)
- {
- //Codec capture start
- s2440CAM->rCICOSCCTRL |=(CAM_CODEC_SACLER_START_BIT);
- s2440CAM->rCIIMGCPT |=(CAM_CAMIF_GLOBAL_CAPTURE_ENABLE_BIT)|(CAM_CODEC_SCALER_CAPTURE_ENABLE_BIT);
- }
- else if (cap_b == CAPTURE_OFF)
- {
- s2440CAM->rCICOSCCTRL &= ~(CAM_CODEC_SACLER_START_BIT);
- s2440CAM->rCIIMGCPT &= ~(CAM_CODEC_SCALER_CAPTURE_ENABLE_BIT);
- }
- if(cap_a == CAPTURE_ON)
- {
- // Preview capture Start
- s2440CAM->rCIPRSCCTRL |=(CAM_PVIEW_SACLER_START_BIT);
- s2440CAM->rCIIMGCPT |=(CAM_CAMIF_GLOBAL_CAPTURE_ENABLE_BIT)|(CAM_PVIEW_SCALER_CAPTURE_ENABLE_BIT);
- }
- else if (cap_a == CAPTURE_OFF)
- {
- s2440CAM->rCIPRSCCTRL &= ~(CAM_PVIEW_SACLER_START_BIT);
- s2440CAM->rCIIMGCPT &= ~(CAM_PVIEW_SCALER_CAPTURE_ENABLE_BIT);
- }
- if ((cap_a == CAPTURE_ON) || (cap_b == CAPTURE_ON))
- {
- s2440CAM->rCIIMGCPT |= (CAM_CAMIF_GLOBAL_CAPTURE_ENABLE_BIT);
- }
- }
- DWORD CameraCaptureThread(void)
- {
- unsigned char tmp=0;
- static unsigned int time,old_time;
- static unsigned int cam_intr;
- while(1)
- {
- WaitForSingleObject(CameraEvent, DisplayTime);
- RETAILMSG(MSG_EN_1,(_T("CameraCaptureThread(%d)++rn"), frame_count));
- #if 0
- if (frame_count <= 2) {
- frame_count++;
- // Enable camera interrupt
- s2440INT->rINTSUBMSK &= ~(BIT_SUB_CAM_P|BIT_SUB_CAM_C);
- s2440INT->rINTMSK &= ~BIT_CAM;
- continue;
- }
- #endif
- //if( DisplayEnable )
- {
- frame_count++;
- if (s2440INT->rINTSUBMSK & BIT_SUB_CAM_C)
- {
- cam_intr = BIT_SUB_CAM_C;
- //RETAILMSG(1,(_T("CAM_C, ts %drn"), GetTickCount()));
- }
- else if (s2440INT->rINTSUBMSK & BIT_SUB_CAM_P)
- {
- cam_intr = BIT_SUB_CAM_P;
- //RETAILMSG(1,(_T("CAM_P, ts %drn"), GetTickCount()));
- }
- // EINT20 to measure time
- // s2440IOP->rGPGDAT |= (1<<12);
- // time = GetTickCount();
- // RETAILMSG(1,(TEXT("+time:%drn"),(time - old_time)));
- // delay for capture
- //Sleep(CAPTURE_TIME); // polling mode
- // display the image
- if ((DRIVER_PREVIEW_ENABLE == 1) & (cam_intr == BIT_SUB_CAM_P))
- Display_Cam_Image(64, 64, QCIF_XSIZE, QCIF_YSIZE, PORT_A);
- //else if (DRIVER_PREVIEW_ENABLE == 2)
- if (cam_intr == BIT_SUB_CAM_C)
- {
- Buffer_codec_info_update();
- }
- if (cam_intr == BIT_SUB_CAM_P)
- {
- Buffer_preview_info_update();
- }
- // Enable camera interrupt
- s2440INT->rINTSUBMSK &= ~(BIT_SUB_CAM_P|BIT_SUB_CAM_C);
- s2440INT->rINTMSK &= ~BIT_CAM;
- /*
- if (DRIVER_PREVIEW_ENABLE == 1)
- Camif_Capture(CAPTURE_ON, CAPTURE_OFF);
- else if (DRIVER_PREVIEW_ENABLE == 2)
- Camif_Capture(CAPTURE_OFF, CAPTURE_ON);
- */
- // EINT20 to measure time
- // s2440IOP->rGPGDAT &= ~(1<<12);
- // old_time = GetTickCount();
- // RETAILMSG(1,(TEXT("-time:%drn"),(old_time-time)));
- }
- }
- }
- void Virtual_Alloc()
- {
- // GPIO Virtual alloc
- s2440IOP = (volatile IOPreg *) VirtualAlloc(0,sizeof(IOPreg),MEM_RESERVE, PAGE_NOACCESS);
- if(s2440IOP == NULL) {
- RETAILMSG(1,(TEXT("For s2440IOP: VirtualAlloc failed!rn")));
- }
- else {
- if(!VirtualCopy((PVOID)s2440IOP,(PVOID)(IOP_BASE),sizeof(IOPreg),PAGE_READWRITE | PAGE_NOCACHE )) {
- RETAILMSG(1,(TEXT("For s2440IOP: VirtualCopy failed!rn")));
- }
- }
- // IIC Virtual alloc
- s2440IIC = (volatile IICreg *) VirtualAlloc(0,sizeof(IICreg),MEM_RESERVE, PAGE_NOACCESS);
- if(s2440IIC == NULL) {
- RETAILMSG(1,(TEXT("For s2440IIC: VirtualAlloc failed!rn")));
- }
- else {
- if(!VirtualCopy((PVOID)s2440IIC,(PVOID)(IIC_BASE),sizeof(IICreg),PAGE_READWRITE | PAGE_NOCACHE )) {
- RETAILMSG(1,(TEXT("For s2440IIC: VirtualCopy failed!rn")));
- }
- }
- // Camera Virtual alloc
- s2440CAM = (volatile CAMreg *) VirtualAlloc(0,sizeof(CAMreg),MEM_RESERVE, PAGE_NOACCESS);
- if(s2440CAM == NULL) {
- RETAILMSG(1,(TEXT("For s2440CAM: VirtualAlloc failed!rn")));
- }
- else {
- if(!VirtualCopy((PVOID)s2440CAM,(PVOID)(CAM_BASE),sizeof(CAMreg),PAGE_READWRITE | PAGE_NOCACHE )) {
- RETAILMSG(1,(TEXT("For s2440CAM: VirtualCopy failed!rn")));
- }
- }
- // Interrupt Virtual alloc
- s2440INT = (volatile INTreg *) VirtualAlloc(0,sizeof(INTreg),MEM_RESERVE, PAGE_NOACCESS);
- if(s2440INT == NULL) {
- RETAILMSG(1,(TEXT("For s2440INT: VirtualAlloc failed!rn")));
- }
- else {
- if(!VirtualCopy((PVOID)s2440INT,(PVOID)(INT_BASE),sizeof(INTreg),PAGE_READWRITE | PAGE_NOCACHE )) {
- RETAILMSG(1,(TEXT("For s2440INT: VirtualCopy failed!rn")));
- }
- }
- // PWM clock Virtual alloc
- s2440PWR = (volatile CLKPWRreg *) VirtualAlloc(0,sizeof(CLKPWRreg),MEM_RESERVE, PAGE_NOACCESS);
- if(s2440PWR == NULL) {
- RETAILMSG(1,(TEXT("For s2440PWR: VirtualAlloc failed!rn")));
- }
- else {
- if(!VirtualCopy((PVOID)s2440PWR,(PVOID)(CLKPWR_BASE),sizeof(CLKPWRreg),PAGE_READWRITE | PAGE_NOCACHE )) {
- RETAILMSG(1,(TEXT("For s2440PWR: VirtualCopy failed!rn")));
- }
- }
- }
- void Display_Cam_Image(U32 pos_x, U32 pos_y, U32 size_x, U32 size_y, U8 port)
- {
- U8 *buffer_rgb;
- U32 y;
- int temp;
- //unsigned short *ptr = (unsigned short *)(FRAMEBUF_BASE+0x5dc0);
- static unsigned short transfer_data[QCIF_XSIZE*QCIF_YSIZE];
- static unsigned int time,old_time;
- //RETAILMSG(1,(_T("Display_Cam_Image()rn")));
- // if (port)
- {
- temp = (s2440CAM->rCIPRSTATUS>>26)&3;
- temp = (temp + 2) % 4;
- switch (temp)
- {
- case 0:
- buffer_rgb = (U8 *)s2440CAM->rCIPRCLRSA1;
- break;
- case 1:
- buffer_rgb = (U8 *)s2440CAM->rCIPRCLRSA2;
- break;
- case 2:
- buffer_rgb = (U8 *)s2440CAM->rCIPRCLRSA3;
- break;
- case 3:
- buffer_rgb = (U8 *)s2440CAM->rCIPRCLRSA4;
- break;
- default :
- buffer_rgb = (U8 *)s2440CAM->rCIPRCLRSA1;
- break;
- }
- }
- RETAILMSG(MSG_EN_1,(_T("preview buf index = %drn"), temp));
- #if (DOTNET_DRIVER)
- SetKMode(TRUE);
- #endif
- buffer_rgb += VIRTUAL_OFFSET;
- // time = GetTickCount();
- // RETAILMSG(1,(TEXT("+:%drn"),(time - old_time)));
- #if 1
- for (y=0;y<(size_y-2);y++) // YCbCr 4:2:0 format
- {
- //memcpy((void *)(FRAMEBUF_BASE+0x5e00+y*240*2),(void *)buffer_rgb,(QCIF_XSIZE)*2);
- memcpy((void *)(FRAMEBUF_BASE+ (240*pos_y + pos_x) + y*240*2),(void *)buffer_rgb,(QCIF_XSIZE)*2);
- buffer_rgb += (QCIF_XSIZE*2);
- }
- #endif
- #if (DOTNET_DRIVER)
- SetKMode(FALSE);
- #endif
- // old_time = GetTickCount();
- // RETAILMSG(1,(TEXT("-:%drn"),(old_time - time)));
- }
- BOOL WINAPI
- DllEntry(HANDLE hinstDLL,
- DWORD dwReason,
- LPVOID /* lpvReserved */)
- {
- switch(dwReason)
- {
- case DLL_PROCESS_ATTACH:
- DEBUGREGISTER((HINSTANCE)hinstDLL);
- DEBUGMSG(ZONE_INIT,(TEXT("CAMERA: DLL_PROCESS_ATTACHrn")));
- return TRUE;
- case DLL_THREAD_ATTACH:
- DEBUGMSG(ZONE_THREAD,(TEXT("CAMERA: DLL_THREAD_ATTACHrn")));
- break;
- case DLL_THREAD_DETACH:
- DEBUGMSG(ZONE_THREAD,(TEXT("CAMERA: DLL_THREAD_DETACHrn")));
- break;
- case DLL_PROCESS_DETACH:
- DEBUGMSG(ZONE_INIT,(TEXT("CAMERA: DLL_PROCESS_DETACHrn")));
- break;
- #ifdef UNDER_CE
- case DLL_PROCESS_EXITING:
- DEBUGMSG(ZONE_INIT,(TEXT("CAMERA: DLL_PROCESS_EXITINGrn")));
- break;
- case DLL_SYSTEM_STARTED:
- DEBUGMSG(ZONE_INIT,(TEXT("CAMERA: DLL_SYSTEM_STARTEDrn")));
- break;
- #endif
- }
- return TRUE;
- }
- //-----------------------------------------------------------------------------
- //-----------------------------------------------------------------------------
- BOOL CIS_Deinit(DWORD hDeviceContext)
- {
- BOOL bRet = TRUE;
- RETAILMSG(1,(TEXT("CAMERA: CIS_Deinitrn")));
- s2440INT->rINTMSK |= BIT_CAM;
- s2440INT->rINTSUBMSK |= (BIT_SUB_CAM_P|BIT_SUB_CAM_C);
- Camif_Capture(CAPTURE_OFF, CAPTURE_OFF);
- //DisplayEnable = 0;
- DRIVER_PREVIEW_ENABLE = 2;
- CloseHandle(CameraThread);
- VirtualFree((void*)s2440IOP, sizeof(IOPreg), MEM_RELEASE);
- VirtualFree((void*)s2440CAM, sizeof(CAMreg), MEM_RELEASE);
- VirtualFree((void*)s2440INT, sizeof(INTreg), MEM_RELEASE);
- VirtualFree((void*)s2440PWR, sizeof(CLKPWRreg), MEM_RELEASE);
- VirtualFree((void*)s2440IIC, sizeof(IICreg), MEM_RELEASE);
- return TRUE;
- }
- BOOL InitInterruptThread()
- {
- DWORD threadID; // thread ID
- BOOL bSuccess;
- CameraEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
- if (!CameraEvent)
- {
- return FALSE;
- }
- bSuccess = InterruptInitialize(SYSINTR_CAM, CameraEvent, NULL, 0);
- if (!bSuccess)
- {
- RETAILMSG(1,(TEXT("Fail to initialize camera interrupt eventrn")));
- return FALSE;
- }
- CameraThread = CreateThread(NULL,
- 0,
- (LPTHREAD_START_ROUTINE)CameraCaptureThread,
- 0,
- 0,
- &threadID);
- if (NULL == CameraThread ) {
- RETAILMSG(1,(TEXT("Create Camera Thread Failrn")));
- }
- RETAILMSG(1,(_T("CAMERA.DLL::InterruptThread Initialized.rn")));
- return TRUE;
- }
- BOOL CamClockOn(BOOL bOnOff)
- {
- // Camera clock
- if (!bOnOff)
- s2440PWR->rCLKCON &= ~(1<<19); // Camera clock disable
- s2440PWR->rCLKCON |= (1<<19); // Camera clock enable
- Camera_Clock(CAM_CLK_DIV);
- RETAILMSG(1,(_T("CamClockOn = %drn"), bOnOff));
- Delay(1000);
- return TRUE;
- }
- BOOL CamGpioInit()
- {
- s2440IOP->rGPJCON = 0x2aaaaaa;
- s2440IOP->rGPJDAT = 0;
- s2440IOP->rGPJUP = 0x1fff;
- return TRUE;
- }
- void CAM_IF_Reset()
- {
- // This functin is used on power handler operation.
- // So, you should not use Kernel API functions as like as "Sleep()".
- //
- // Camera (FIMC2.0) I/F Reset
- //
- //s2440CAM->rCTRL_C = (1<<19); // 2440X
- s2440CAM->rCIGCTRL |= (1<<31);
- // Don't modify this delay time
- RETAILMSG(1,(TEXT("Camera I/F Resetrn")));
- Delay(100);
- //s2440CAM->rCTRL_C = (0<<19);
- s2440CAM->rCIGCTRL &= ~(1<<31);
- // Wait for Camera module initialization
- Delay(1000);
- }
- void Camera_Module_Reset()
- {
- //s2440CAM->rCTRL_C = (1<<19); // 2440X
- s2440CAM->rCIGCTRL |= (1<<30);
- // Don't modify this delay time
- RETAILMSG(1,(TEXT("Camera Module Resetrn")));
- //Delay(10);
- Sleep(1);
- //s2440CAM->rCTRL_C = (0<<19);
- s2440CAM->rCIGCTRL &= ~(1<<30);
- // Wait for Camera module initialization
- //Delay(100);
- Sleep(10);
- // Samsung Camera need delay time between camera clock enable and camera reset.
- //RETAILMSG(1,(TEXT("You need delay timern")));
- //Delay(1000);
- Sleep(10);
- }
- BOOL Cam_Init()
- {
- //
- // 1. Camera IO setup
- //
- CamGpioInit();
- // 2. Camera i/f reset
- CAM_IF_Reset();
- //
- // 3. Camera Clock setup
- //
- CamClockOn(TRUE);
- // 4. Camera Module Reset
- Camera_Module_Reset();
- // 5. set register of camera module through IIC
- Camera_Initialize();
- // to check time
- s2440IOP->rGPGCON &= ~(0x3<<24);
- s2440IOP->rGPGCON |= (0x1<<24); // EINT20
- if (image_size == 1)
- CamInit(QCIF_XSIZE, QCIF_YSIZE, QCIF_XSIZE, QCIF_YSIZE, 112, 20, COPIFRAMEBUFFER_B, COPIFRAMEBUFFER_A);
- else if (image_size == 2)
- CamInit(CIF_XSIZE, CIF_YSIZE, QCIF_XSIZE, QCIF_YSIZE, 112, 20, COPIFRAMEBUFFER_B, COPIFRAMEBUFFER_A);
- //RETAILMSG(1,(_T("CamInit().. donern")));
- return TRUE;
- }
- DWORD CIS_Init(DWORD dwContext)
- {
- // 1. Virtual Alloc
- Virtual_Alloc();
- Cam_Init();
- if (!InitInterruptThread())
- {
- RETAILMSG(1,(TEXT("Fail to initialize camera interrupt eventrn")));
- return FALSE;
- }
- m_Dx = (_CEDEVICE_POWER_STATE)D0;
- DevicePowerNotify(_T("CIS1:"),(_CEDEVICE_POWER_STATE)D0, POWER_NAME);
- mInitialized = TRUE;
- return TRUE;
- }
- //-----------------------------------------------------------------------------
- //-----------------------------------------------------------------------------
- BOOL CIS_IOControl(DWORD hOpenContext,
- DWORD dwCode,
- PBYTE pBufIn,
- DWORD dwLenIn,
- PBYTE pBufOut,
- DWORD dwLenOut,
- PDWORD pdwActualOut)
- {
- BOOL RetVal = TRUE;
- DWORD dwErr = ERROR_SUCCESS;
- static unsigned int time=0,old_time=0;
- switch (dwCode)
- {
- //-----------------------------------------------------------------------------------------
- case IOCTL_POWER_CAPABILITIES:
- {
- PPOWER_CAPABILITIES ppc;
- RETAILMSG(1, (TEXT("CIS: IOCTL_POWER_CAPABILITIESrn")));
- if ( !pdwActualOut || !pBufOut || (dwLenOut < sizeof(POWER_CAPABILITIES)) ) {
- RetVal = FALSE;
- dwErr = ERROR_INVALID_PARAMETER;
- break;
- }
- ppc = (PPOWER_CAPABILITIES)pBufOut;
- memset(ppc, 0, sizeof(POWER_CAPABILITIES));
- // support D0, D4
- ppc->DeviceDx = 0x11;
- // Report our power consumption in uAmps rather than mWatts.
- ppc->Flags = POWER_CAP_PREFIX_MICRO | POWER_CAP_UNIT_AMPS;
- // 25 m = 25000 uA
- // TODO: find out a more accurate value
- ppc->Power[D0] = 25000;
- *pdwActualOut = sizeof(POWER_CAPABILITIES);
- } break;
- case IOCTL_POWER_SET:
- {
- CEDEVICE_POWER_STATE NewDx;
- if ( !pdwActualOut || !pBufOut || (dwLenOut < sizeof(CEDEVICE_POWER_STATE)) ) {
- RetVal = FALSE;
- dwErr = ERROR_INVALID_PARAMETER;
- break;
- }
- NewDx = *(PCEDEVICE_POWER_STATE)pBufOut;
- if ( VALID_DX(NewDx) ) {
- switch ( NewDx ) {
- case D0:
- if (m_Dx != D0) {
- CIS_PowerUp(hOpenContext);
- m_Dx = D0;
- }
- break;
- default:
- if (m_Dx != (_CEDEVICE_POWER_STATE)D4) {
- CIS_PowerDown(hOpenContext);
- m_Dx = (_CEDEVICE_POWER_STATE)D4;
- }
- break;
- }
- // return our state
- *(PCEDEVICE_POWER_STATE)pBufOut = m_Dx;
- RETAILMSG(1, (TEXT("CIS: IOCTL_POWER_SET: D%u rn"), NewDx));
- *pdwActualOut = sizeof(CEDEVICE_POWER_STATE);
- } else {
- RetVal = FALSE;
- dwErr = ERROR_INVALID_PARAMETER;
- }
- } break;
- case IOCTL_POWER_GET:
- if ( !pdwActualOut || !pBufOut || (dwLenOut < sizeof(CEDEVICE_POWER_STATE)) ) {
- RetVal = FALSE;
- dwErr = ERROR_INVALID_PARAMETER;
- break;
- }
- *(PCEDEVICE_POWER_STATE)pBufOut = m_Dx;
- RETAILMSG(1, (TEXT("CIS: IOCTL_POWER_GET: D%u rn"), m_Dx));
- *pdwActualOut = sizeof(CEDEVICE_POWER_STATE);
- break;
- //-----------------------------------------------------------------------------------------
- case IOCTL_CAM_SHOW :
- // Charlie. Show Menu
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SHOW(%x)rn"),dwLenIn));
- break;
- case IOCTL_CAM_HIDE :
- // Charlie. Close display window
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_HIDErn")));
- break;
- case IOCTL_CAM_SETPOS :
- time = GetTickCount();
- // RETAILMSG(MSG_EN_1,(TEXT("Capture time:%d msecrn"), (time-old_time)));
- RETAILMSG(MSG_EN_1,(TEXT("Capture time:%d msecrn"), (time)));
- old_time = time;
- break;
- case CAM_IOCTL_MOVIE_START: // for MPEG4
- case IOCTL_CAM_CONT :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_CONTrn")));
- // Charlie. Play
- //DisplayEnable = 1;
- // Enable camera interrupt
- s2440INT->rINTMSK &= ~BIT_CAM;
- s2440INT->rINTSUBMSK &= ~(BIT_SUB_CAM_P|BIT_SUB_CAM_C);
- #if 0
- if (DRIVER_PREVIEW_ENABLE == 1)
- {
- Camif_Capture(CAPTURE_ON, CAPTURE_OFF);
- }
- else if (DRIVER_PREVIEW_ENABLE == 2)
- {
- Camif_Capture(CAPTURE_OFF, CAPTURE_ON);
- }
- #else
- Camif_Capture(CAPTURE_ON, CAPTURE_ON);
- #endif
- //DisplayTime = DISPLAY_SCHEDULE; // polling mode
- //SetEvent(CameraEvent);
- s2440IOP->rGPGCON &= ~(0x3<<24);
- s2440IOP->rGPGCON |= (0x1<<24); // EINT20
- frame_count = 0; // for MPEG4
- break;
- case CAM_IOCTL_MOVIE_STOP: // for MPEG4
- case IOCTL_CAM_STOP :
- // Charlie. Stop
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_STOPrn")));
- // Disable camera interrupt
- s2440INT->rINTMSK |= BIT_CAM;
- s2440INT->rINTSUBMSK |= (BIT_SUB_CAM_P|BIT_SUB_CAM_C);
- if (s2440INT->rINTPND & BIT_CAM) s2440INT->rINTPND |= BIT_CAM;
- s2440INT->rSRCPND |= BIT_CAM;
- s2440INT->rSUBSRCPND |= (BIT_SUB_CAM_P|BIT_SUB_CAM_C);
- Camif_Capture(CAPTURE_OFF, CAPTURE_OFF);
- //DisplayEnable = 0;
- DRIVER_PREVIEW_ENABLE = 2;
- DisplayTime = INFINITE;
- break;
- // for MPEG4
- case CAM_IOCTL_GET_LATEST_FRAME:
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:CAM_IOCTL_GET_LATEST_FRAMErn")));
- //RETAILMSG(MSG_EN_1,(TEXT("pBufIn = 0x%xrn"), pBufIn));
- //RETAILMSG(MSG_EN_1,(TEXT("no function available, TBDrn")));
- if (frame_count < 2) {
- RETAILMSG(1,(TEXT("CAMERA:CAM_IOCTL_GET_LATEST_FRAME - frame not available!!!rn")));
- return false;
- }
- Tick_GET_FRAME_PREV = Tick_GET_FRAME_CUR;
- Tick_GET_FRAME_CUR = GetTickCount();
- Copy_Cam_Image(pBufOut, QCIF_XSIZE, QCIF_YSIZE, PORT_A);
- break;
- case CAM_IOCTL_SAMSUNG_CAM: // ID=0x520
- RETAILMSG(MSG_EN_1,(_T("CAM_IOCTL_SAMSUNG_CAMrn")));
- Samsung_camcoder(pBufOut);
- break;
- case CAM_IOCTL_SAMSUNG_CAM_PR: // ID=0x522
- RETAILMSG(MSG_EN_1,(_T("CAM_IOCTL_SAMSUNG_CAM_PRrn")));
- Samsung_camcoder_pr(pBufOut);
- break;
- case CAM_IOCTL_SAMSUNG_PREVIEW_START : // ID=0x523
- DRIVER_PREVIEW_ENABLE = 1;
- RETAILMSG(MSG_EN_1,(_T("CAM_IOCTL_SAMSUNG_PREVIEW_START(%x)rn"),*pBufOut, DRIVER_PREVIEW_ENABLE));
- break;
- case CAM_IOCTL_SAMSUNG_PREVIEW_STOP : // ID=0x524
- DRIVER_PREVIEW_ENABLE = 2;
- RETAILMSG(MSG_EN_1,(_T("CAM_IOCTL_SAMSUNG_PREVIEW_STOP(%x)rn"),*pBufOut, DRIVER_PREVIEW_ENABLE));
- break;
- case IOCTL_CAM_SETGAMMA :
- if( *pBufOut == 1 ){
- DRIVER_PREVIEW_ENABLE = 1;
- }
- else if( *pBufOut == 2 ){
- DRIVER_PREVIEW_ENABLE = 2;
- }
- RETAILMSG(MSG_EN_1,(_T("IOCTL_CAM_SETGAMMA:*pBufOut(%x):DRIVER_PREVIEW_ENABLE(%x)rn"),*pBufOut, DRIVER_PREVIEW_ENABLE));
- break;
- case CAM_IOCTL_IMAGE_SIZE: // ID=0x521
- if( *pBufOut == 1 ){
- image_size = 1;
- }
- else if( *pBufOut == 2 ){
- image_size = 2;
- }
- RETAILMSG(MSG_EN_1,(TEXT("image_size:%d,0x%x,0x%xrn"),image_size,pBufOut,*pBufOut));
- s2440INT->rINTMSK |= BIT_CAM;
- s2440INT->rINTSUBMSK |= (BIT_SUB_CAM_P|BIT_SUB_CAM_C);
- Camif_Capture(CAPTURE_OFF, CAPTURE_OFF);
- if (image_size == 1)
- CamInit(QCIF_XSIZE, QCIF_YSIZE, QCIF_XSIZE, QCIF_YSIZE, 112, 20, COPIFRAMEBUFFER_B, COPIFRAMEBUFFER_A);
- else if (image_size == 2)
- CamInit(CIF_XSIZE, CIF_YSIZE, QCIF_XSIZE, QCIF_YSIZE, 112, 20, COPIFRAMEBUFFER_B, COPIFRAMEBUFFER_A);
- break;
- case IOCTL_CAM_COPY :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_COPY(dwLenIn:%x)rn"), dwLenIn));
- break;
- case IOCTL_CAM_SETCOLKEY :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETCOLKEYrn")));
- break;
- case IOCTL_CAM_SETALPHA :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETALPHArn")));
- break;
- case IOCTL_CAM_GETINFO :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_GETINFOrn")));
- break;
- case IOCTL_CAM_SETSCALE :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETSCALErn")));
- break;
- case IOCTL_CAM_SETHUE :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETHUErn")));
- break;
- #if 0
- case IOCTL_CAM_SETGAMMA :
- // Get which ping -pong buffer have data
- //DisplayEnable = 0;
- Sleep(200);
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_BUFFER:%drn"),buffer_num));
- break;
- #endif
- case IOCTL_CAM_SETWBCOORD :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETWBCOORDrn")));
- break;
- case IOCTL_CAM_SETAELIMIT :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETAELIMITrn")));
- break;
- case IOCTL_CAM_SETADCOFS :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETADCOFSrn")));
- break;
- case IOCTL_CAM_SETWBGAIN :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETWBGAINrn")));
- break;
- case IOCTL_CAM_SETCBCRGAIN :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETCBCRGAINrn")));
- break;
- case IOCTL_CAM_SETLEGAIN :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETLEGAINrn")));
- break;
- case IOCTL_CAM_SETBRIGHTNESS :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETBRIGHTNESSrn")));
- break;
- case IOCTL_CAM_SETCLIP :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETCLIPrn")));
- break;
- case IOCTL_CAM_SETSLICELMT :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETSLICELMTrn")));
- break;
- case IOCTL_CAM_WBACCLMT :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_WBACCLMTrn")));
- break;
- case IOCTL_CAM_CSEDGELMT :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_CSEDGELMTrn")));
- break;
- case IOCTL_CAM_ENVINT :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_ENVINTrn")));
- break;
- case IOCTL_CAM_DISVINT :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_DISVINTrn")));
- break;
- case IOCTL_CAM_SETCAMERA :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:IOCTL_CAM_SETCAMERArn")));
- /*
- RETAILMSG(MSG_EN_1,(_T("---------------------------------------rn")));
- RETAILMSG(MSG_EN_1,(_T("ImgCptEn_PRSC = %drn"), (s2440CAM->rCIPRSTATUS>>21)&0x1));
- RETAILMSG(MSG_EN_1,(_T("PrScalerStart = %drn"), (s2440CAM->rCIPRSCCTRL>>15)&0x1));
- RETAILMSG(MSG_EN_1,(_T("---------------------------------------rn")));
- RETAILMSG(MSG_EN_1,(_T("CoScalerStart = %drn"), (s2440CAM->rCICOSCCTRL>>15)&0x1));
- RETAILMSG(MSG_EN_1,(_T("VSYNC = %drn"), (s2440CAM->rCICOSTATUS>>28)&0x1));
- RETAILMSG(MSG_EN_1,(_T("ImgCptEn_Camif = %drn"), (s2440CAM->rCICOSTATUS>>22)&0x1));
- RETAILMSG(MSG_EN_1,(_T("ImgCptEn_CoSC = %drn"), (s2440CAM->rCICOSTATUS>>21)&0x1));
- RETAILMSG(MSG_EN_1,(_T("VSYNC_A = %drn"), (s2440CAM->rCICOSTATUS>>20)&0x1));
- RETAILMSG(MSG_EN_1,(_T("VSYNC_B = %drn"), (s2440CAM->rCICOSTATUS>>19)&0x1));
- RETAILMSG(MSG_EN_1,(_T("---------------------------------------rn")));
- RETAILMSG(MSG_EN_1,(_T("ImgCptEn = %drn"), (s2440CAM->rCIIMGCPT>>31)&0x1));
- RETAILMSG(MSG_EN_1,(_T("ImgCptEn_CoSc = %drn"), (s2440CAM->rCIIMGCPT>>30)&0x1));
- RETAILMSG(MSG_EN_1,(_T("ImgCptEn_PrSc = %drn"), (s2440CAM->rCIIMGCPT>>29)&0x1));
- RETAILMSG(MSG_EN_1,(_T("----------------- %d ----------------------rn"), mInitialized));
- SetEvent(CameraEvent);
- */
- break;
- default :
- RETAILMSG(MSG_EN_1,(TEXT("CAMERA:Ioctl code = 0x%xrn"), dwCode));
- return FALSE;
- }
- return TRUE;
- }
- //-----------------------------------------------------------------------------
- //-----------------------------------------------------------------------------
- DWORD CIS_Open(DWORD hDeviceContext, DWORD AccessCode, DWORD ShareMode)
- {
- RETAILMSG(1,(TEXT("CAMERA: CIS_Openrn")));
- DRIVER_PREVIEW_ENABLE = 2;
- return TRUE;
- }
- //-----------------------------------------------------------------------------
- //-----------------------------------------------------------------------------
- BOOL CIS_Close(DWORD hOpenContext)
- {
- RETAILMSG(1,(TEXT("CAMERA: CIS_Closern")));
- return TRUE;
- }
- //-----------------------------------------------------------------------------
- //-----------------------------------------------------------------------------
- void CIS_PowerDown(DWORD hDeviceContext)
- {
- RETAILMSG(1,(TEXT("CAMERA: CIS_PowerDownrn")));
- m_Dx = (_CEDEVICE_POWER_STATE)D4;
- Camif_Capture(CAPTURE_OFF, CAPTURE_OFF);
- CamClockOn(FALSE);
- //RETAILMSG(1,(TEXT("CAMERA: CIS_PowerDown, m_Dx = D%u, init %d rn"), m_Dx, mInitialized));
- }
- //-----------------------------------------------------------------------------
- //-----------------------------------------------------------------------------
- void CIS_PowerUp(DWORD hDeviceContext)
- {
- RETAILMSG(1,(TEXT("CAMERA: CIS_PowerUprn")));
- m_Dx = (_CEDEVICE_POWER_STATE)D0;
- //
- // 1. Camera IO setup
- //
- CamGpioInit();
- //
- // 2. Camera Clock setup
- //
- CamClockOn(TRUE);
- // 3. Camera i/f reset
- CAM_IF_Reset();
- if (image_size == 1)
- CamInit(QCIF_XSIZE, QCIF_YSIZE, QCIF_XSIZE, QCIF_YSIZE, 112, 20, COPIFRAMEBUFFER_B, COPIFRAMEBUFFER_A);
- else if (image_size == 2)
- CamInit(CIF_XSIZE, CIF_YSIZE, QCIF_XSIZE, QCIF_YSIZE, 112, 20, COPIFRAMEBUFFER_B, COPIFRAMEBUFFER_A);
- RETAILMSG(1,(TEXT("CAMERA: CIS_PowerUp, m_Dx = D%urn"), m_Dx));
- }
- //-----------------------------------------------------------------------------
- //-----------------------------------------------------------------------------
- DWORD CIS_Read(DWORD hOpenContext, LPVOID pBuffer, DWORD Count)
- {
- RETAILMSG(1,(TEXT("CAMERA: CIS_Readrn")));
- return TRUE;
- }
- //-----------------------------------------------------------------------------
- //-----------------------------------------------------------------------------
- DWORD CIS_Seek(DWORD hOpenContext, long Amount, DWORD Type)
- {
- RETAILMSG(1,(TEXT("CAMERA: CIS_Seekrn")));
- return 0;
- }
- //-----------------------------------------------------------------------------
- //-----------------------------------------------------------------------------
- DWORD CIS_Write(DWORD hOpenContext, LPCVOID pSourceBytes, DWORD NumberOfBytes)
- {
- RETAILMSG(1,(TEXT("CAMERA: CIS_Writern")));
- return 0;
- }
- // for MPEG4
- void Copy_Cam_Image(U8 *pBufOut, U32 size_x, U32 size_y, U8 port)
- {
- U8 *buffer_y, *buffer_cb, *buffer_cr;
- U32 Y_size, C_size, P_size;
- int temp;
- U8 *pImage;
- static unsigned int frame_timestamp_prev = GetTickCount();
- static int frame_bank_prev = -1;
- YUVINFO yuvinfo;
- RETAILMSG(MSG_EN_1,(_T("Copy_Cam_Imagern")));
- //s2440IOP->rGPFDAT &= ~(1<<6);
- pImage = pBufOut;
- if (image_size == 1) // QCIF
- Y_size = QCIF_XSIZE*QCIF_YSIZE;
- else if (image_size == 2) // CIF
- Y_size = CIF_XSIZE*CIF_YSIZE;
- C_size = Y_size/4;
- P_size = Y_size + C_size*2;
- {
- temp = (s2440CAM->rCICOSTATUS>>26)&3;
- temp = (temp + 2) % 4;
- RETAILMSG(MSG_EN_1,(_T("Copy_Cam_Image %drn"), temp));
- switch (temp)
- {
- case 0:
- buffer_y = (U8 *)s2440CAM->rCICOYSA1;
- buffer_cb = (U8 *)s2440CAM->rCICOCBSA1;
- buffer_cr = (U8 *)s2440CAM->rCICOCRSA1;
- break;
- case 1:
- buffer_y = (U8 *)s2440CAM->rCICOYSA2;
- buffer_cb = (U8 *)s2440CAM->rCICOCBSA2;
- buffer_cr = (U8 *)s2440CAM->rCICOCRSA2;
- break;
- case 2:
- buffer_y = (U8 *)s2440CAM->rCICOYSA3;
- buffer_cb = (U8 *)s2440CAM->rCICOCBSA3;
- buffer_cr = (U8 *)s2440CAM->rCICOCRSA3;
- break;
- case 3:
- buffer_y = (U8 *)s2440CAM->rCICOYSA4;
- buffer_cb = (U8 *)s2440CAM->rCICOCBSA4;
- buffer_cr = (U8 *)s2440CAM->rCICOCRSA4;
- break;
- default :
- buffer_y = (U8 *)s2440CAM->rCICOYSA1;
- buffer_cb = (U8 *)s2440CAM->rCICOCBSA1;
- buffer_cr = (U8 *)s2440CAM->rCICOCRSA1;
- break;
- }
- }
- #if (DOTNET_DRIVER)
- SetKMode(TRUE);
- #endif
- buffer_y += VIRTUAL_ADDR_OFFSET;
- buffer_cb += VIRTUAL_ADDR_OFFSET;
- buffer_cr += VIRTUAL_ADDR_OFFSET;
- RETAILMSG(MSG_EN_1,(_T("buffer_y = 0x%xrn"), buffer_y));
- RETAILMSG(MSG_EN_1,(_T("buffer_cb = 0x%xrn"), buffer_cb));
- RETAILMSG(MSG_EN_1,(_T("buffer_cr = 0x%xrn"), buffer_cr));
- if (image_size == 1) // QCIF
- {
- yuvinfo.frame_width = QCIF_XSIZE;
- yuvinfo.frame_height = QCIF_YSIZE;
- }
- else if (image_size == 2) // CIF
- {
- yuvinfo.frame_width = CIF_XSIZE;
- yuvinfo.frame_height = CIF_YSIZE;
- }
- if (temp == frame_bank_prev) yuvinfo.frame_stamp = frame_timestamp_prev;
- else
- {
- yuvinfo.frame_stamp = GetTickCount();
- frame_timestamp_prev = yuvinfo.frame_stamp;
- frame_bank_prev = temp;
- }
- RETAILMSG(MSG_EN_1,(_T("pBufOut 0 offset = 0x%xrn"), pImage));
- memcpy(pImage, &yuvinfo, sizeof(YUVINFO));
- pImage += sizeof(YUVINFO);
- RETAILMSG(MSG_EN_1,(_T("pBufOut Y = 0x%xrn"), pImage));
- memcpy(pImage, buffer_y, Y_size);
- pImage += (Y_size);
- RETAILMSG(MSG_EN_1,(_T("pBufOut cb = 0x%xrn"), pImage));
- memcpy(pImage, buffer_cb, C_size);
- pImage += C_size;
- RETAILMSG(MSG_EN_1,(_T("pBufOut cr = 0x%xrn"), pImage));
- memcpy(pImage, buffer_cr, C_size);
- // pBufOut += (size_x*size_y)/4;
- #if (DOTNET_DRIVER)
- SetKMode(FALSE);
- #endif
- // RETAILMSG(MSG_EN_1,(TEXT("1:buffer_y:0x%x,buffer_cb:0x%x,buffer_cr:0x%xrn"),buffer_y,buffer_cb,buffer_cr));
- //s2440IOP->rGPFDAT |= (1<<6);
- Tick_COPY_FRAME = GetTickCount();
- RETAILMSG(MSG_EN_1,(_T("COPY_Tick = %drn"), (Tick_COPY_FRAME-Tick_GET_FRAME_CUR)));
- RETAILMSG(MSG_EN_1,(_T("Frame_Tick = %drn"), (Tick_GET_FRAME_CUR-Tick_GET_FRAME_PREV)));
- // RETAILMSG(1,(_T("Tick_COPY_FRAME = %drn"), Tick_COPY_FRAME));
- // RETAILMSG(1,(_T("Tick_GET_FRAME_PREV = %drn"), Tick_GET_FRAME_PREV));
- // RETAILMSG(1,(_T("Tick_GET_FRAME_CUR = %drn"), Tick_GET_FRAME_CUR));
- }
- void Samsung_camcoder(U8 *pBufOut)
- {
- U8 *pImage;
- PINGPONG caminfo;
- pImage = pBufOut;
- if( codec_flag )
- {
- caminfo.flag = 1;
- caminfo.y_address = y_address;
- caminfo.cb_address = cb_address;
- caminfo.cr_address = cr_address;
- memcpy(pImage, &caminfo, sizeof(PINGPONG));
- codec_flag = 0;
- }
- }
- void Samsung_camcoder_pr(U8 *pBufOut)
- {
- U8 *pImage;
- PINGPONG_PR prinfo;
- pImage = pBufOut;
- if ( rgb_flag )
- {
- prinfo.flag = 1;
- prinfo.rgb_address = rgb_address;
- memcpy(pImage, &prinfo, sizeof(PINGPONG_PR));
- rgb_flag = 0;
- }
- }
- void Buffer_codec_info_update()
- {
- U32 Y_size, C_size, P_size;
- int temp;
- unsigned int buffer_y, buffer_cb, buffer_cr;
- if ( image_size == 1 )
- Y_size = QCIF_XSIZE*QCIF_YSIZE;
- else if ( image_size == 2 )
- Y_size = CIF_XSIZE*CIF_YSIZE;
- C_size = Y_size/4;
- P_size = Y_size + C_size*2;
- temp = (s2440CAM->rCICOSTATUS>>26)&3;
- temp = (temp + 2) % 4;
- RETAILMSG(MSG_EN_2,(_T("codec index = %d, size %drn"), temp, image_size));
- switch (temp)
- {
- case 0:
- buffer_y = s2440CAM->rCICOYSA1;
- buffer_cb = s2440CAM->rCICOCBSA1;
- buffer_cr = s2440CAM->rCICOCRSA1;
- break;
- case 1:
- buffer_y = s2440CAM->rCICOYSA2;
- buffer_cb = s2440CAM->rCICOCBSA2;
- buffer_cr = s2440CAM->rCICOCRSA2;
- break;
- case 2:
- buffer_y = s2440CAM->rCICOYSA3;
- buffer_cb = s2440CAM->rCICOCBSA3;
- buffer_cr = s2440CAM->rCICOCRSA3;
- break;
- case 3:
- buffer_y = s2440CAM->rCICOYSA4;
- buffer_cb = s2440CAM->rCICOCBSA4;
- buffer_cr = s2440CAM->rCICOCRSA4;
- break;
- default :
- buffer_y = s2440CAM->rCICOYSA1;
- buffer_cb = s2440CAM->rCICOCBSA1;
- buffer_cr = s2440CAM->rCICOCRSA1;
- break;
- }
- buffer_y += VIRTUAL_ADDR_OFFSET;
- buffer_cb += VIRTUAL_ADDR_OFFSET;
- buffer_cr += VIRTUAL_ADDR_OFFSET;
- #if 0
- RETAILMSG(MSG_EN_1,(_T("buffer_y = 0x%xrn"), buffer_y));
- RETAILMSG(MSG_EN_1,(_T("buffer_cb = 0x%xrn"), buffer_cb));
- RETAILMSG(MSG_EN_1,(_T("buffer_cr = 0x%xrn"), buffer_cr));
- #endif
- if( codec_flag ) RETAILMSG(MSG_EN_1,(_T("Buffer is not readrn")));
- codec_flag = 1;
- y_address = buffer_y;
- cb_address = buffer_cb;
- cr_address = buffer_cr;
- }
- void Buffer_preview_info_update()
- {
- // U32 Y_size;
- int temp;
- unsigned int buffer_rgb;
- /*
- if ( image_size == 1 )
- Y_size = QCIF_XSIZE*QCIF_YSIZE;
- else if ( image_size == 2 )
- Y_size = CIF_XSIZE*CIF_YSIZE;
- */
- temp = (s2440CAM->rCIPRSTATUS>>26)&3;
- temp = (temp + 2) % 4;
- RETAILMSG(MSG_EN_2,(_T("preview index = %d, size %drn"), temp, image_size));
- switch (temp)
- {
- case 0:
- buffer_rgb = s2440CAM->rCIPRCLRSA1;
- break;
- case 1:
- buffer_rgb = s2440CAM->rCIPRCLRSA2;
- break;
- case 2:
- buffer_rgb = s2440CAM->rCIPRCLRSA3;
- break;
- case 3:
- buffer_rgb = s2440CAM->rCIPRCLRSA4;
- break;
- default :
- buffer_rgb = s2440CAM->rCIPRCLRSA1;
- break;
- }
- buffer_rgb += VIRTUAL_ADDR_OFFSET;
- #if 0
- RETAILMSG(MSG_EN_1,(_T("buffer_rgb = 0x%xrn"), buffer_rgb));
- #endif
- if( rgb_flag ) RETAILMSG(MSG_EN_1,(_T("Buffer is not readrn")));
- rgb_flag = 1;
- rgb_address = buffer_rgb;
- }
- void CamInit(U32 CoDstWidth, U32 CoDstHeight, U32 PrDstWidth, U32 PrDstHeight,
- U32 WinHorOffset, U32 WinVerOffset, U32 CoFrameBuffer, U32 PrFrameBuffer)
- {
- U32 WinOfsEn;
- U32 divisor, multiplier;
- U32 MainBurstSizeY, RemainedBurstSizeY, MainBurstSizeC, RemainedBurstSizeC, MainBurstSizeRGB, RemainedBurstSizeRGB;
- U32 H_Shift, V_Shift, PreHorRatio, PreVerRatio, MainHorRatio, MainVerRatio;
- U32 SrcWidth, SrcHeight;
- U32 ScaleUp_H_Co, ScaleUp_V_Co, ScaleUp_H_Pr, ScaleUp_V_Pr;
- //constant for calculating codec dma address
- if(CAM_CODEC_OUTPUT)
- divisor=2; //CCIR-422
- else
- divisor=4; //CCIR-420
- //constant for calculating preview dma address
- if(CAM_PVIEW_OUTPUT)
- multiplier=4;
- else
- multiplier=2;
- if(WinHorOffset==0 && WinVerOffset==0)
- WinOfsEn=0;
- else
- WinOfsEn=1;
- SrcWidth=CAM_SRC_HSIZE-WinHorOffset*2;
- SrcHeight=CAM_SRC_VSIZE-WinVerOffset*2;
- if(SrcWidth>=CoDstWidth) ScaleUp_H_Co=0; //down
- else ScaleUp_H_Co=1; //up
- if(SrcHeight>=CoDstHeight) ScaleUp_V_Co=0;
- else ScaleUp_V_Co=1;
- if(SrcWidth>=PrDstWidth) ScaleUp_H_Pr=0; //down
- else ScaleUp_H_Pr=1; //up
- if(SrcHeight>=PrDstHeight) ScaleUp_V_Pr=0;
- else ScaleUp_V_Pr=1;
- ////////////////// common control setting
- s2440CAM->rCIGCTRL |= (1<<26)|(0<<27); // inverse PCLK, test pattern
- s2440CAM->rCIWDOFST = (1<<30)|(0xf<<12); // clear overflow
- s2440CAM->rCIWDOFST = 0;
- s2440CAM->rCIWDOFST=(WinOfsEn<<31)|(WinHorOffset<<16)|(WinVerOffset);
- s2440CAM->rCISRCFMT=(CAM_ITU601<<31)|(0<<30)|(0<<29)|(CAM_SRC_HSIZE<<16)|(CAM_ORDER_YCBYCR<<14)|(CAM_SRC_VSIZE);
- //s2440CAM->rCISRCFMT=(CAM_ITU656<<31)|(0<<30)|(0<<29)|(CAM_SRC_HSIZE<<16)|(CAM_ORDER_CBYCRY<<14)|(CAM_SRC_VSIZE);
- ////////////////// codec port setting
- s2440CAM->rCICOYSA1=CoFrameBuffer;
- s2440CAM->rCICOYSA2=s2440CAM->rCICOYSA1+CoDstWidth*CoDstHeight+2*CoDstWidth*CoDstHeight/divisor;
- s2440CAM->rCICOYSA3=s2440CAM->rCICOYSA2+CoDstWidth*CoDstHeight+2*CoDstWidth*CoDstHeight/divisor;
- s2440CAM->rCICOYSA4=s2440CAM->rCICOYSA3+CoDstWidth*CoDstHeight+2*CoDstWidth*CoDstHeight/divisor;
- s2440CAM->rCICOCBSA1=s2440CAM->rCICOYSA1+CoDstWidth*CoDstHeight;
- s2440CAM->rCICOCBSA2=s2440CAM->rCICOYSA2+CoDstWidth*CoDstHeight;
- s2440CAM->rCICOCBSA3=s2440CAM->rCICOYSA3+CoDstWidth*CoDstHeight;
- s2440CAM->rCICOCBSA4=s2440CAM->rCICOYSA4+CoDstWidth*CoDstHeight;
- s2440CAM->rCICOCRSA1=s2440CAM->rCICOCBSA1+CoDstWidth*CoDstHeight/divisor;
- s2440CAM->rCICOCRSA2=s2440CAM->rCICOCBSA2+CoDstWidth*CoDstHeight/divisor;
- s2440CAM->rCICOCRSA3=s2440CAM->rCICOCBSA3+CoDstWidth*CoDstHeight/divisor;
- s2440CAM->rCICOCRSA4=s2440CAM->rCICOCBSA4+CoDstWidth*CoDstHeight/divisor;
- s2440CAM->rCICOTRGFMT=(CAM_CODEC_IN_422<<31)|(CAM_CODEC_OUTPUT<<30)|(CoDstWidth<<16)|(CAM_FLIP_NORMAL<<14)|(CoDstHeight);
- CalculateBurstSize(CoDstWidth, &MainBurstSizeY, &RemainedBurstSizeY);
- CalculateBurstSize(CoDstWidth/2, &MainBurstSizeC, &RemainedBurstSizeC);
- s2440CAM->rCICOCTRL=(MainBurstSizeY<<19)|(RemainedBurstSizeY<<14)|(MainBurstSizeC<<9)|(RemainedBurstSizeC<<4);
- CalculatePrescalerRatioShift(SrcWidth, CoDstWidth, &PreHorRatio, &H_Shift);
- CalculatePrescalerRatioShift(SrcHeight, CoDstHeight, &PreVerRatio, &V_Shift);
- MainHorRatio=(SrcWidth<<8)/(CoDstWidth<<H_Shift);
- MainVerRatio=(SrcHeight<<8)/(CoDstHeight<<V_Shift);
- s2440CAM->rCICOSCPRERATIO=((10-H_Shift-V_Shift)<<28)|(PreHorRatio<<16)|(PreVerRatio);
- s2440CAM->rCICOSCPREDST=((SrcWidth/PreHorRatio)<<16)|(SrcHeight/PreVerRatio);
- s2440CAM->rCICOSCCTRL=(CAM_SCALER_BYPASS_OFF<<31)|(ScaleUp_H_Co<<30)|(ScaleUp_V_Co<<29)|(MainHorRatio<<16)|(MainVerRatio);
- s2440CAM->rCICOTAREA=CoDstWidth*CoDstHeight;
- ///////////////// preview port setting
- s2440CAM->rCIPRCLRSA1=PrFrameBuffer;
- s2440CAM->rCIPRCLRSA2=s2440CAM->rCIPRCLRSA1+PrDstWidth*PrDstHeight*multiplier;
- s2440CAM->rCIPRCLRSA3=s2440CAM->rCIPRCLRSA2+PrDstWidth*PrDstHeight*multiplier;
- s2440CAM->rCIPRCLRSA4=s2440CAM->rCIPRCLRSA3+PrDstWidth*PrDstHeight*multiplier;
- s2440CAM->rCIPRTRGFMT=(PrDstWidth<<16)|(CAM_FLIP_NORMAL<<14)|(PrDstHeight);
- if (CAM_PVIEW_OUTPUT==CAM_RGB24B)
- CalculateBurstSize(PrDstWidth*4, &MainBurstSizeRGB, &RemainedBurstSizeRGB);
- else // RGB16B
- CalculateBurstSize(PrDstWidth*2, &MainBurstSizeRGB, &RemainedBurstSizeRGB);
- s2440CAM->rCIPRCTRL=(MainBurstSizeRGB<<19)|(RemainedBurstSizeRGB<<14);
- CalculatePrescalerRatioShift(SrcWidth, PrDstWidth, &PreHorRatio, &H_Shift);
- CalculatePrescalerRatioShift(SrcHeight, PrDstHeight, &PreVerRatio, &V_Shift);
- MainHorRatio=(SrcWidth<<8)/(PrDstWidth<<H_Shift);
- MainVerRatio=(SrcHeight<<8)/(PrDstHeight<<V_Shift);
- s2440CAM->rCIPRSCPRERATIO=((10-H_Shift-V_Shift)<<28)|(PreHorRatio<<16)|(PreVerRatio);
- s2440CAM->rCIPRSCPREDST=((SrcWidth/PreHorRatio)<<16)|(SrcHeight/PreVerRatio);
- s2440CAM->rCIPRSCCTRL=(1<<31)|(CAM_RGB16B<<30)|(ScaleUp_H_Pr<<29)|(ScaleUp_V_Pr<<28)|(MainHorRatio<<16)|(MainVerRatio);
- s2440CAM->rCIPRTAREA= PrDstWidth*PrDstHeight;
- }