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

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

?? jpeg.c

?? GPRS模組,GPRS原理圖,sim300
?? C
?? 第 1 頁 / 共 2 頁
字號:
//=============================================================
// 文件名稱:	jpeg_decoder.c
// 功能描述:	jpeg解碼程序
// 維護記錄:	2007-8-13	by liuxue created
//				2007.08.23	V1.0		by lijian <lijian@sunnorth.com.cn>
//=============================================================

#include "JPEG.h"
#include "MPEG4_Driver.h"
#include "BLNDMA.h"

//=============================================================
// 語法格式:	unsigned char *find_marker(unsigned char * jpg_ptr);
// 實現功能:	找jpeg的marker
// 參數:		jpg_ptr,指向jpeg數據的指針
// 返回值:		marker
//=============================================================
static unsigned char *find_marker(unsigned char * jpg_ptr)
{
	while(*jpg_ptr != 0xff)
	{
		jpg_ptr++;
	}
	
	return ++jpg_ptr;				// 返回marker
}


//=============================================================
// 語法格式:	unsigned int get_jpg_segment_length(unsigned char *jpg_ptr);
// 實現功能:	找當前marker欄的長度
// 參數:		jpg_ptr,指向jpeg數據的指針
// 返回值:		length,當前marker欄的長度,長度不包括marker,但包括length本身
//=============================================================

static unsigned int get_jpg_segment_length(unsigned char *jpg_ptr)
{
	unsigned int length;

	length = (*jpg_ptr << 8) + *(jpg_ptr + 1);
	
	return length;
}

//=============================================================
// 語法格式:	unsigned char *bypass_jpg_segment(unsigned char *jpg_ptr);
// 實現功能:	跳過當前marker欄數據
// 參數:		jpg_ptr,指向jpeg數據的指針
// 返回值:		jpr_ptr,指向下一個marker欄首
//=============================================================

static unsigned char *bypass_jpg_segment(unsigned char *jpg_ptr)
{
	unsigned int length;
	
	length = get_jpg_segment_length(jpg_ptr);
	jpg_ptr = jpg_ptr + length;
	
	return jpg_ptr;	
}

//=============================================================
// 語法格式:	void fill_quantize_sram(unsigned char *jpg_ptr);
// 實現功能:	向SPCE3200填充量化表
// 參數:		jpg_ptr,指向jpeg數據的指針
// 返回值:		無
//=============================================================

static void fill_quantize_sram(unsigned char *jpg_ptr)
{
	const unsigned int jpeg_natural_order[64] = {
												0,	1,	8,	16,	9,	2,	3,	10,
												17,	24,	32,	25,	18,	11,	4,	5,
												12,	19,	26,	33,	40,	48,	41,	34,
												27,	20,	13,	6,	7,	14,	21,	28,
												35,	42,	49,	56,	57,	50,	43,	36,
												29,	22,	15,	23,	30,	37,	44,	51,
												58,	59,	52,	45,	38,	31,	39,	46,
												53,	60,	61,	54,	47,	55,	62,	63
												};		// Zig-Zag變換
	unsigned int i;
	unsigned int length, counter;
	unsigned char qtable[64];
	unsigned char *pointer;
	unsigned int *ptr;
	
	length = get_jpg_segment_length(jpg_ptr);
	counter = 2;
	pointer = jpg_ptr + 2;
	
	*P_MPEG4_QTABLE_SRAM = C_MPEG4_QTABLESRAM_EN;		// enable CPU access Q Sram
	
	while(counter < length)
	{
		if((*pointer & 0x0f)== 0x00)
		{
			ptr = (unsigned int *)P_MPEG4_QTABLE1_START;// fill Y Q_table ,亮度
		}
		else
		{
			ptr = (unsigned int *)P_MPEG4_QTABLE2_START;// fill C Q_table chroma,色度
		}
		
		counter++;
		pointer++;

		for(i=0; i<64; i++)
		{
			counter++;
			qtable[jpeg_natural_order[i]] = *pointer++;
		}
		for(i=0;i<64;i++)								// Fill Q_Table_SRAM
		{
			*ptr++ = (unsigned int)qtable[i];
		}
	}	// while(counter < length)

	*P_MPEG4_QTABLE_SRAM = C_MPEG4_QTABLESRAM_DIS;		// disable CPU access Q Sram
}


