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

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

?? testcamera.c

?? S3C2440 攝像頭linux2.4.18的驅動
?? C
?? 第 1 頁 / 共 2 頁
字號:
	if(fd<0) {		fd = open("/dev/misc/i2c", O_RDWR);		if(fd<0) {			printf("fail to open i2c adapter device!\n");			return -1;		}	}	if(ioctl(fd, I2C_SLAVE, CAMERA_I2C_ADDR)<0) {		printf("fail to set i2c device slave address!\n");		close(fd);		return -1;	}	printf("set slave address to 0x%x success!\n", CAMERA_I2C_ADDR);	if(i2c_read(fd, CAMERA_MIDH, id)||i2c_read(fd, CAMERA_MIDL, id+1)) {		printf("fail to get camera MID!\n");		close(fd);		return -1;	}	printf("manufactory ID is 0x%04x\n", (id[0]<<8)|id[1]);	i2c_read(fd, CAMERA_PIDH, id+2);	i2c_read(fd, CAMERA_PIDL, id+3);	printf("product ID is 0x%04x\n", (id[2]<<8)|id[3]);	for(i=0; i<CAMERA_REGS; i++) {		if(camera_regs[i].subaddr==CHIP_DELAY)			delay_ms(camera_regs[i].value);		else if(i2c_write(fd, camera_regs[i].subaddr, camera_regs[i].value))			printf("write subaddr 0x%x fail!\n", camera_regs[i].subaddr);		//delay_ms(2);		//printf("%d\n", i);	}	if(cpu_type==1)	{	//s3c2440a		i2c_write(fd, 0x15, 0x00);	//always has PCLK		i2c_write(fd, 0x3a, 0x01);	//YCbYCr order	}		close(fd);	return 0;}#else#define	camera_i2c_init()	0#endif#ifdef SCCB_INITstatic int sccb_init(int fd){	int i;	__u16 val;	__u8 id[4];		val = CAMERA_MIDH<<8;	if(ioctl(fd, WCAM_VIDIOCGCAMREG, &val)<0) {		printf("get camera register fail!\n");		return -1;	}	id[0] = val;	val = CAMERA_MIDL<<8;	if(ioctl(fd, WCAM_VIDIOCGCAMREG, &val)<0) {		printf("get camera register fail!\n");		return -1;	}	id[1] = val;	printf("manufactory ID is 0x%04x\n", (id[0]<<8)|id[1]);		val = CAMERA_PIDH<<8;	if(ioctl(fd, WCAM_VIDIOCGCAMREG, &val)<0) {		printf("get camera register fail!\n");		return -1;	}	id[2] = val;	val = CAMERA_PIDL<<8;	if(ioctl(fd, WCAM_VIDIOCGCAMREG, &val)<0) {		printf("get camera register fail!\n");		return -1;	}	id[3] = val;	printf("product ID is 0x%04x\n", (id[2]<<8)|id[3]);	for(i=0; i<CAMERA_REGS; i++) {		if(camera_regs[i].subaddr==CHIP_DELAY)			delay_ms(camera_regs[i].value);		else {			val = (camera_regs[i].subaddr<<8)|camera_regs[i].value;			if(ioctl(fd, WCAM_VIDIOCSCAMREG, &val)<0)				printf("write subaddr 0x%x fail!\n", camera_regs[i].subaddr);		}	}	return 0;}#else#define	sccb_init(fd)		0#endif/*************************************************************/static void usage(void){	int i;	printf("testcamera [-x/y/p/m/v/o/f/u/h options]\n");	printf("-w width   (set output image width, must be 4 alignment)\n");	printf("-h height  (set output image height, must be 4 alignment)\n");	printf("-p palette (set output image color space)\n");	printf("	optional image:\n");	for(i=0; i<MAX_IMAGE_FORMAT; i++)		printf("	[%2d] : %s\n", i, optional_image_format[i].name);	printf("-m         (use mmap method for camera)\n");	printf("-v         (capture video instead of still image)\n");	printf("-o number  (set save jpeg file optimization, must be 0~100)\n");	printf("-f name    (set save jpeg file prefix name)\n");	printf("-u arch    (set CPU type)\n");	printf("	current special CPU:\n");	printf("	pxa27x\n");	printf("	s3c2440a\n");	printf("	default is pxa27x\n");	printf("-h show help\n");}static int getoptions(int argc, char *argv[]){	int ret = 0;	char c;	opterr = 0;	//don't print error message	while ((c = getopt (argc, argv, "x:y:p:o:f:u:mvh")) != (char)EOF)	/* Scan the command line for options */	switch (c) {	case 'x':		image_width = atoi(optarg);		if((image_width%4)||(image_width>FIXED_SOURCE_WIDTH))			ret = -1;		break;	case 'y':		image_height = atoi(optarg);		if((image_height%4)||(image_height>FIXED_SOURCE_HEIGHT))			ret = -1;		break;	case 'p':		image_format = atoi(optarg);		if(image_format>=MAX_IMAGE_FORMAT)			ret = -1;		break;	case 'o':		optimization = atoi(optarg);		if(optimization>100)			ret = -1;		break;	case 'f':		image_file = optarg;		break;	case 'm':		mmap_camera = 1;		break;	case 'v':		capture_video = 1;		break;	case 'u':		if(strncmp(optarg, "pxa27x", 6)==0)			cpu_type = 0;		else if(strncmp(optarg, "s3c2440a", 8)==0)			cpu_type = 1;		else			printf("unknown CPU type\n");		break;	case 'h':		//ret = -1;		//break;	default:		ret = -1;		break;	}	return ret;}/*************************************************************/int main(int argc, char *argv[]){	int i, fd, fbfd;	struct fb_var_screeninfo vinfo;	struct fb_fix_screeninfo finfo;	__u8 *fb_buf;	__u32 screensize;	struct video_capability vc;	struct video_window vw;	struct video_capture vcp;	struct video_picture vp;	struct video_mbuf vm;	__u8 *buf = NULL;	int show, cnt;	fd_set rfds;	struct timeval tv;	struct termios tio;	int c_lflag;	fbfd = open("/dev/fb0", O_RDWR);	if (fbfd < 0) {		fbfd = open("/dev/fb/0", O_RDWR);		if(fbfd<0) {			printf("Error: cannot open framebuffer device.\n");		        return -1;		}	}	// Get fixed screen information	if (ioctl(fbfd, FBIOGET_FSCREENINFO, &finfo)) {				printf("Error reading fixed information.\n");		close(fbfd);        	return -1;	}	// Get variable screen information	if (ioctl(fbfd, FBIOGET_VSCREENINFO, &vinfo)) {		printf("Error reading variable information.\n");		close(fbfd);		return -1;	}	printf("%dx%d, %dbpp\n", vinfo.xres, vinfo.yres, vinfo.bits_per_pixel );	fb_xres = vinfo.xres;	fb_yres = vinfo.yres;	fb_bpp  = vinfo.bits_per_pixel;	screensize = vinfo.xres * vinfo.yres * vinfo.bits_per_pixel / 8;	fb_buf = (char *)mmap(0, screensize, PROT_READ | PROT_WRITE, MAP_SHARED,				fbfd, 0);	if ((int)fb_buf == -1) {		printf("Error: failed to map framebuffer device to memory.\n");		close(fbfd);        	return -1;	}	test_ycbcr_to_rgb(fb_buf);	if(getoptions(argc, argv)<0) {		close(fbfd);		usage();		return -1;	}	fd = open("/dev/v4l/video0", O_RDONLY);	//rd&wr	if(fd<0) {		fprintf(stderr, "Open camera fail!\n");		close(fbfd);		return -1;	} else		fprintf(stdout, "Open camera success\n");	if(camera_i2c_init()||sccb_init(fd)) {		printf("fail to initialize the I2C interface of camera!\n");		close(fd);		close(fbfd);		return -1;	}	if(ioctl(fd, VIDIOCGCAP, &vc)<0)		printf("VIDIOCGCAP fail\n");	else		printf("max width %d, height %d\nmin width %d, height %d\n",			vc.maxwidth, vc.maxheight, vc.minwidth, vc.minheight);	vw.width  = FIXED_SOURCE_WIDTH;		//fixed in this application	vw.height = FIXED_SOURCE_HEIGHT;	//fixed in this application	if(ioctl(fd, VIDIOCSWIN, &vw)<0)		printf("VIDIOCSWIN fail\n");	if(ioctl(fd, VIDIOCGWIN, &vw)<0)		printf("VIDIOCGWIN fail\n");	else		printf("current width %d, height %d\n",	vw.width, vw.height);	if(!image_width||!image_height) {		image_width  = vw.width;		image_height = vw.height;	}	//useful in s3c2440a	vcp.width  = image_width;	vcp.height = image_height;	if(ioctl(fd, VIDIOCSCAPTURE, &vcp)<0)		printf("VIDIOCSCAPTURE fail\n");	else {		if(ioctl(fd, VIDIOCGCAPTURE, &vcp)<0)			printf("VIDIOCGCAPTURE fail\n");		else			printf("capture width %d, height %d\n", vcp.width, vcp.height);	}	vp.palette = optional_image_format[image_format].palette;	if(ioctl(fd, VIDIOCSPICT, &vp)<0)		printf("VIDIOCSPICT fail\n");	if(ioctl(fd, VIDIOCGPICT, &vp)<0)		printf("VIDIOCGPICT fail\n");	else		printf("current palette %d\n",	vp.palette);	if(cpu_type==0) {		struct reg_set_s reg;		//extend ioctl, just in pxa270		reg.val1 = CAMERA_IMAGE_FORMAT_YCBCR422_PACKED;	//input format for pxa270		reg.val2 = CAMERA_IMAGE_FORMAT_YCBCR422_PLANAR;	//output format for pxa270		if(ioctl(fd, WCAM_VIDIOCSINFOR, &reg)<0)			printf("WCAM_VIDIOCSINFOR fail\n");		if(ioctl(fd, WCAM_VIDIOCGINFOR, &reg)<0)			printf("WCAM_VIDIOCGINFOR fail\n");		else			printf("current input format %d, output format %d\n",				reg.val1, reg.val2);	}	if(mmap_camera) {		if(ioctl(fd, VIDIOCGMBUF, &vm)<0) {			printf("VIDIOCGMBUF fail\n");			mmap_camera = 0;		} else {			printf("current camera buffer size %d, total frames %d\n",				vm.size, vm.frames);					buf = (__u8 *)mmap(0, vm.size, PROT_READ, MAP_SHARED, fd, 0);			if((int)buf==-1) {				printf("mmap camera fail!\n");				mmap_camera = 0;			} else				puts("mmap camera ok.\n");		}	}	if(!mmap_camera) {		puts("allocate memory for camera buffer.\n");		buf = malloc(image_width*image_height*2);		if(!buf) {			printf("fail to allocate memory for camera!\n");			close(fd);			munmap(fb_buf, screensize);			close(fbfd);			return -1;		}	}	printf("buffer at 0x%08x\n", (int)buf);	//puts("press enter to start...\n");	//getchar();		if(tcgetattr(0, &tio)<0) {		printf("tcgetattr fail!\n");		goto fail;	} else {		c_lflag = tio.c_lflag;		tio.c_lflag &= ~(ICANON | ECHO);		if(tcsetattr(0, TCSAFLUSH, &tio)<0) {			printf("tcsetattr fail!\n");			goto fail;		}	}		printf("now start capture...\n");	printf("press Esc key to exit, 'c' to save picture, 'd' to enable/disable display\n");	if(capture_video) {		if(ioctl(fd, VIDIOCCAPTURE, VIDEO_START)<0) {			printf("VIDIOCCAPTURE fail\n");			goto fail;		}	} else if(!cpu_type){		if(ioctl(fd, VIDIOCCAPTURE, STILL_IMAGE)<0) {			printf("VIDIOCCAPTURE fail\n");			goto fail;		}	}		FD_ZERO(&rfds);	//FD_SET(0, &rfds);	//FD_SET(fd, &rfds);		show = 1;	cnt  = 0;	while(1) {		//in pxa270, if capture still image, can do it just one time		if(!capture_video&&cpu_type)			if(ioctl(fd, VIDIOCCAPTURE, STILL_IMAGE)<0) {				printf("VIDIOCCAPTURE fail\n");				break;			}		//FD_ZERO(&rfds);		FD_SET(0, &rfds);		FD_SET(fd, &rfds);		tv.tv_sec = 3;		tv.tv_usec = 0;		select(fd+1, &rfds, NULL,  NULL, &tv);		if(FD_ISSET(0, &rfds)) {			char cmd;			//printf("stdin input\n");			if(read(0, &cmd, 1)<0) {				printf("read stdin fail!\n");				break;			}			if(cmd=='d'||cmd=='D') {				show = !show;				printf("%s display\n", show?"enable":"disable");			} else if(cmd=='c'||cmd=='C') {				printf("save picture...\n");				save_picture(buf);			} else if(cmd==0x1b)				break;		} else if(FD_ISSET(fd, &rfds)) {			if(mmap_camera) {#if 1			//just for performance test in video capturing, int(rdy)->show->int->show			//use read to clear ready flag in driver				i = read(fd, buf, 0);	//mmap camera for read, so read 0 byte to buf				if(i<0) {					printf("read fail!%d\n", i);					break;				}#endif			} else {				i = read(fd, buf, image_width*image_height*2);				if(i<0) {					fprintf(stderr, "read fail! %d\n", i);					break;				}				//printf("read %d bytes\n", i);				cnt++;			}		} else {			printf("wait timeout, break...\n");			break;		}#if 0		{			FILE *wfp;			wfp = fopen("/tmp/dat", "w+b");			if(wfp==NULL) {				printf("fail to open file for save data!\n");				break;			}			printf("write %d bytes.\n", fwrite(buf, i, 1, wfp)*i);			fclose(wfp);			break;		}#endif		if(show)			show_cam_img(fb_buf, buf,					buf+image_width*image_height,					buf+(image_width*image_height*3)/2);	}	tio.c_lflag = c_lflag;	tcsetattr(0, TCSAFLUSH, &tio);fail:	if(mmap_camera)		munmap(buf, vm.size);	else		free(buf);	close(fd);	munmap(fb_buf, screensize);	close(fbfd);	return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久综合国产精品| 亚洲一区二区三区四区在线| 7777精品伊人久久久大香线蕉完整版| www.亚洲国产| 97精品国产露脸对白| 99精品视频在线观看免费| 国产69精品久久777的优势| 国产成人精品一区二| 国产一区二区精品久久99| 国产一区二区毛片| 成人永久aaa| 色综合久久九月婷婷色综合| 色天天综合久久久久综合片| 欧美色图12p| 日韩欧美综合一区| 国产亚洲女人久久久久毛片| 久久久久久久久久久99999| 亚洲国产高清不卡| 亚洲精品视频观看| 日韩av一区二区在线影视| 蜜臀av亚洲一区中文字幕| 国产一区二区h| av不卡免费电影| 欧美日韩国产成人在线免费| 欧美sm美女调教| 国产精品欧美一级免费| 一区二区不卡在线播放 | 加勒比av一区二区| 高清不卡一二三区| 91九色最新地址| 精品国一区二区三区| |精品福利一区二区三区| 一个色妞综合视频在线观看| 欧美96一区二区免费视频| 成人午夜免费av| 欧美高清视频不卡网| 国产欧美一区二区在线观看| 欧美大肚乱孕交hd孕妇| jiyouzz国产精品久久| 丁香啪啪综合成人亚洲小说| 一本一本大道香蕉久在线精品| 欧美视频中文一区二区三区在线观看 | 亚洲精品乱码久久久久久久久| 亚洲成av人影院| av在线综合网| 久久噜噜亚洲综合| 亚洲成人av电影在线| 福利电影一区二区| 欧美一级欧美三级在线观看| 亚洲欧美日韩电影| 国产精品911| 日韩网站在线看片你懂的| 亚洲男人都懂的| 岛国精品在线观看| 久久综合久久综合久久| 亚洲va欧美va天堂v国产综合| 菠萝蜜视频在线观看一区| 欧美一区二区三区色| 亚洲一线二线三线久久久| 成人91在线观看| xfplay精品久久| 美女在线一区二区| 正在播放亚洲一区| 亚洲国产精品一区二区久久恐怖片| 国产乱子轮精品视频| 日韩欧美中文一区二区| 亚洲一区二区三区四区不卡| 91色.com| 亚洲色欲色欲www| 91视频一区二区| 亚洲素人一区二区| av影院午夜一区| 国产精品国模大尺度视频| 国产成人精品一区二区三区四区| 久久久无码精品亚洲日韩按摩| 蜜臀久久99精品久久久画质超高清| 欧美剧在线免费观看网站| 午夜伊人狠狠久久| 欧美人xxxx| 美女一区二区久久| 日韩欧美你懂的| 国产一区免费电影| 欧美韩国一区二区| 99在线精品一区二区三区| 中文字幕一区二区不卡| 91亚洲国产成人精品一区二三| 1024精品合集| 欧美性猛交xxxx黑人交| 亚洲成人动漫在线观看| 欧美一区日韩一区| 极品尤物av久久免费看| 国产午夜精品在线观看| 波多野结衣视频一区| 亚洲日本一区二区| 欧美日韩五月天| 久久成人免费电影| 国产精品美女久久福利网站| 色综合网站在线| 日日摸夜夜添夜夜添精品视频 | 欧洲色大大久久| 日韩专区在线视频| 中文字幕av不卡| 色欧美乱欧美15图片| 视频在线观看91| 久久日韩粉嫩一区二区三区| 91啪亚洲精品| 免费看黄色91| 国产精品视频线看| 欧美一区二区成人6969| 成人丝袜18视频在线观看| 亚洲精品大片www| 欧美精品一区二区在线播放| av一区二区三区在线| 麻豆91在线播放免费| 国产精品成人一区二区三区夜夜夜 | 欧美在线999| 国产精品伊人色| 天堂在线亚洲视频| 国产精品久久久久国产精品日日| 欧美日韩高清在线播放| 国产精品一级在线| 日日摸夜夜添夜夜添国产精品| 国产精品久久久久久妇女6080| 91精品国产综合久久久久久 | 制服丝袜在线91| 99精品久久99久久久久| 韩国av一区二区三区在线观看| 亚洲国产日韩精品| 中文字幕亚洲综合久久菠萝蜜| 日韩三级.com| 制服.丝袜.亚洲.另类.中文| 91精品1区2区| 不卡在线观看av| 国产91精品久久久久久久网曝门| 午夜在线成人av| 亚洲韩国一区二区三区| 日韩一区欧美小说| 欧美激情一区二区三区| 久久亚洲一区二区三区明星换脸| 69堂成人精品免费视频| 欧美亚洲一区二区三区四区| 99视频在线精品| 成年人网站91| proumb性欧美在线观看| 国产精品18久久久久| 国产美女主播视频一区| 久草热8精品视频在线观看| 老色鬼精品视频在线观看播放| 亚洲午夜一二三区视频| 亚洲一区视频在线| 一区二区三区波多野结衣在线观看| 成人欧美一区二区三区白人| ㊣最新国产の精品bt伙计久久| 中文字幕+乱码+中文字幕一区| 国产日韩av一区二区| 亚洲国产精品成人久久综合一区| 国产日韩欧美精品综合| 中文字幕乱码久久午夜不卡| 亚洲国产精品高清| 国产精品国产a| 亚洲美女区一区| 亚洲18女电影在线观看| 香港成人在线视频| 久久99精品久久久| 国产成人综合网| 一本大道久久a久久精二百| 一本一道波多野结衣一区二区| 色94色欧美sute亚洲线路一久| 欧美在线一区二区| 日韩三级视频在线看| 久久丝袜美腿综合| 综合久久国产九一剧情麻豆| 亚洲女女做受ⅹxx高潮| 五月天视频一区| 国产在线看一区| 91丨九色丨蝌蚪富婆spa| 欧美日韩免费高清一区色橹橹 | 国产+成+人+亚洲欧洲自线| 91美女蜜桃在线| 91精品国产一区二区人妖| 国产午夜久久久久| 亚洲电影在线播放| 国产伦精一区二区三区| 99re这里只有精品首页| 欧美日韩国产大片| 欧美精品一区二区三区一线天视频| 欧美群妇大交群的观看方式| 91精品国产综合久久香蕉麻豆| 精品欧美一区二区在线观看| 中文字幕中文在线不卡住| 视频在线在亚洲| jiyouzz国产精品久久| 欧美肥妇bbw| 国产精品网站在线播放| 亚洲va在线va天堂| 99久久夜色精品国产网站| 日韩欧美精品在线视频| 亚洲韩国一区二区三区| 成人禁用看黄a在线| 日韩欧美国产成人一区二区|