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

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

?? jpeg_test.c

?? 三星 s3c6400測試代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdarg.h>

#include "sysc.h"
#include "system.h"
#include "intc.h"
#include "jpeg.h"
#include "lcd.h"
#include "camera.h"
#include "glib.h"
#include "post.h"
#include "option.h"
#include "library.h"
#include "sdhc.h"
#include "fat.h"
#include "uart.h"

#ifndef PREPARED_JPEG
#define PREPARED_JPEG      "./jpg/144_96_420.jpg"
#endif

#define CAPTURED_JPEG      "Captured.jpg"
#define YUV_FILE_NAME      "Captured.yuv"

static POST	oPost;
static SDHC   oSdhc;

static u32 uRawImgHSz_Dec, uRawImgVSz_Dec, uRawImgAddr;
static u32 uRawImgHsz_Enc, uRawImgVsz_Enc, uGlibAddr;
static CSPACE eRawImgFormat;
static u32 uLcdFbAddr, uLcdHSz, uLcdVSz;
static CSPACE eLcdBpp;
static u32 uJpgAddr;
static JPEG_TYPE eJpgFormat;
static u32 uJpgSize;
static JPEG_STATUS eJpgStatus;
static bool bIsJpgLoaded;
static bool bIsOneStep;
static u32 uIntCnt;

#if 1
#define WaitForSet(bDone) while (!bDone)
#else
#define WaitForSet(bDone) \
	for (int i=0; !bDone; i++) \
	{ \
		Delay(100); \
		if (i == 100) \
		{ \
			printf(" Abnormal termination !!!\n"); \
			return; \
		} \
	}
#endif

#if 0   // Polling mode
#define WaitForConversionDone(bDone) while(!CIM_IsProcessingDone())
#else   // Interrupt mode
#define WaitForConversionDone(bDone) while(!bDone)
#endif

static volatile bool bCamifDone;

void __irq Isr_Camif_P(void)
{
	LCD_Trigger();
	//bPreviewDone = true;
	//printf("P");
	CAMERA_SetClearPreviewInt();
	INTC_ClearVectAddr();		
}

void __irq Isr_Camif_C(void)
{
	INTC_Disable(NUM_CAMIF_C );
	bCamifDone = true;	
	CAMERA_SetClearCodecInt();
	INTC_Disable(NUM_CAMIF_C );
	INTC_ClearVectAddr();
}

static volatile bool bJpegDone;

void __irq Isr_Jpeg(void)
{
	INTC_Disable(NUM_JPEG);
	if ( (bIsOneStep == false) || ((bIsOneStep == true)&&(uIntCnt == 1)) )
	{
		JPEG_ReadAndClearStatus(&eJpgStatus);
		uIntCnt = 0;
	}
	//INTC_ClearPending(INT_JPEG);
	bJpegDone = true;
	uIntCnt++;
	printf("bJpegDone: %d\n", bJpegDone); 

	INTC_Enable(NUM_JPEG);
	INTC_ClearVectAddr();	
}

#define MJPEG_FRAME_NUM	5
#define MJPEG_MAX_SZ		0x8000
#define MJPEG_STREAM_ST	(uJpgAddr)
#define MJPEG_YUV_ST		(MJPEG_STREAM_ST+MJPEG_MAX_SZ*MJPEG_FRAME_NUM)	// after 10 frame

static volatile u32  uMjpgCount;
static volatile bool bMjpgEncDone;

void __irq Isr_EncMotion(void)
{
	u32 uResult; //, cnt;
	//Assert(0);
	INTC_Disable(NUM_JPEG);

	uMjpgCount++;
	JPEG_SetNextFrameStartAddr(MJPEG_STREAM_ST + MJPEG_MAX_SZ*(uMjpgCount+1));
	JPEG_CheckDone(&uResult);

	if (uResult)
	{
		JPEG_GetEncodedStreamLen(&uJpgSize);
		if (uMjpgCount >= MJPEG_FRAME_NUM)
		{
			bMjpgEncDone = 1;
		}
	}
	else
	{
		JPEG_GetEncodedStreamLen(&uJpgSize);
		printf("JPEG Encoding: Done abnormally. %x\n", uJpgSize);
		bMjpgEncDone = 0;
	}
	printf("JPEG Encoding frame = %d Done.\n", uJpgSize);
	INTC_Enable(NUM_JPEG);
	INTC_ClearVectAddr();	
}

