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

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

?? demo.c

?? 基于Linux的ffmepg decoder
?? C
字號:
#include <stdio.h>#include <stdlib.h>#include "jpeg_enc.h"#include "../../faraday_mpeg4_common/dev_mem.h"// to declare the dma memory allocation functionvoid *TM_DmaMalloc(unsigned int size,unsigned char align_size,unsigned char reserved_size,void ** phy_ptr);void  TM_DmaFree(void * virt_ptr, void * phy_ptr);#define MAX(x, y) ((x) > (y) ? (x) : (y))#define MIN(x, y) ((x) < (y) ? (x) : (y))#define IMAGE_WIDTH	480	//192#define IMAGE_HEIGHT 640	//128#define IMAGE_COMP	3#define IMAGE_QUALITY	90#define IMAGE_RST	5#define SET_COMP(index,hsamp,vsamp)  \  (enc_param.rgComponentInfo[index].m_u8HSamplingFrequency = (hsamp), \   enc_param.rgComponentInfo[index].m_u8VSamplingFrequency = (vsamp))static void usage(char *name);int main(int argc, char **argv){  unsigned int image_size[3],yuv_size=0;   unsigned char *image_phy_addr[3];  unsigned char *image_virt_addr[3];  unsigned char *pbitstream_phy_addr,*pbitstream_virt_addr;  unsigned int bitstream_size;  void *enc_handle;  unsigned int max_h_samp,max_v_samp;  unsigned char * base;  FJPEG_ENC_PARAM enc_param;  FILE *in_file,*out_file;  char in_filename[256];  char out_filename[256];  int YUVsampling = 1; // set default to YUV422  int i;    enc_param.u32ImageQuality = IMAGE_QUALITY; // we set image quality to 90 (0~100)    enc_param.u32RestartInterval = IMAGE_RST; // we set restart interval to 5    enc_param.u32ImageWidth=IMAGE_WIDTH;  // set image width  enc_param.u32ImageHeight=IMAGE_HEIGHT; // set image height  // to describe the YUV format through the following encoding parameters    enc_param.u8NumComponents = IMAGE_COMP; // the input image has 3 components 'YUV'  	for (i=1; i< argc; i++) {		if (strcmp("-i", argv[i]) == 0 && i < argc - 1 ) {			i ++;			strcpy (in_filename, argv[i]);		}		else if (strcmp("-o", argv[i]) == 0 && i < argc - 1 ) {			i ++;			strcpy (out_filename, argv[i]);		}		else if (strcmp("-w", argv[i]) == 0 && i < argc - 1 ) {			i++;			enc_param.u32ImageWidth = (unsigned int)atoi(argv[i]);		}		else if (strcmp("-h", argv[i]) == 0 && i < argc - 1 ) {			i++;			enc_param.u32ImageHeight = (unsigned int)atoi(argv[i]);		}		else if (strcmp("-comp", argv[i]) == 0 && i < argc - 1 ) {			i++;			enc_param.u8NumComponents = (unsigned int)atoi(argv[i]);		}		else if (strcmp("-qlt", argv[i]) == 0 && i < argc - 1 ) {			i++;			enc_param.u32ImageQuality = (unsigned int)atoi(argv[i]);		}		else if (strcmp("-rst", argv[i]) == 0 && i < argc - 1 ) {			i++;			enc_param.u32RestartInterval = (unsigned int)atoi(argv[i]);		}		else if (strcmp("-fmt", argv[i]) == 0 && i < argc - 1 ) {			i ++;			if (strcmp("yuv420", argv[i]) == 0)				YUVsampling = 0;			else if (strcmp("yuv422", argv[i]) == 0)				YUVsampling = 1;			else if (strcmp("yuv211", argv[i]) == 0)				YUVsampling = 2;			else if (strcmp("yuv333", argv[i]) == 0)				YUVsampling = 3;			else if (strcmp("yuv222", argv[i]) == 0)				YUVsampling = 4;			else if (strcmp("yuv111", argv[i]) == 0)				YUVsampling = 5;			else {				printf("Unreconigized format '%s', stop\n", argv[i]);				usage(argv[0]);				return -1;			}		}		else {			printf("Unreconigized parameter '%s', stop\n", argv[i]);			usage(argv[0]);			return -1;		}	}/***************************************************************************** * Values checking ****************************************************************************/	if ((enc_param.u32ImageWidth > 65536) || (enc_param.u32ImageHeight > 65536)) {		usage(argv[0]);		return -1;	}	if (enc_param.u8NumComponents > 3) {		usage(argv[0]);		return -1;	}	if (enc_param.u32ImageQuality > 100) {		usage(argv[0]);		return -1;	}	// open input YUV file, the YUV data file is arranged in 2D format	if((in_file=fopen(in_filename,"rb"))==NULL) {      printf ("Can't open file %s\n", in_filename);      exit(1);	}	// open output bitstream file	if((out_file=fopen(out_filename,"wb"))==NULL) {      printf ("Can't open file %s\n", out_filename);      exit(1);	}#ifdef LINUX  base = (unsigned char *)ioremap(0x90700000, 0x100000);  if (base == 0) {			/// maping failure	printf("mpeg4 maping failure\n");	return -1;  }  printf("jpeg virt addr = 0x%x\n", (int)base);#else  base = 0x90700000;#endif  // set the hardware core base address  enc_param.pu32BaseAddr = base;    if(enc_param.u8NumComponents==1)    YUVsampling = 5; // if there is only one component, it is gray, so we force it YUV111    	switch (YUVsampling) {		case 0:		  SET_COMP(0, 2, 2);		  SET_COMP(1, 1,1);		  SET_COMP(2, 1,1);		  break;		case 1:		  SET_COMP(0, 4,1);		  SET_COMP(1, 2,1);		  SET_COMP(2, 2,1);		  break;		case 2:		  SET_COMP(0, 2,1);		  SET_COMP(1, 1,1);		  SET_COMP(2, 1,1);		  break;		case 3:		  SET_COMP(0, 3,1);		  SET_COMP(1, 3,1);		  SET_COMP(2, 3,1);		  break;		case 4:		  SET_COMP(0, 2,1);		  SET_COMP(1, 2,1);		  SET_COMP(2, 2,1);		  break;		case 5:		  SET_COMP(0, 1,1);		  SET_COMP(1, 1,1);		  SET_COMP(2, 1,1);		  break;		default:		  break;	}  // to set each component's sampling factor (horizontally and vertically)  // get the maximum horizontal sampling factor  max_h_samp=MAX(enc_param.rgComponentInfo[0].m_u8HSamplingFrequency,                 MAX(enc_param.rgComponentInfo[1].m_u8HSamplingFrequency,                     enc_param.rgComponentInfo[2].m_u8HSamplingFrequency));  // get the maximum horizontal sampling factor  max_v_samp=MAX(enc_param.rgComponentInfo[0].m_u8VSamplingFrequency,                 MAX(enc_param.rgComponentInfo[1].m_u8VSamplingFrequency,                     enc_param.rgComponentInfo[2].m_u8VSamplingFrequency));                         // calculate each component size according to its maximum sampling factor  // and individual sampling factor  for(i=0;i<enc_param.u8NumComponents;i++)    {      image_size[i]=(((enc_param.rgComponentInfo[i].m_u8HSamplingFrequency*enc_param.u32ImageWidth)                       /max_h_samp) *                    ((enc_param.rgComponentInfo[i].m_u8VSamplingFrequency*enc_param.u32ImageHeight)                       /max_v_samp));      yuv_size += image_size[i];            // allocate the input Y frame buffer with 8-byte aligned (64-bit alignment)        if((image_virt_addr[i]=(unsigned char *)TM_DmaMalloc(image_size[i],8,16,&image_phy_addr[i]))==NULL)        { printf("Memory allocation error!\n"); exit(1); }       // set each component's buffer address to the encoding parameter      enc_param.pu8YUVAddr[i]=image_phy_addr[i];      // to read the Y component of YUV data from file      if(fread(image_virt_addr[i],sizeof(unsigned char),image_size[i],in_file)!=image_size[i])        { printf("File read error!\n"); exit(1); }     }  // assign bitstream buffer about the 1.5 * YUV image buffer size  bitstream_size=(yuv_size*3)/2;  // allocate the output bitstream buffer with 4-byte aligned (32-bit alignment)    if((pbitstream_virt_addr=(unsigned char*)TM_DmaMalloc(bitstream_size,4,16,&pbitstream_phy_addr))==NULL)    exit(1);  enc_param.pu8BitstreamAddr=pbitstream_phy_addr;    // to create the jpeg encoder object  enc_handle=FJpegEncCreate(&enc_param);  if(!enc_handle) exit(1);    // to begin to encode the input image  FJpegEncEncode(enc_handle);      // to obtain encoded bitstream buffer length  bitstream_size=FJpegEncGetBitsLength(enc_handle);  // write the encoded bitstream to the file  fwrite(pbitstream_virt_addr,sizeof(unsigned char),bitstream_size,out_file);  printf("JPEG Encoding is done!, jpeg file size = 0x%x\n", bitstream_size);      // release the JPEG encoder object  FJpegEncDestroy(enc_handle);    // free the allocated JPEG bitstream aligned buffer  TM_DmaFree(pbitstream_virt_addr,pbitstream_phy_addr);  for(i=0;i<enc_param.u8NumComponents;i++)    { TM_DmaFree(image_virt_addr[i],image_phy_addr[i]); }      // close output YUV file  fclose(out_file);      // close input bitstream file  fclose(in_file);  return 0;}void * TM_DmaMalloc(unsigned int size,unsigned char align_size,unsigned char reserved_size,void ** phy_ptr){	unsigned char *virt_mem_ptr;	unsigned char *virt_ret;	if (!align_size) {		size += (reserved_size + 9);	   	if (dma_malloc(size, phy_ptr, (void **)&virt_mem_ptr, (void **)&virt_ret) == 0) {			/* Store (mem_ptr - "real allocated memory") in *(mem_ptr-9) */			*(virt_mem_ptr + 0) = 9;			/* Store (malloc size) in *(mem_ptr-8) ~ *(mem_ptr-5)*/			*(virt_mem_ptr + 1) = (size >> 24) & 0xFF;			*(virt_mem_ptr + 2) = (size >> 16) & 0xFF;			*(virt_mem_ptr + 3) = (size >> 8) & 0xFF;			*(virt_mem_ptr + 4) = (size >> 0) & 0xFF;			/* Store (virt_ret at consistent_alloc) in *(mem_ptr-4) ~ *(mem_ptr-1)*/			*(virt_mem_ptr + 5) = ((unsigned int)virt_ret >> 24) & 0xFF;			*(virt_mem_ptr + 6) = ((unsigned int)virt_ret >> 16) & 0xFF;			*(virt_mem_ptr + 7) = ((unsigned int)virt_ret >> 8) & 0xFF;			*(virt_mem_ptr + 8) = ((unsigned int)virt_ret >> 0) & 0xFF;			*(unsigned int *)phy_ptr += 9;			/* Return the mem_ptr pointer */			return (void *) (virt_mem_ptr + 9);		}	}	else {		unsigned char *tmp;		/*		 * Allocate the required size memory + alignment so we		 * can realign the data if necessary		 */		size += (reserved_size + align_size + 8);	   	if (dma_malloc(size, phy_ptr, (void **)&tmp, (void **)&virt_ret) == 0) {			/* Align the tmp pointer */			virt_mem_ptr =				(unsigned char *) ((unsigned int) (tmp + 8 + align_size - 1) &							 (~(unsigned int) (align_size - 1)));			/*			 * Special case where malloc have already satisfied the alignment			 * We must add alignment to mem_ptr because we must store			 * (mem_ptr - tmp) in *(mem_ptr-1)			 * If we do not add alignment to mem_ptr then *(mem_ptr-1) points			 * to a forbidden memory space			 */			while ((virt_mem_ptr - tmp) <= 8)				virt_mem_ptr += align_size;			*(unsigned int *)phy_ptr += (virt_mem_ptr - tmp);			/*			 * (mem_ptr - tmp) is stored in *(mem_ptr-1) so we are able to retrieve			 * the real malloc block allocated and free it in xvid_free			 */			/* Store (mem_ptr - "real allocated memory") in *(mem_ptr-5) */			*(virt_mem_ptr - 9) = (unsigned char) (virt_mem_ptr - tmp);			/* Store (malloc size) in *(mem_ptr-8) ~ *(mem_ptr-5)*/			*(virt_mem_ptr - 8) = (size >> 24) & 0xFF;			*(virt_mem_ptr - 7) = (size >> 16) & 0xFF;			*(virt_mem_ptr - 6) = (size >> 8) & 0xFF;			*(virt_mem_ptr - 5) = (size >> 0) & 0xFF;			/* Store (virt_ret at consistent_alloc) in *(mem_ptr-4) ~ *(mem_ptr-1)*/			*(virt_mem_ptr - 4) = ((unsigned int)virt_ret >> 24) & 0xFF;			*(virt_mem_ptr - 3) = ((unsigned int)virt_ret >> 16) & 0xFF;			*(virt_mem_ptr - 2) = ((unsigned int)virt_ret >> 8) & 0xFF;			*(virt_mem_ptr - 1) = ((unsigned int)virt_ret >> 0) & 0xFF;			/* Return the aligned pointer */			return (void *) virt_mem_ptr;		}	}	return NULL;}void TM_DmaFree(void * virt_ptr, void * phy_ptr){	unsigned int tsize;	unsigned char *virt_ret;	unsigned char offset;	/* *(virt_mem_ptr - 1) give us the offset to the real malloc block */	if (virt_ptr) {		offset = *(unsigned char *) ((unsigned int) virt_ptr - 9);		tsize = (*(unsigned char *)((unsigned int) virt_ptr - 8) << 24) +		  	(*(unsigned char *)((unsigned int) virt_ptr - 7) << 16) +			(*(unsigned char *)((unsigned int) virt_ptr - 6) << 8) +			(*(unsigned char *)((unsigned int) virt_ptr - 5) << 0);		virt_ret = (unsigned char*)((*(unsigned char *)((unsigned int) virt_ptr - 4) << 24) +						(*(unsigned char *)((unsigned int) virt_ptr - 3) << 16) +						(*(unsigned char *)((unsigned int) virt_ptr - 2) << 8) +						(*(unsigned char *)((unsigned int) virt_ptr - 1) << 0));		dma_free(tsize,								// total size				(void *)((unsigned int) phy_ptr - offset),	// original phy point				(void *)((unsigned int) virt_ptr - offset),		// original virt point				virt_ret);					//  	}}static void usage(char *name){	fprintf(stderr, "Usage : %s <-i input_file>  <-o output_file> [OPTIONS]\n", name);	fprintf(stderr, "-i input_file            : input raw data file name\n");	fprintf(stderr, "-o output_file         : output jpeg file name\n");	fprintf(stderr, "Options :\n");	fprintf(stderr, "-fmt input_format  : input file format, posible: \"yuv420\", \"yuv422\", \"yuv211\", \"yuv333\", \"yuv222\", \"yuv111\"  (default = yuv422)\n");	fprintf(stderr, " -w integer            : picture width ([1.2048, default = %d])\n", IMAGE_WIDTH);	fprintf(stderr, " -h integer           : picture height ([1.2048], default = %d)\n", IMAGE_HEIGHT);	fprintf(stderr, " -qlt integer         : quality ([1.100], default = %d)\n", IMAGE_QUALITY);	fprintf(stderr, " -rst integer        : restart marker([1. inf], default = %d)\n", IMAGE_RST);	fprintf(stderr, " -comp integer    : component number in input file ([1. 3], default = %d)\n", IMAGE_COMP);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区四区视频精品免费 | 久久国产人妖系列| 亚洲麻豆国产自偷在线| 成人欧美一区二区三区在线播放| 欧美高清在线一区| 国产精品美女久久久久aⅴ国产馆| 久久久久久免费| 中文字幕欧美日本乱码一线二线| 日本一区二区成人| 亚洲人成网站在线| 亚洲午夜在线观看视频在线| 亚洲成人在线免费| 国产成人av福利| 激情五月播播久久久精品| 韩国三级在线一区| 国产成人精品影视| 91在线国内视频| 欧美午夜电影一区| 欧美一级国产精品| 26uuu久久综合| 中文字幕在线不卡| 亚洲国产成人va在线观看天堂| 天天射综合影视| 久久精品99久久久| 国产成人超碰人人澡人人澡| 91视频在线观看免费| 欧美日本一区二区| 久久一区二区三区四区| 国产精品电影一区二区三区| 亚洲午夜在线视频| 久久精品国产一区二区| 成人国产精品视频| 欧美综合一区二区| 精品粉嫩超白一线天av| 中文字幕永久在线不卡| 无吗不卡中文字幕| 国产成人av电影在线观看| 欧美性极品少妇| 欧美精品一区二区在线观看| 亚洲欧美色图小说| 久久国产视频网| 色婷婷亚洲一区二区三区| 日韩亚洲欧美成人一区| 中文字幕一区二区三区在线播放 | 日韩有码一区二区三区| 国产乱码精品一区二区三区忘忧草| 91视频一区二区三区| 欧美一激情一区二区三区| 国产精品久久久久影院老司| 日韩av午夜在线观看| 91在线高清观看| 日韩欧美在线网站| 亚洲婷婷国产精品电影人久久| 日韩av电影一区| 99re热这里只有精品视频| 欧美成人一区二区| 亚洲一区二区黄色| 成人一区二区在线观看| 日韩一区二区精品在线观看| 亚洲黄色小视频| 国产成人在线视频网站| 欧美一区二区三区视频免费播放| 《视频一区视频二区| 国产一区二区剧情av在线| 欧美亚洲高清一区二区三区不卡| 久久精品在线观看| 美美哒免费高清在线观看视频一区二区| 99久久久国产精品免费蜜臀| 久久综合九色综合97婷婷女人| 亚洲成av人片| 一本大道久久a久久精二百 | 午夜视黄欧洲亚洲| 91亚洲资源网| 日本一区二区三区四区在线视频| 免费在线观看一区| 欧美日韩和欧美的一区二区| 亚洲欧美日韩在线| 成人精品高清在线| 久久欧美中文字幕| 蜜臀久久久久久久| 欧美精品777| 亚洲伦在线观看| av一区二区三区| 国产精品丝袜久久久久久app| 免费成人性网站| 宅男噜噜噜66一区二区66| 亚洲福利一区二区三区| 91片在线免费观看| 中文字幕视频一区| 欧美日韩一区在线观看| 亚洲天堂网中文字| 色综合一个色综合亚洲| 国产精品污www在线观看| 国产经典欧美精品| 国产欧美日韩三级| 国产黄人亚洲片| 欧美激情在线看| 成人美女在线视频| 中文字幕在线不卡一区二区三区| 成人美女视频在线观看18| 国产精品日韩成人| 91在线精品秘密一区二区| 亚洲婷婷国产精品电影人久久| 99国产精品国产精品毛片| 亚洲欧洲成人精品av97| 色素色在线综合| 午夜视频在线观看一区| 91精品国产欧美日韩| 裸体歌舞表演一区二区| 精品毛片乱码1区2区3区| 激情综合色综合久久综合| 2021久久国产精品不只是精品| 激情五月婷婷综合网| 国产女人水真多18毛片18精品视频 | 最新日韩av在线| 91小宝寻花一区二区三区| 亚洲综合精品自拍| 宅男在线国产精品| 国产在线精品免费| 国产精品久久久久久一区二区三区 | 国产a精品视频| 国产精品久久久久久久久免费樱桃 | 欧美日韩一区二区三区不卡| 午夜精品福利视频网站| 日韩亚洲欧美一区二区三区| 国产一区二区影院| 日韩一区在线免费观看| 欧美日韩一区二区在线视频| 另类专区欧美蜜桃臀第一页| 欧美国产日韩亚洲一区| 在线免费不卡视频| 久久国产精品露脸对白| 欧美国产日韩亚洲一区| 欧美体内she精高潮| 精品一区二区三区免费播放| 国产精品夫妻自拍| 91麻豆精品国产自产在线| 国产精品综合一区二区三区| 亚洲欧洲成人精品av97| 欧美一区二区三区免费| 国产91精品一区二区麻豆网站| **欧美大码日韩| 91精品国产日韩91久久久久久| 国产成人综合在线| 亚洲成人一区在线| 国产日韩精品视频一区| 欧美日韩黄视频| 国产 日韩 欧美大片| 亚洲第一福利视频在线| 久久精品人人做| 欧美性受xxxx| 成人免费毛片高清视频| 五月天婷婷综合| 国产精品久久久一本精品| 日韩一级大片在线| 91麻豆精品国产无毒不卡在线观看| 国产一区二区三区黄视频 | 欧美日韩日日摸| 国产91色综合久久免费分享| 亚洲线精品一区二区三区八戒| 久久免费视频一区| 欧美日韩一区久久| www.日本不卡| 精品亚洲aⅴ乱码一区二区三区| 亚洲欧洲在线观看av| 日韩一区二区在线观看视频| 91香蕉视频黄| 国产福利精品一区二区| 日本欧美在线观看| 一区二区三区91| 国产精品美女久久久久aⅴ| 欧美成人精精品一区二区频| 欧美午夜不卡在线观看免费| 成人免费高清视频在线观看| 奇米一区二区三区| 亚洲一区二区欧美激情| 中文字幕中文在线不卡住| 欧美电视剧免费观看| 欧美日高清视频| 在线精品视频小说1| 成人高清免费在线播放| 国内精品国产成人国产三级粉色 | 亚洲精品写真福利| 国产日韩一级二级三级| 欧美电视剧免费全集观看| 在线观看91av| 欧美日韩一区三区四区| 91福利国产精品| 92国产精品观看| 99久久婷婷国产| 粗大黑人巨茎大战欧美成人| 精品一区二区三区久久久| 日韩经典中文字幕一区| 亚洲韩国精品一区| 亚洲中国最大av网站| 亚洲人成电影网站色mp4| 国产精品久久久久一区二区三区| 中文字幕第一页久久| 国产精品美女一区二区三区| 国产丝袜欧美中文另类|