//=============================================================
// 語法格式:	int set_jpg_mode(unsigned char *jpg_ptr);
// 實現功能:	向SPCE3200填充高度、寬度、FRAME_Buffer 寬度等信息
//				根據jpeg圖片數據,選擇YUV格式
// 參數:		jpg_ptr,指向jpeg數據的指針
// 返回值:		1: 成功;  0: 失敗
//=============================================================

static int set_jpg_mode(unsigned char *jpg_ptr)
{
	unsigned char *pointer;
	unsigned char word;
	unsigned int width;

	pointer = jpg_ptr + 3;

	word = *pointer++;
	*P_MPEG4_DECHEIGHT_HIGH = (unsigned int)word;		// 高度
	word = *pointer++;
	*P_MPEG4_DECHEIGHT_LOW = (unsigned int)word;

	word = *pointer++;
	*P_MPEG4_DECWIDTH_HIGH = (unsigned int)word;		// 寬度
	width = (unsigned int)word;
	width = width << 8;
	
	word = *pointer++;
	*P_MPEG4_DECWIDTH_LOW = (unsigned int)word;
	width = width + (unsigned int)word;

	*P_MPEG4_FRAMEBUFFER_HSIZE = width;					// FRAMEBUFFER_HSIZE

	word = *pointer++;
	pointer++;											// skip 1 byte
	
	
    if(word==0x01)										// 單色  01
	{
		*P_MPEG4_YUV_SEL = 0x00000000;					// 0 : {yuv420, yuv422}
														// 1 : {yuv411, yuv444}
		*P_MPEG4_MODE_CTRL1 = C_MPEG4_JPEG_DEC
								| C_MPEG4_YUV422_MODE
								| C_MPEG4_COLOR_MODE;

	}
	else												// 彩色  03
	{
		word = *pointer;
		
		switch(word)									// 分量水平sampling比例
		{
			case 0x11:									// yuv444
				*P_MPEG4_YUV_SEL = 0x00000001;
				*P_MPEG4_MODE_CTRL1 = C_MPEG4_JPEG_DEC
										| C_MPEG4_YUV444_MODE;
				break;
			case 0x21:									// yuv422
				*P_MPEG4_YUV_SEL = 0x00000000;
				*P_MPEG4_MODE_CTRL1 = C_MPEG4_JPEG_DEC
										| C_MPEG4_YUV422_MODE;
				break;
			case 0x41:									// yuv411
				*P_MPEG4_YUV_SEL = 0x00000001;
				*P_MPEG4_MODE_CTRL1 = C_MPEG4_JPEG_DEC
										| C_MPEG4_YUV411_MODE;
				break;
			case 0x22:									// yuv420
				*P_MPEG4_YUV_SEL = 0x00000000;
				*P_MPEG4_MODE_CTRL1 = C_MPEG4_JPEG_DEC
										| C_MPEG4_YUV420_MODE;
				*P_MPEG4_YUV_MODE = 0x30;
				break;
			case 0x12:									// 不支持 單 垂直采樣2:1模式
				return 0;								// i can't decode this JPG file
		}	// end switch
	}	// end if
	return 1;
}	// end function

//=============================================================
// 語法格式:	Get_Huffman_cs_cw(unsigned char *cs, unsigned int *cw, unsigned char *pointer);
// 實現功能:	獲得Huffman表
// 參數:		*cs,huffman的VLC的相對開始;*cw,存儲huffman表;*pointer,指向jpeg數據
// 返回值:		無
//=============================================================
static void Get_Huffman_cs_cw(unsigned char *cs, unsigned int *cw, unsigned char *pointer)
{
	unsigned char pcount[16];
	unsigned int index;
	unsigned int l_codeword = 0;						// local_codeword
	unsigned int last_valid;
	unsigned int j;
	
	for(j=0; j<16; j++)
	{
		pcount[j] = *pointer++;
	}
	for(j=15; j>=0; j--)
	{
		if(pcount[j])
			break;
	}

	last_valid = j;

	for(index=0; index<16; index++)
	{
		if(0 == index)
		{
			cs[0] = 0;
		}
		else if(1 == index)
		{
			cs[1] = pcount[0];
		}
		else
		{
			cs[index] = cs[index - 1] + pcount[index - 1];
		}	// end if(0 == index)

		if(index == 0)
		{
			cw[index] = 0;
			if(pcount[0] == 1)
				l_codeword = 1;
			else
				l_codeword = 0;
		}
		else if(index <= last_valid)
		{
			if(0 == cs[index])
			{
				l_codeword = 0;
			}
			l_codeword = l_codeword << 1;
			cw[index] = l_codeword;
			l_codeword = l_codeword + pcount[index];
		}
		else
		{
			cw[index] = 0xffff;
		}	// end if(index == 0)
	} // end for(index=0; index<16; index++)
}