static void TestDscSubsys(void)
{
	char x=0;
	u32 uSrcHsz ,uSrcVsz ;
	u32 uCaptureHsz, uCaptureVsz;
	u32 uCodecAddr = uJpgAddr + 0x500000;

	CSPACE eDstDataFmt = RGB16;
	IMG_SIZE eCodecSz = UXGA;

	// 1. Initialize LCD
	//========================================
	LCD_InitLDI(MAIN);
	LCD_InitDISPC(eDstDataFmt, uLcdFbAddr, WIN0, false);
	LCD_GetFrmSz(&uLcdHSz, &uLcdVSz, WIN0);
	LCD_Start();

	// 2. Initialize Interrupt
	//========================================
	INTC_Init();
	INTC_SetVectAddr(NUM_JPEG, Isr_Jpeg);
	INTC_SetVectAddr(NUM_CAMIF_C, Isr_Camif_C);	
	//INTC_SetVectAddr(NUM_CAMIF_P, Isr_Camif_P);	
	INTC_Enable(NUM_JPEG);
	INTC_Enable(NUM_CAMIF_C);
	//INTC_Enable(NUM_CAMIF_P);	

	// 3. Initialize camera and run the  process of preview path.
	//========================================
	CAMERA_InitSensor();		//CAMERA_InitSensor1(ePreviewSz, CCIR601, YCBYCR);
	CAMERA_SetSensorSize(eCodecSz);
	CAMERA_GetSrcImgSz(&uSrcHsz, &uSrcVsz);
	
	uSrcHsz = (uSrcHsz > uLcdHSz) ? uLcdHSz : uSrcHsz;
	uSrcVsz = (uSrcVsz > uLcdVSz) ? uLcdVSz : uSrcVsz;

	CAMERA_InitPreviewPath(uSrcHsz, uSrcVsz, uLcdFbAddr, eLcdBpp, FLIP_NO, ROT_0);
	CAMERA_StartPreviewPath();

	while(true)
	{
		printf("x = Turn off Camera, s = Capture IMG(Enocoded To JPEG), c = Change IMG Size : ");
		x = getchar();
		
		printf("%c\n", x);

		if(x == 'x' || x=='X')
		{
			CAMERA_StopPreviewPath();
			break;
		}
		else if(x=='s' || x=='S')
		{
			CAMERA_StopPreviewPath();
			CAMERA_SetSensorSize(eCodecSz);

			bCamifDone = false;

			ConvertImgSzToNumber(eCodecSz, &uCaptureHsz, &uCaptureVsz);
			eDstDataFmt = YCBYCR;
			CAMERA_InitCodecPath(uCaptureHsz, uCaptureVsz, uCodecAddr,  eDstDataFmt, FLIP_NO, ROT_0);
			CAMERA_StartCodecPath(1);

			while(!CAMERA_IsProcessingDone());
			//WaitForConversionDone(bCamifDone);			

			CAMERA_ClearFrameEndStatus();
			printf("Capturing raw image  ... \n");				
			
			bJpegDone = false;
			JPEG_StartEncodingOneFrame(uCaptureHsz, uCaptureVsz, uCodecAddr, eDstDataFmt, uJpgAddr, eJpgFormat);
			WaitForSet(bJpegDone);
			Assert(eJpgStatus == OK_ENC_OR_DEC);
			//JPEG_Wait_Done();

			JPEG_GetEncodedStreamLen(&uJpgSize);
/*
			//+daedoo 061212
			CIM_SetSensorSize(ePreviewSz);
			CIM_InitPreviewPath(uSrcHsz, uSrcVsz, uLcdFbAddr, eDstDataFmt, FLIP_NO, ROT_0);
			CIM_StartPreviewPath();
*/			

#if	 SEMIHOSTING
			printf("Saving image to file ... \n");
			SaveToFile(CAPTURED_JPEG, uJpgSize, uJpgAddr);
#else
			// Under Construction. SD/MMC will be used.
#endif
			
		}

		else if(x=='c' || x=='C')
		{
			printf("1 = UXGA, 2 = SXGA, 3 = SVGA, 4 = VGA : ");
			//x = Getc();
			x = getchar();

			printf("%c\n", x);

			eCodecSz =  (x=='11') ? UXGA : (x=='22') ? SXGA : (x=='33') ? SVGA : (x=='44') ? VGA : SVGA;
		}
		else
			printf("Invalid input! Retry!!\n");
	}
	CAMERA_StopPreviewPath();

}

