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

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

?? s3c2440a_camif.c

?? sumsung s3c2440下的camera(OV7620)驅動程序源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
		spin_lock_irqsave(&dev->lock, flags);	rCIPRSCCTRL &= ~(1<<15);	//stop preview scaler.	rCICOSCCTRL &= ~(1<<15);	//stop codec scaler.	rCIIMGCPT   &= ~(7<<29);	//stop capturing for preview and codec scaler.	dev->open_count--;	spin_unlock_irqrestore(&dev->lock, flags);		camera_power(0);	DPRINTK("close(): dev->opencount = %d\n", dev->open_count);	MOD_DEC_USE_COUNT;}static int v4l_cam_ioctl(struct video_device *v, unsigned int cmd, void *arg){	int retval = 0;	struct s3c2440_camif *dev = (struct s3c2440_camif *)(v->priv);	switch (cmd) {/* V4L Standard IOCTL. */	case VIDIOCGCAP:	{		struct video_capability vc;		strcpy (vc.name, "S3C2440A Camera");		vc.maxwidth = CAMIF_MAX_W;		vc.maxheight = CAMIF_MAX_H;		vc.minwidth = CAMIF_MIN_W; 		vc.minheight = CAMIF_MIN_H;		if (copy_to_user((int __user*)arg, &vc, sizeof(struct video_capability)))			return -EFAULT;		break;	}	/* get capture size */	case VIDIOCGWIN:	{		struct video_window vw;		vw.width = s3c2440_camif_cfg.src_x;		vw.height = s3c2440_camif_cfg.src_y;		if (copy_to_user((int __user*)arg, &vw, sizeof(struct video_window)))			retval = -EFAULT;		break;	}	/* set capture size. */	case VIDIOCSWIN:	{		struct video_window vw;		if (copy_from_user(&vw, (int __user*)arg, sizeof(struct video_window))) {			retval = -EFAULT;			break;		}		if (vw.width > CAMIF_MAX_W || vw.height > CAMIF_MAX_H 			|| vw.width < CAMIF_MIN_W || vw.height < CAMIF_MIN_H) {			retval = -EINVAL;			break;		}		if(down_interruptible(&dev->change))			return -ERESTARTSYS;		if(dev->flag&1)			retval = -EBUSY;		else if(s3c2440_camif_cfg.src_x!=vw.width||				s3c2440_camif_cfg.src_y!=vw.height) {			dev->set_chg = 1;			s3c2440_camif_cfg.src_x = vw.width;			s3c2440_camif_cfg.src_y = vw.height;		}		up(&dev->change);		break;	}	/* get subcapture */	case VIDIOCGCAPTURE:	{		struct video_capture vc;		vc.x = vc.y = 0;		vc.width  = s3c2440_camif_cfg.dst_x;		vc.height = s3c2440_camif_cfg.dst_y;		if (copy_to_user((int __user*)arg, &vc, sizeof(struct video_capture)))			retval = -EFAULT;		break;	}	/* set subcapture */	case VIDIOCSCAPTURE:	{		struct video_capture vc;		if (copy_from_user(&vc, (int __user*)arg, sizeof(struct video_capture))) {			retval = -EFAULT;			break;		}		if(down_interruptible(&dev->change))			return -ERESTARTSYS;		if(dev->flag&1)			retval = -EBUSY;		else if(vc.width > s3c2440_camif_cfg.src_x ||				vc.height > s3c2440_camif_cfg.src_y	|| 				vc.width < CAMIF_MIN_W ||				vc.height < CAMIF_MIN_H)			retval = -EINVAL;		else if(vc.width!=s3c2440_camif_cfg.dst_x ||				vc.height!=s3c2440_camif_cfg.dst_y) {			dev->set_chg = 1;			s3c2440_camif_cfg.dst_x = vc.width;			s3c2440_camif_cfg.dst_y = vc.height;		}		up(&dev->change);		break;	}	/* get palette */	case VIDIOCGPICT:	{		struct video_picture vp;		switch (dev->mode) {		case 0:			vp.palette = VIDEO_PALETTE_RGB565;			break;		case 1:			vp.palette = VIDEO_PALETTE_RGB24;			break;		case 2:			vp.palette = VIDEO_PALETTE_YUV420P;			break;		case 3:			vp.palette = VIDEO_PALETTE_YUV422P;			break;		default:			retval = -EINVAL;			break;		}		if (copy_to_user((int __user*)arg, &vp, sizeof(struct video_picture)))			retval = -EFAULT;		break;	}	/* set palette */	case VIDIOCSPICT:	{		struct video_picture vp;		if (copy_from_user(&vp, (int __user*)arg, sizeof(vp))) {			retval = -EFAULT;			break;		}		if(down_interruptible(&dev->change))			return -ERESTARTSYS;		if(dev->flag&1)			retval = -EBUSY;		else {			int mode = dev->mode;						if(vp.palette==VIDEO_PALETTE_RGB565)				mode = 0;			else if(vp.palette==VIDEO_PALETTE_RGB24)				mode = 1;			else if(vp.palette==VIDEO_PALETTE_YUV420P)				mode = 2;			else if(vp.palette==VIDEO_PALETTE_YUV422P)				mode = 3;			else				retval = -EINVAL;						if(mode!=dev->mode) {				dev->set_chg = 1;				dev->mode = mode;			}		}		up(&dev->change);		break;	}	/* set YCbCr order */	case VIDIOCSYCbCr:	{		if(down_interruptible(&dev->change))			return -ERESTARTSYS;		if(dev->flag&1)			retval = -EBUSY;		else if(s3c2440_camif_cfg.ycbcr!=((int)arg&3)) {			dev->set_chg = 1;			s3c2440_camif_cfg.ycbcr = (int)arg&3;		}		up(&dev->change);		break;	}	/* start/stop capture */	case VIDIOCCAPTURE:	{		int capture_flag = (int)arg;				if(down_interruptible(&dev->change))			return -ERESTARTSYS;		/* Still Image Capture */		if (capture_flag == STILL_IMAGE) {			if(dev->flag&1)				retval = -EBUSY;			else				dev->flag = 1;	// one frame capture;		}		/* Video Capture Start */		else if (capture_flag == VIDEO_START) {			if(dev->flag&1)				retval = -EBUSY;			else				dev->flag = 3;	// sequential capture;		}		/* Video Capture Stop */		else if (capture_flag == VIDEO_STOP) {			if(dev->flag&1) {				init_completion(&dev->stop);				dev->flag |= 0x100;				wait_for_completion(&dev->stop);	// complete with flag = 0			} else				retval = -ESRCH;		}		else			retval = -EFAULT;		up(&dev->change);				if(!retval&&dev->flag) {			dev->rdy  = 0;			if(dev->set_chg) {	//now flag.0 is 1				dev->set_chg = 0;				dev->size = 0;				s3c2440_camif_configure(&s3c2440_camif_cfg);			}			//enable_irq();			start_capture(dev);			#if DEBUG				printk(KERN_DEBUG "<0x%08x\n", rCISRCFMT);				printk(KERN_DEBUG "0x%08x\n", rCIWDOFST);				printk(KERN_DEBUG "0x%08x\n", rCIGCTRL);				printk(KERN_DEBUG "0x%08x\n", rCICOYSA1);				printk(KERN_DEBUG "0x%08x\n", rCICOCBSA1);				printk(KERN_DEBUG "0x%08x\n", rCICOCRSA1);				printk(KERN_DEBUG "0x%08x\n", rCICOTRGFMT);				printk(KERN_DEBUG "0x%08x\n", rCICOCTRL);				printk(KERN_DEBUG "0x%08x\n", rCICOSCPRERATIO);				printk(KERN_DEBUG "0x%08x\n", rCICOSCCTRL);				printk(KERN_DEBUG "0x%08x\n", rCICOTAREA);				printk(KERN_DEBUG "0x%08x\n", rCICOSTATUS);				printk(KERN_DEBUG "0x%08x>\n", rCIIMGCPT);				printk(KERN_DEBUG "<0x%08x\n", rCIPRCLRSA1);				printk(KERN_DEBUG "0x%08x\n", rCIPRTRGFMT);				printk(KERN_DEBUG "0x%08x\n", rCIPRCTRL);				printk(KERN_DEBUG "0x%08x\n", rCIPRSCPRERATIO);				printk(KERN_DEBUG "0x%08x\n", rCIPRSCPREDST);				printk(KERN_DEBUG "0x%08x\n", rCIPRSCCTRL);				printk(KERN_DEBUG "0x%08x\n", rCIPRTAREA);				printk(KERN_DEBUG "0x%08x>\n", rCIPRSTATUS);			//	printk(KERN_DEBUG "<0x%08x\n", INTMSK);			//	printk(KERN_DEBUG "0x%08x>\n", INTSUBMSK);			#endif		}					break;	}	/* mmap interface */	case VIDIOCGMBUF:	{		struct video_mbuf vm;		int i;		memset(&vm, 0, sizeof(vm));		vm.size = YUV_IMG_BUF_SIZE;		vm.frames = 1;			//just support 1 frame		for (i = 0; i < vm.frames; i++)			vm.offsets[i] = 0;	//start at 0		if (copy_to_user((int __user*)arg, (void *)&vm, sizeof(vm)))			retval = -EFAULT;		break;	}	default:		retval = -ENOIOCTLCMD;	}	return retval;}static long v4l_cam_read(struct video_device *v, char *buf, unsigned long count, int noblock){	unsigned long flags;	int retval = 0;	struct s3c2440_camif *dev = (struct s3c2440_camif *)(v->priv);	if(noblock) {		if(down_trylock(&dev->change))			return -EAGAIN;	} else {		if(down_interruptible(&dev->change))			return -EINTR;	}	local_irq_save(flags);	if(!dev->rdy) {		if(noblock)			retval = -EAGAIN;		else {			interruptible_sleep_on(&dev->wait);			if(!dev->rdy)				retval = -EINTR;		}	}	local_irq_restore(flags);	if(!retval) {		//now if retval==0, dev->rdy must be 1		dev->rdy = 0;	//clear ready flag		retval = min(count, dev->size);		if(copy_to_user(buf, (void *)camif_yuv_buf, retval))	//can copy 0 byte			retval = -EFAULT;		//printk("%d,%d\n", count, dev->size);	}		up(&dev->change);	return retval;}static int v4l_cam_mmap(struct video_device *v, const char *adr, unsigned long size){	//printk("camera mmap address 0x%08x, length %d\n", (int)adr, (int)size);	//size = (size  + PAGE_SIZE-1) & ~(PAGE_SIZE-1);	if(remap_page_range((unsigned long)adr, (unsigned long)camif_yuv_buf_dma, size, PAGE_SHARED))		return -EFAULT;	return 0;}#if 0 // needlessstatic long v4l_cam_write(struct video_device *v, const char *buf, unsigned long count, int noblock){	return -EPERM;}#endifstatic unsigned int v4l_cam_poll(struct video_device *v, struct file *file, poll_table *table){	unsigned long flags, rdy;	struct s3c2440_camif *dev = (struct s3c2440_camif *)(v->priv);	local_irq_save(flags);	if(!dev->rdy)		poll_wait(file, &dev->wait, table);	rdy = dev->rdy;	local_irq_restore(flags);	return rdy?(POLLIN | POLLRDNORM) : 0;}static int v4l_cam_initdone (struct video_device *v){	return 0;}void inline config_camif_v4l(void){	DPRINTK("%s():\n", __FUNCTION__);	sprintf(camif.v.name,"%s","S3C2440_CAMIF");	camif.v.priv     = (void*)&camif;	camif.v.type     = VID_TYPE_CAPTURE | VID_TYPE_SCALES;	camif.v.hardware = VID_HARDWARE_S3C2440A;	camif.v.open     = v4l_cam_open;	camif.v.close    = v4l_cam_close;	camif.v.read     = v4l_cam_read;	camif.v.ioctl    = v4l_cam_ioctl;	camif.v.poll     = v4l_cam_poll;	camif.v.mmap     = v4l_cam_mmap;#if 0 // needless	camif.v.write    = v4l_cam_write;#endif	camif.v.initialize = v4l_cam_initdone;	//used in video_register_device}int __init s3c2440_camif_initialize(void){	int ret = 0;	DPRINTK("%s():\n", __FUNCTION__);	s3c2440_camif_init();	spin_lock_init(&camif.lock);	init_MUTEX(&camif.change);	init_completion(&camif.stop);	init_waitqueue_head(&camif.wait);	camif_yuv_buf = 			consistent_alloc(GFP_KERNEL, YUV_IMG_BUF_SIZE, &camif_yuv_buf_dma);#ifdef	RGB_YUV_MUTEX	camif_rgb_buf = camif_yuv_buf;	camif_rgb_buf_dma = camif_yuv_buf_dma;#else	camif_rgb_buf = 			consistent_alloc(GFP_KERNEL, RGB_IMG_BUF_SIZE, &camif_rgb_buf_dma);#endif	if (!camif_yuv_buf || !camif_rgb_buf ) {		ret = -ENOMEM;		goto mem_err;	}	memset(camif_yuv_buf, 0, YUV_IMG_BUF_SIZE);	memset(camif_rgb_buf, 0, RGB_IMG_BUF_SIZE);	if ((ret = request_irq(IRQ_CAM_C, s3c2440_camif_isr_c, SA_INTERRUPT,			"CAM_C", &camif))) {		printk("request_irq(CAM_C) failed.\n");		goto err_irq_s;	}	if ((ret = request_irq(IRQ_CAM_P, s3c2440_camif_isr_p, SA_INTERRUPT,			"CAM_P", &camif))) {		free_irq(IRQ_CAM_C, &camif);		printk("request_irq(CAM_P) failed.\n");		goto err_irq_s;	}	config_camif_v4l();		ret = video_register_device (&camif.v, VFL_TYPE_GRABBER, -1); 	if (ret != 0) {		printk("V4L registering failed!\n");		goto error_v4l_register;	}#ifdef MODULE	/* CPU : FIXME */	flush_scheduled_tasks();#endif	return 0;error_v4l_register:	free_irq(IRQ_CAM_P, &camif);	free_irq(IRQ_CAM_C, &camif);err_irq_s:	s3c2440_camif_deinit();mem_err:	if (camif_yuv_buf)		consistent_free(camif_yuv_buf, YUV_IMG_BUF_SIZE , camif_yuv_buf_dma);#ifndef	RGB_YUV_MUTEX	if (camif_rgb_buf)		consistent_free(camif_rgb_buf, RGB_IMG_BUF_SIZE , camif_rgb_buf_dma);#endif	return ret;}void __exit s3c2440_camif_exit(void){	DPRINTK("%s():\n", __FUNCTION__);	video_unregister_device(&camif.v);		s3c2440_camif_deinit();	free_irq(IRQ_CAM_P, &camif);	free_irq(IRQ_CAM_C, &camif);	if (camif_yuv_buf)		consistent_free(camif_yuv_buf, YUV_IMG_BUF_SIZE , camif_yuv_buf_dma);#ifndef	RGB_YUV_MUTEX	if (camif_rgb_buf)		consistent_free(camif_rgb_buf, RGB_IMG_BUF_SIZE , camif_rgb_buf_dma);#endif}module_exit(s3c2440_camif_exit);module_init(s3c2440_camif_initialize);MODULE_LICENSE("GPL");#ifdef MODULEMODULE_PARM(power_lvl, "h");MODULE_PARM(reset_lvl, "h");#elsestatic int __init pwr_lvl_setup(char *str){	if(simple_strtol(str, NULL, 0))		power_lvl = 1;	printk(KERN_DEBUG "Camera power level is %s\n", power_lvl?"high":"low");	return 0;}static int __init rst_lvl_setup(char *str){	if(simple_strtol(str, NULL, 0))		reset_lvl = 1;	printk(KERN_DEBUG "Camera reset level is %s\n", reset_lvl?"high":"low");	return 0;}__setup("camera_pwr=", pwr_lvl_setup);__setup("camera_rst=", rst_lvl_setup);#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产综合久久国产大片| 国产亚洲成年网址在线观看| 日韩精品一区二区在线| 欧美国产精品劲爆| 蜜臀av性久久久久蜜臀aⅴ四虎 | 日韩精品久久理论片| 国产精品18久久久久久久网站| 一本久久精品一区二区 | 欧美片网站yy| 亚洲欧美电影一区二区| 国产精品伊人色| 欧美一卡2卡3卡4卡| 亚洲免费资源在线播放| 欧美妇女性影城| 国产精品免费久久| 国产精品一区免费视频| 日韩欧美一区电影| 欧美aaaaa成人免费观看视频| 91亚洲国产成人精品一区二区三 | 欧美色倩网站大全免费| 亚洲色图制服诱惑| 99re热视频这里只精品| 国产婷婷色一区二区三区| 久久国产成人午夜av影院| 欧美老女人在线| 午夜激情一区二区三区| 欧美自拍偷拍午夜视频| 亚洲午夜av在线| 欧美人与性动xxxx| 日本不卡在线视频| 日韩欧美一区在线| 激情偷乱视频一区二区三区| 日韩免费高清视频| 国产在线国偷精品产拍免费yy| 精品久久久网站| 国产九色sp调教91| 中文字幕乱码久久午夜不卡| 国产成人亚洲综合色影视| 国产午夜亚洲精品不卡| 不卡一区二区三区四区| 国产精品色在线观看| 91麻豆免费视频| 亚洲国产一二三| 日韩欧美不卡在线观看视频| 国产精品中文字幕日韩精品 | 亚洲大片一区二区三区| 欧美日韩免费高清一区色橹橹| 日韩精品国产欧美| 欧美大片免费久久精品三p| 国产一区二区三区美女| 国产精品美女久久久久高潮| 91国产丝袜在线播放| 日产欧产美韩系列久久99| www国产成人免费观看视频 深夜成人网| 欧美日韩在线直播| 狠狠久久亚洲欧美| 亚洲日本电影在线| 欧美日韩电影在线播放| 国内一区二区在线| 亚洲免费观看高清完整版在线观看熊| 欧美视频在线一区二区三区 | 欧美国产一区在线| 91国产免费观看| 日韩在线a电影| 国产精品美女久久久久久久久久久| 欧美羞羞免费网站| 精品中文av资源站在线观看| 亚洲视频狠狠干| 精品动漫一区二区三区在线观看| 不卡在线观看av| 男男成人高潮片免费网站| 国产精品三级在线观看| 91精品国产综合久久精品图片| 国产999精品久久久久久绿帽| 亚洲一区二区三区四区五区黄| 欧美va日韩va| 欧美午夜一区二区三区| 国产不卡视频在线播放| 日韩高清在线电影| 亚洲激情综合网| 久久久久久久综合色一本| 欧美系列日韩一区| 97se亚洲国产综合在线| 国产一区二区看久久| 日韩二区三区四区| 一区二区欧美在线观看| 中文字幕国产一区| 久久久噜噜噜久久中文字幕色伊伊 | 日韩精品中文字幕一区二区三区 | 日韩中文字幕麻豆| 亚洲人一二三区| 久久综合久久99| 欧美一级爆毛片| 欧洲一区二区三区免费视频| 成人一区二区视频| 国产精品一区二区在线看| 免费人成精品欧美精品| 婷婷久久综合九色综合绿巨人| 一区二区激情小说| 一区二区三区四区av| 国产精品久久久99| 亚洲国产成人在线| 久久久精品蜜桃| 欧美精品一区二| 26uuu亚洲| 久久男人中文字幕资源站| 日韩欧美一二三四区| 欧美高清视频在线高清观看mv色露露十八 | 国产精品美女久久久久aⅴ| 久久丝袜美腿综合| 久久精品一级爱片| 国产亚洲欧美日韩日本| 中文字幕不卡一区| 国产精品电影院| 一区二区三区资源| 亚洲高清免费一级二级三级| 亚洲在线视频免费观看| 亚洲成人av电影在线| 日日夜夜精品视频免费| 蜜桃久久久久久| 国产在线不卡视频| 成人晚上爱看视频| 91黄视频在线| 91精品国产一区二区三区蜜臀| 51午夜精品国产| 精品理论电影在线观看 | 日韩一区二区在线看片| 日韩精品综合一本久道在线视频| 日韩欧美一级在线播放| 国产肉丝袜一区二区| 亚洲欧美综合色| 亚洲成人tv网| 极品少妇一区二区三区精品视频| 国产成人精品午夜视频免费| 成人黄色电影在线 | 久久婷婷综合激情| 国产精品久久久久婷婷二区次| 樱花草国产18久久久久| 免费观看在线综合| 粉嫩高潮美女一区二区三区| 色一区在线观看| 欧美一级片在线看| 国产精品久久国产精麻豆99网站| 亚洲福利一区二区三区| 毛片av中文字幕一区二区| 成人禁用看黄a在线| 欧美视频在线一区| 久久久久免费观看| 亚洲线精品一区二区三区| 久草精品在线观看| 色婷婷av一区二区三区gif | 4438x亚洲最大成人网| 26uuu精品一区二区| 一区二区三区自拍| 国模一区二区三区白浆| 欧美专区亚洲专区| 国产欧美一区二区在线| 午夜精品久久久久久久久久 | 国内成人自拍视频| 欧美制服丝袜第一页| 久久久久国产精品麻豆| 亚洲一区成人在线| 成人黄色在线视频| 精品国产百合女同互慰| 一二三四社区欧美黄| 成人av在线看| 久久综合九色欧美综合狠狠| 亚洲线精品一区二区三区八戒| 国产精品自拍一区| 日韩欧美三级在线| 香蕉久久一区二区不卡无毒影院| 丁香五精品蜜臀久久久久99网站 | 欧美成人vr18sexvr| 一区二区三区欧美久久| 成人av先锋影音| 久久综合久久综合久久| 麻豆一区二区三区| 欧美日韩免费一区二区三区| 亚洲欧美日本韩国| 成人sese在线| 久久久久久99久久久精品网站| 日韩国产欧美一区二区三区| 欧美性极品少妇| 亚洲综合久久av| 色婷婷一区二区三区四区| 中文字幕一区二区不卡| 国内精品久久久久影院薰衣草| 欧美精品乱码久久久久久| 亚洲一区二区在线免费看| 91高清视频免费看| 亚洲精品日韩一| 色婷婷综合久久久久中文 | 国产精品午夜在线| 国产精品 日产精品 欧美精品| 精品国产百合女同互慰| 精品一区二区在线观看| 精品国产乱码久久久久久免费| 蜜臀av性久久久久蜜臀aⅴ四虎| 91精品国产日韩91久久久久久| 日本欧美一区二区三区|