//=============================================================
// 語法格式:	void set_Huff_sram_mode(int Page);
// 實現功能:	向SPCE3200填充TSRAM,前4頁存儲亮度信息,后4頁存儲色度信息
// 參數:		Page,選擇TSRAM的頁數
// 返回值:		無
//=============================================================
static void set_Huff_sram_mode(int Page)
{
	if(Page == 0)
		*P_MPEG4_TSRAM_CTRL = C_MPEG4_CPU_TSRAM
								| C_MPEG4_TSRAM_PAGE0;
	else if(Page == 1)
		*P_MPEG4_TSRAM_CTRL = C_MPEG4_CPU_TSRAM
								| C_MPEG4_TSRAM_PAGE1;
	else if(Page == 2)
		*P_MPEG4_TSRAM_CTRL = C_MPEG4_CPU_TSRAM
								| C_MPEG4_TSRAM_PAGE2;
	else if(Page == 3)
		*P_MPEG4_TSRAM_CTRL = C_MPEG4_CPU_TSRAM
								| C_MPEG4_TSRAM_PAGE3;
	else if(Page == 4)
		*P_MPEG4_TSRAM_CTRL = C_MPEG4_CPU_TSRAM
								| C_MPEG4_TSRAM_PAGE4;
	else if(Page == 5)
		*P_MPEG4_TSRAM_CTRL = C_MPEG4_CPU_TSRAM
								| C_MPEG4_TSRAM_PAGE5;
	else if(Page == 6)
		*P_MPEG4_TSRAM_CTRL = C_MPEG4_CPU_TSRAM
								| C_MPEG4_TSRAM_PAGE6;
	else if(Page == 7)
		*P_MPEG4_TSRAM_CTRL = C_MPEG4_CPU_TSRAM
								| C_MPEG4_TSRAM_PAGE7;
	else
		*P_MPEG4_TSRAM_CTRL = C_MPEG4_CPU_REG;
}

//=============================================================
// 語法格式:	set_jpg_huffman_cw_reg(unsigned char htype, unsigned int *cw);
// 實現功能:	填充Huffman表
// 參數:		htype,huffman表的類型;*cw,存儲的huffman表
// 返回值:		無
//=============================================================
static void set_jpg_huffman_cw_reg(unsigned char htype, unsigned int *cw)
{
	unsigned int i;
	unsigned int *pointer;

	if(htype == 0x00)
		pointer = (unsigned int *)P_MPEG4_HUFFMAN_START;				// YDC huffman
	else if(htype == 0x01)
		pointer = (unsigned int *)P_MPEG4_CHROMDCCODE_START;			// CDC huffman
	else if(htype == 0x10)
		pointer = (unsigned int *)P_MPEG4_LUMACHUFFMANTABLE_START;		// YAC huffman
	else if(htype == 0x11)
		pointer = (unsigned int *)P_MPEG4_CHROMACHUFFMANTABLE_START;	// CAC huffman

	for(i=0; i<8; i++)
	{
		*pointer++ = cw[i];
	}
	for(i=8; i<16; i++)
	{
		*pointer++ = cw[i];
		*pointer++ = cw[i] >> 8;
	}
}

//=============================================================
// 語法格式:	set_jpg_huffman_acs_reg(int chrominance, unsigned char *cs);
// 實現功能:	填充 AC Huffman VLC偏移
// 參數:		chrominance,選擇亮度還是色度;*cs,VLC偏移
// 返回值:		無
//=============================================================
static void set_jpg_huffman_acs_reg(int chrominance, unsigned char *cs)
{
	unsigned int i;
	unsigned int *pointer;
	
	if(chrominance == 0)
	{
		pointer = (unsigned int *)P_MPEG4_LUMACHUFFMANOFFSET_SA;
	}
	else
	{
		pointer = (unsigned int *)P_MPEG4_CHROMACHUFFMANOFFSET_SA;
	}
	
	for(i=0; i<16; i++)
	{
		*pointer++ = (unsigned int)cs[i];
	}
}