static void TestOneStepDecoding(void)
{
	bIsOneStep = true;
	
	if (bIsJpgLoaded == false)
	{
		printf("ERROR! Load a raw image first!!\n");
		return;
	}

	INTC_Init();
	INTC_SetVectAddr(NUM_JPEG, Isr_Jpeg);
	INTC_Enable(NUM_JPEG);

	uRawImgAddr = uJpgAddr+((uJpgSize+16)/16)*16;
	bJpegDone = false;
	JPEG_StartDecodingOneFrame(uJpgAddr, uRawImgAddr, false);
	WaitForSet(bJpegDone);
	//Assert(eJpgStatus == OK_ENC_OR_DEC);
	JPEG_Wait_Done();
	
	JPEG_GetDecodedWidthAndHeight(&uRawImgHSz_Dec, &uRawImgVSz_Dec);
	if ( uRawImgHSz_Dec == 0 || uRawImgVSz_Dec == 0 )
		printf("Error! Widht or Height is zero\n");
	else 
		printf(" Hsz = %d, Vsz = %d\n", uRawImgHSz_Dec, uRawImgVSz_Dec);

	/*
	CIM_InitDmaInPath(uRawImgHSz_Dec, uRawImgVSz_Dec, uRawImgAddr, YCBYCR,
		uLcdHSz, uLcdVSz, uLcdFbAddr, eLcdBpp, FLIP_NO, ROT_0, C_PATH);

	bCamifDone = false;
	CIM_StartDmaInPath();
	WaitForConversionDone(bCamifDone);
	*/

	POST_InitIp(
		uRawImgHSz_Dec, uRawImgVSz_Dec, uRawImgAddr, CRYCBY,
		//uLcdHSz, uLcdVSz, uLcdFbAddr, eLcdBpp, 1, false, ONE_SHOT, &oPost);
		320, 240, uLcdFbAddr, eLcdBpp, 1, false, ONE_SHOT, &oPost);

	POST_StartProcessing(&oPost);
	while (!POST_IsFreeRunDone(&oPost));
	
}

static void TestTwoStepDecoding(void)
{
	char pType[30];

	bIsOneStep = false;	
	
	if (bIsJpgLoaded == false)
	{
		printf("ERROR! Load a raw image first !!\n");
		return;
	}

	INTC_Init();
	INTC_SetVectAddr(NUM_JPEG, Isr_Jpeg);
	INTC_SetVectAddr(NUM_CAMIF_C, Isr_Camif_C);
	INTC_Enable(NUM_JPEG);
	INTC_Enable(NUM_CAMIF_C);

	// Header Parsing
	bJpegDone = false;
	JPEG_StartParsingHeader(uJpgAddr);
	WaitForSet(bJpegDone);
	
	Assert(eJpgStatus == OK_HD_PARSING);

	JPEG_GetJpegType1(pType);
	printf(" 1. Sub-Sampling Mode = %s\n", pType);

	JPEG_GetDecodedWidthAndHeight(&uRawImgHSz_Dec, &uRawImgVSz_Dec);
	if ( uRawImgHSz_Dec == 0 || uRawImgVSz_Dec == 0 )
		printf("Error! Width or Height is zero\n");
	else
		printf(" 2. Resolution : Width = %d, Height = %d\n", uRawImgHSz_Dec, uRawImgVSz_Dec);

	// Decoding body.
	uRawImgAddr = uJpgAddr+((uJpgSize+16)/16)*16;
	printf(" uRawImgAddr = 0x%x\n",uRawImgAddr);
	bJpegDone = false;
	JPEG_StartDecodingBody(uRawImgAddr, false);
	WaitForSet(bJpegDone);
	Assert(eJpgStatus == OK_ENC_OR_DEC);
	
	//printf("After JpegDone\n");

	#if 0	// camera dma

	CAMERA_InitDmaInPath(uRawImgHSz_Dec, uRawImgVSz_Dec, uRawImgAddr, YCBYCR,
		//uLcdHSz, uLcdVSz, uLcdFbAddr, eLcdBpp, FLIP_NO, ROT_0, C_PATH);
		320, 240, uLcdFbAddr, eLcdBpp, FLIP_NO, ROT_0, C_PATH);

	bCamifDone = false;
	CAMERA_StartDmaInPath();
	WaitForConversionDone(bCamifDone);

	#else

	POST_InitIp(
		uRawImgHSz_Dec, uRawImgVSz_Dec, uRawImgAddr, CRYCBY,
		uLcdHSz, uLcdVSz, uLcdFbAddr, eLcdBpp, 1, false, ONE_SHOT, &oPost);
	POST_StartProcessing(&oPost);
	while (!POST_IsFreeRunDone(&oPost));

	#endif

}

#if	 SEMIHOSTING
static void GetJpegStreamFromPc(void)
{
	const char *pFileName = PREPARED_JPEG;
	printf(" Loading %s from PC ...\n", pFileName);
	LoadFromFile1(pFileName, uJpgAddr, &uJpgSize);

	printf(" Stream size = %d bytes\n", uJpgSize);
	bIsJpgLoaded = true;
}
#endif

static void GetJpegStreamFromSd(void)
{
	u32 uTotalNumOfFiles, i;
	int sel;
	char pFileName[50];

	if (!SDHC_OpenMedia(SDHC_HCLK, &oSdhc) || !FAT_LoadFileSystem(&oSdhc))
		Assert(0);
	
	FAT_GetTotalNumOfFiles(&uTotalNumOfFiles, &oSdhc);
	for (i=0; i<uTotalNumOfFiles; i++)
	{
		FAT_GetFileName(i, pFileName, &oSdhc);
		printf("%02d -- %s\n", i, pFileName);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区在线影院| 蜜桃视频一区二区| 91精品国产91综合久久蜜臀| 久草这里只有精品视频| 国产精品美女久久久久aⅴ国产馆| 欧美日韩中文国产| 国产91在线看| 久久爱另类一区二区小说| 亚洲日韩欧美一区二区在线| 精品国产伦理网| 欧美日韩激情一区二区三区| av影院午夜一区| 久久99精品久久久| 亚洲国产视频直播| 中文字幕欧美一区| 国产区在线观看成人精品 | 日本sm残虐另类| 一区二区三区在线观看视频| 久久精品夜夜夜夜久久| 日韩欧美国产麻豆| 91精品国产色综合久久ai换脸| 91猫先生在线| 国产成a人亚洲| 蜜臀av性久久久久蜜臀av麻豆| **欧美大码日韩| 久久夜色精品国产噜噜av| 777xxx欧美| 欧美挠脚心视频网站| 色综合久久久久久久久| 国产高清成人在线| 国产一区二区三区观看| 久久99精品久久只有精品| 日本不卡中文字幕| 免费美女久久99| 男女男精品视频网| 免费成人美女在线观看.| 日韩中文字幕不卡| 香蕉影视欧美成人| 日本最新不卡在线| 亚洲国产乱码最新视频 | 亚洲男女毛片无遮挡| 国产精品免费久久| 综合久久综合久久| 亚洲人成网站色在线观看| 1024亚洲合集| 中文字幕一区二区三区不卡在线 | 午夜日韩在线观看| 亚洲国产成人精品视频| 1区2区3区精品视频| 国产精品乱人伦| 欧美精品一区二区三区在线| 91精品欧美久久久久久动漫| 91精品国产福利| 韩国三级在线一区| 日本一区免费视频| 欧美第一区第二区| 国产宾馆实践打屁股91| 亚洲女女做受ⅹxx高潮| 欧美私人免费视频| jlzzjlzz亚洲日本少妇| 国产在线视频精品一区| 免费人成网站在线观看欧美高清| 日本一区二区三区电影| 一区二区三区小说| 欧洲一区二区av| 欧美日韩国产综合视频在线观看| 欧洲人成人精品| 7878成人国产在线观看| 777奇米成人网| 欧美日韩一区二区三区不卡| 日韩一级高清毛片| 精品久久久久久无| 中文字幕在线一区免费| 国产色一区二区| 国产精品久久午夜| 亚洲成av人综合在线观看| 久久精品久久综合| 91婷婷韩国欧美一区二区| 91香蕉视频污在线| 91国产精品成人| 欧美精品v日韩精品v韩国精品v| 欧美肥妇bbw| 国产经典欧美精品| 欧美艳星brazzers| 欧美午夜理伦三级在线观看| 欧美一级xxx| 久久综合av免费| 亚洲一线二线三线视频| 调教+趴+乳夹+国产+精品| 国产成人免费视频一区| 北条麻妃国产九九精品视频| 欧美肥胖老妇做爰| 久久久久久久综合日本| 性欧美大战久久久久久久久| 精品一区二区三区香蕉蜜桃| 色婷婷综合中文久久一本| 7777精品伊人久久久大香线蕉经典版下载 | 91精品国产免费| 久久九九国产精品| 天天操天天综合网| 国产二区国产一区在线观看| 欧美视频日韩视频| 久久久久久**毛片大全| 亚洲国产wwwccc36天堂| 国产一区二区精品久久99| 日本高清不卡在线观看| 欧美va亚洲va| 亚洲欧美另类图片小说| 麻豆国产91在线播放| 91丨porny丨国产入口| 久久蜜桃av一区二区天堂| 亚洲狠狠丁香婷婷综合久久久| 国产一区不卡在线| 欧美日韩一区二区不卡| 亚洲精品免费播放| 久久av中文字幕片| 在线播放日韩导航| 中文幕一区二区三区久久蜜桃| 蜜桃视频一区二区三区| 91福利视频网站| 中文字幕日本乱码精品影院| 美女一区二区久久| 欧美日韩国产综合一区二区三区 | 69堂国产成人免费视频| 亚洲女人的天堂| 成人黄色软件下载| 国产日韩精品一区二区浪潮av| 天天色 色综合| 欧美精品色一区二区三区| 国产精品国产三级国产aⅴ无密码| 蜜臀久久99精品久久久久久9 | 日韩国产精品久久久久久亚洲| 色综合视频一区二区三区高清| 久久青草欧美一区二区三区| 狠狠色综合播放一区二区| 日韩一级完整毛片| 日韩中文字幕麻豆| 欧美一区二区大片| 一区二区三区在线播| 色天使色偷偷av一区二区| 久久久久久久久久久久久女国产乱| 天天做天天摸天天爽国产一区| 欧美三级一区二区| 亚洲欧美日韩久久精品| 色综合天天做天天爱| 国产精品国产精品国产专区不片| 成人动漫在线一区| 国产亚洲一本大道中文在线| 夫妻av一区二区| 国产日韩三级在线| 成人app网站| 国产精品污污网站在线观看| eeuss鲁片一区二区三区在线看| 欧美精品一区二区三区很污很色的 | 91在线一区二区三区| 亚洲图片另类小说| 国产91丝袜在线播放| 国产精品久久久久桃色tv| 国产中文字幕一区| 国产日韩v精品一区二区| 99国内精品久久| 日韩毛片精品高清免费| 欧美丝袜丝交足nylons图片| 亚洲国产成人91porn| 精品少妇一区二区三区视频免付费 | 欧美va日韩va| 成人永久免费视频| 国产精品女人毛片| 精品污污网站免费看| 亚洲国产一区二区视频| 精品三级在线看| 琪琪久久久久日韩精品| 久久精品在线免费观看| 日韩电影在线观看一区| 日韩欧美激情四射| 成人午夜av电影| 一区二区三区四区在线免费观看| 日韩视频免费观看高清完整版 | 国产尤物一区二区| 亚洲欧美日韩国产一区二区三区| 色老头久久综合| 久久66热偷产精品| 日本一区二区免费在线观看视频| 色欧美日韩亚洲| 日日夜夜精品视频免费| 国产精品久线观看视频| 91美女在线观看| 国产在线麻豆精品观看| 国产欧美一区二区精品婷婷 | 色综合咪咪久久| 久久成人久久爱| 亚洲永久免费av| 日韩一区二区三区电影 | 日韩国产一区二| 2023国产精品自拍| 色成年激情久久综合| 日韩国产精品大片| 一区视频在线播放| 欧美一区二区三区在| 日本高清不卡在线观看|