//=============================================================
// 語法格式:	set_jpg_huffman_acs_reg(int chrominance, unsigned char *cs);
// 實現功能:	填充 AC Huffman值
// 參數:		chrominance,選擇亮度還是色度;*cv,AC huffman值
// 返回值:		無
//=============================================================
static void set_jpg_huffman_acv_sram(int chrominance, unsigned char *cv)
{
	unsigned int Huffman_SRAM_Page;
	unsigned int *pointer;
	unsigned int j, i, k;
	
	if(chrominance == 0)
		Huffman_SRAM_Page = 0;
	else
		Huffman_SRAM_Page = 4;
	
	for(j=0; j<4; j++)
	{
		set_Huff_sram_mode(Huffman_SRAM_Page);
		pointer = (unsigned int *)P_MPEG4_LUMDCCODE_START;
		k= j * 64;
		
		for(i=0; i<64; i++)
		{
			*pointer++ = (unsigned int)cv[k++];
		}
		Huffman_SRAM_Page++;
	}
	set_Huff_sram_mode(8);
}

//=============================================================
// 語法格式:	void set_jpg_huffman_dcs_reg(int chrominance, unsigned char *cs);
// 實現功能:	填充 DC Huffman VLC偏移
// 參數:		chrominance,選擇亮度還是色度;*cs,VLC偏移
// 返回值:		無
//=============================================================
static void set_jpg_huffman_dcs_reg(int chrominance, unsigned char *cs)
{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩久久久| 国产日本亚洲高清| 国产亚洲欧美激情| 亚洲一二三四在线| 国产成人综合亚洲91猫咪| 欧美美女bb生活片| 日韩毛片一二三区| 国产一区福利在线| 日韩免费观看高清完整版| 亚洲人成影院在线观看| 国产高清成人在线| 欧美大胆人体bbbb| 男人的天堂久久精品| 欧美欧美午夜aⅴ在线观看| 国产精品毛片久久久久久| 激情综合五月天| 日韩精品在线一区二区| 日韩av电影免费观看高清完整版 | 欧美久久久一区| 亚洲免费在线视频一区 二区| 国产成人久久精品77777最新版本| 欧美精品色综合| 亚洲第一主播视频| 91黄色激情网站| 夜夜精品视频一区二区| 日本黄色一区二区| 亚洲五月六月丁香激情| 91精品1区2区| 亚洲1区2区3区视频| 欧美性猛交xxxxxx富婆| 亚洲国产日韩a在线播放性色| 91亚洲精品乱码久久久久久蜜桃| 欧美激情一区二区在线| 国产成人在线视频免费播放| 国产女同性恋一区二区| 成人在线一区二区三区| 国产精品免费久久久久| 成人国产精品视频| 亚洲欧洲韩国日本视频| 99re这里只有精品6| 亚洲美女一区二区三区| 欧美日韩精品系列| 日韩和欧美一区二区三区| 欧美一区二区三区系列电影| 狠狠v欧美v日韩v亚洲ⅴ| 久久久av毛片精品| 99re这里只有精品6| 亚洲一区精品在线| 欧美一级片免费看| 国产自产2019最新不卡| 亚洲欧洲99久久| 欧美性色黄大片| 狠狠色综合播放一区二区| 国产女主播一区| 在线观看区一区二| 另类综合日韩欧美亚洲| 国产精品美女一区二区| 一本大道久久a久久精品综合| 亚洲国产日韩在线一区模特| 精品免费国产二区三区| 99亚偷拍自图区亚洲| 午夜亚洲福利老司机| 精品国产乱码久久久久久闺蜜| 国产成人亚洲综合a∨婷婷图片| 亚洲视频在线观看三级| 欧美一区二区三区白人| 粉嫩aⅴ一区二区三区四区| 亚洲福中文字幕伊人影院| 久久嫩草精品久久久精品| 一本一道综合狠狠老| 精品在线亚洲视频| 亚洲已满18点击进入久久| 精品国一区二区三区| 色综合天天做天天爱| 韩国精品一区二区| 亚洲精品欧美二区三区中文字幕| 欧美xxxxx裸体时装秀| 91福利在线看| 风流少妇一区二区| 蜜臀91精品一区二区三区 | 91精彩视频在线观看| 国产一区二区成人久久免费影院 | 综合激情成人伊人| 日韩一级高清毛片| 欧美中文字幕亚洲一区二区va在线 | 成人在线综合网| 老司机一区二区| 亚洲一区二区三区中文字幕在线| 久久九九久久九九| 日韩免费观看高清完整版在线观看| 91免费观看视频在线| 国产精品一级片| 久久成人综合网| 午夜精品久久久久久不卡8050| 成人免费在线播放视频| 久久久久亚洲蜜桃| 91精品国产综合久久久久久漫画| 色综合一区二区| 成人美女在线视频| 国产精品亚洲人在线观看| 热久久一区二区| 亚洲成a人v欧美综合天堂| 一区二区三区成人| 亚洲日本欧美天堂| 一色屋精品亚洲香蕉网站| 久久亚洲春色中文字幕久久久| 8x8x8国产精品| 69堂精品视频| 91精品视频网| 欧美一区二区三区色| 欧美久久一二区| 欧美高清性hdvideosex| 884aa四虎影成人精品一区| 9191国产精品| 精品少妇一区二区三区在线播放 | 日韩一级高清毛片| 日韩亚洲欧美高清| 亚洲精品在线免费观看视频| 精品国产乱码久久久久久图片| 欧美刺激午夜性久久久久久久| 欧美成人aa大片| 久久久99精品免费观看不卡| 欧美激情一区二区在线| 国产精品高潮呻吟| 亚洲欧美日韩成人高清在线一区| 日韩一区日韩二区| 亚洲一区免费观看| 琪琪一区二区三区| 国产麻豆精品视频| 91影院在线观看| 欧美日韩精品高清| 精品精品国产高清a毛片牛牛| 久久精品在线观看| 亚洲精品日韩综合观看成人91| 亚洲国产aⅴ天堂久久| 蜜臀久久99精品久久久画质超高清| 麻豆精品一区二区三区| 顶级嫩模精品视频在线看| 色悠久久久久综合欧美99| 在线成人av影院| 2022国产精品视频| 亚洲女厕所小便bbb| 麻豆成人久久精品二区三区红| 国内精品国产三级国产a久久| 成人精品在线视频观看| 欧美视频在线一区| 久久综合资源网| 亚洲欧美另类小说视频| 美女www一区二区| 99久久国产综合精品麻豆| 日韩视频在线一区二区| 亚洲视频小说图片| 美女视频一区二区三区| 一本色道久久加勒比精品| 日韩欧美一级精品久久| 亚洲日韩欧美一区二区在线| 蜜臀av亚洲一区中文字幕| 99精品欧美一区二区蜜桃免费| 6080午夜不卡| 亚洲精品成人在线| 国产精品亚洲一区二区三区妖精| 在线观看网站黄不卡| wwww国产精品欧美| 婷婷综合在线观看| 色婷婷综合中文久久一本| 久久影院电视剧免费观看| 亚洲香蕉伊在人在线观| 成人精品视频一区二区三区尤物| 欧美精选一区二区| 亚洲黄一区二区三区| 丁香激情综合五月| 欧美大片在线观看一区二区| 亚洲资源中文字幕| 色综合色狠狠天天综合色| 久久久影视传媒| 久热成人在线视频| 在线视频中文字幕一区二区| 日本一区二区三区国色天香| 另类小说欧美激情| 7777精品伊人久久久大香线蕉 | 极品美女销魂一区二区三区| 欧美精品在线视频| 亚洲欧美区自拍先锋| 成人妖精视频yjsp地址| wwwwxxxxx欧美| 老鸭窝一区二区久久精品| 6080国产精品一区二区| 亚洲一区二区综合| 91久久精品网| 亚洲黄色录像片| 色综合久久88色综合天天| 国产精品亲子伦对白| 国产99久久久国产精品潘金网站| 日韩一级二级三级| 久久精工是国产品牌吗| 欧美一级久久久久久久大片| 免费欧美在线视频| 日韩视频免费观看高清完整版 | 亚洲一区二区av电影| 色欲综合视频天天天|