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

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

?? videodevx.c

?? sumsung s3c2440下的camera(OV7620)驅動程序源代碼
?? C
?? 第 1 頁 / 共 4 頁
字號:
/* *	Video for Linux Two * *	A generic video device interface for the LINUX operating system *	using a set of device structures/vectors for low level operations. * *	This file replaces the videodev.c file that comes with the *	regular kernel distribution. * *	This program is free software; you can redistribute it and/or *	modify it under the terms of the GNU General Public License *	as published by the Free Software Foundation; either version *	2 of the License, or (at your option) any later version. * * Author:	Bill Dirks <bdirks@pacbell.net> *		based on code by Alan Cox, <alan@cymru.net> * *//* * Video capture interface for Linux * *	A generic video device interface for the LINUX operating system *	using a set of device structures/vectors for low level operations. * *		This program is free software; you can redistribute it and/or *		modify it under the terms of the GNU General Public License *		as published by the Free Software Foundation; either version *		2 of the License, or (at your option) any later version. * * Author:	Alan Cox, <alan@redhat.com> * * Fixes: *//* * Video4linux 1/2 integration by Justin Schoeman * <justin@suntiger.ee.up.ac.za> * 2.4 PROCFS support ported from 2.4 kernels by  *  I馻ki Garc韆 Etxebarria <garetxe@euskalnet.net> * Makefile fix by "W. Michael Petullo" <mike@flyn.org> * 2.4 devfs support ported from 2.4 kernels by *  Dan Merillat <dan@merillat.org> * Added Gerd Knorrs v4l1 enhancements (Justin Schoeman) */#ifndef __KERNEL__#define __KERNEL__#endif#include <linux/config.h>#ifndef EXPORT_SYMTAB#define EXPORT_SYMTAB#endif#include <linux/version.h>#include <linux/module.h>#include <linux/types.h>#include <linux/kernel.h>#include <linux/sched.h>#include <linux/smp_lock.h>#include <linux/mm.h>#include <linux/string.h>#include <linux/errno.h>#include <asm/div64.h>#include "videodev.h"#if LINUX_VERSION_CODE >= 0x020100#include <asm/uaccess.h>#endif#include <asm/system.h>#include <asm/pgtable.h>#include <asm/io.h>#ifdef CONFIG_KMOD#include <linux/kmod.h>#endif#include <linux/proc_fs.h>#if defined(CONFIG_UST) || defined(CONFIG_UST_MODULE)#include <linux/ust.h>#endif#ifdef MODULE_LICENSEMODULE_LICENSE("GPL");#endif#define V4L2_NUM_DEVICES	256 static int v4l2_major		= 81;MODULE_PARM(v4l2_major, "i");#define VIDEO_NUM_DEVICES	256 /* *	Active devices  */static struct v4l2_device *v4l2_device[V4L2_NUM_DEVICES];static struct file_operations v4l2_fops; static struct video_device *video_device[VIDEO_NUM_DEVICES];static struct file_operations video_fops;#ifndef MODULE#ifdef CONFIG_VIDEO_BWQCAMextern int init_bw_qcams(struct video_init *);#endif#ifdef CONFIG_VIDEO_CPIAextern int cpia_init(struct video_init *);#endif#ifdef CONFIG_VIDEO_PLANBextern int init_planbs(struct video_init *);#endif#ifdef CONFIG_VIDEO_ZORANextern int init_zoran_cards(struct video_init *);#endif#if LINUX_VERSION_CODE < 0x020400#ifdef CONFIG_VIDEO_BT848extern int init_bttv_cards(struct video_init *);extern int i2c_tuner_init(struct video_init *);#endif#ifdef CONFIG_VIDEO_SAA5249extern int init_saa_5249(struct video_init *);#endif	#ifdef CONFIG_VIDEO_CQCAMextern int init_colour_qcams(struct video_init *);#endif#ifdef CONFIG_RADIO_AZTECHextern int aztech_init(struct video_init *);#endif#ifdef CONFIG_RADIO_RTRACKextern int rtrack_init(struct video_init *);#endif#ifdef CONFIG_RADIO_RTRACK2extern int rtrack2_init(struct video_init *);#endif#ifdef CONFIG_RADIO_SF16FMIextern int fmi_init(struct video_init *);#endif#ifdef CONFIG_RADIO_MIROPCM20extern int pcm20_init(struct video_init *);#endif#ifdef CONFIG_RADIO_GEMTEKextern int gemtek_init(struct video_init *);#endif#ifdef CONFIG_RADIO_TYPHOONextern int typhoon_init(struct video_init *);#endif#ifdef CONFIG_RADIO_CADETextern int cadet_init(struct video_init *);#endif#ifdef CONFIG_RADIO_TRUSTextern int trust_init(struct video_init *);#endif#ifdef CONFIG_VIDEO_PMSextern int init_pms_cards(struct video_init *);#endif#endif /* not 2.4.x */#endif /* compiled into kernel (not module) */static struct video_init video_init_list[]={#ifndef MODULE#ifdef CONFIG_VIDEO_BWQCAM	{"bw-qcam", init_bw_qcams},#endif        #ifdef CONFIG_VIDEO_CPIA        {"cpia", cpia_init},#endif	#ifdef CONFIG_VIDEO_PLANB	{"planb", init_planbs},#endif#ifdef CONFIG_VIDEO_ZORAN	{"zoran", init_zoran_cards},#endif	#if LINUX_VERSION_CODE < 0x020400#ifdef CONFIG_VIDEO_BT848	{"i2c-tuner", i2c_tuner_init},	{"bttv", init_bttv_cards},#endif	#ifdef CONFIG_VIDEO_SAA5249	{"saa5249", init_saa_5249},#endif	#ifdef CONFIG_VIDEO_CQCAM	{"c-qcam", init_colour_qcams},#endif	#ifdef CONFIG_VIDEO_PMS	{"PMS", init_pms_cards}, #endif	#ifdef CONFIG_RADIO_AZTECH	{"Aztech", aztech_init}, #endif	#ifdef CONFIG_RADIO_RTRACK	{"RTrack", rtrack_init}, #endif #ifdef CONFIG_RADIO_RTRACK2	{"RTrack2", rtrack2_init}, #endif#ifdef CONFIG_RADIO_SF16FMI	{"SF16FMI", fmi_init}, #endif	#ifdef CONFIG_RADIO_MIROPCM20	{"PCM20", pcm20_init}, #endif#ifdef CONFIG_RADIO_CADET	{"Cadet", cadet_init},#endif#ifdef CONFIG_RADIO_GEMTEK	{"GemTek", gemtek_init},#endif#ifdef CONFIG_RADIO_TYPHOON	{"radio-typhoon", typhoon_init},#endif#ifdef CONFIG_RADIO_TRUST	{"Trust", trust_init}, #endif	#endif /* not 2.4.x */#endif /* compiled into kernel (not module) */	{"end", NULL}};#if LINUX_VERSION_CODE >= 0x020100/* *	Read will do some smarts later on. Buffer pin etc. */ inline ssize_t video_read(struct file *file,	char *buf, size_t count, loff_t *ppos){	struct video_device *vfl=video_device[MINOR(file->f_dentry->d_inode->i_rdev)];#if LINUX_VERSION_CODE >= 0x020300	if (vfl->fops) {		if (vfl->fops->read)			return vfl->fops->read(file,buf,count,ppos);		else			return -EINVAL;	}#endif	if(vfl->read)		return vfl->read(vfl, buf, count, file->f_flags&O_NONBLOCK);	else		return -EINVAL;}/* *	Write for now does nothing. No reason it shouldnt do overlay setting *	for some boards I guess.. */inline ssize_t video_write(struct file *file, const char *buf, 	size_t count, loff_t *ppos){	struct video_device *vfl=video_device[MINOR(file->f_dentry->d_inode->i_rdev)];#if LINUX_VERSION_CODE >= 0x020300	if (vfl->fops) {		if (vfl->fops->write)			return vfl->fops->write(file,buf,count,ppos);		else			return 0;	}#endif	if(vfl->write)		return vfl->write(vfl, buf, count, file->f_flags&O_NONBLOCK);	else		return 0;}/* *	Poll to see if we're readable, can probably be used for timing on incoming *  frames, etc.. */inline unsigned int video_poll(struct file *file, poll_table * wait){	struct video_device *vfl=video_device[MINOR(file->f_dentry->d_inode->i_rdev)];#if LINUX_VERSION_CODE >= 0x020300	if (vfl->fops) {		if (vfl->fops->poll)			return vfl->fops->poll(file,wait);		else			return 0;	}#endif	if(vfl->poll)		return vfl->poll(vfl, file, wait);	else		return 0;}#else#warning This version of videodevX does not fully support pre 2.2.x kernelsinline int video_read(struct inode *ino,struct file *file,			  char *buf, int count){         int err;	 struct video_device *vfl=video_device[MINOR(ino->i_rdev)];	 if (vfl->read)	   return vfl->read(vfl, buf, count, file->f_flags&O_NONBLOCK);	 else	   return -EINVAL;}inline int video_write(struct inode *ino,struct file *file, const char *buf, 			int count){	int err;	struct video_device *vfl=video_device[MINOR(ino->i_rdev)];	if (vfl->write)	  return vfl->write(vfl, buf, count, file->f_flags&O_NONBLOCK);	else	  return 0;}#endif/* *	Open a video device. */inline int video_open(struct inode *inode, struct file *file){	unsigned int minor = MINOR(inode->i_rdev);	int err, retval = 0;	struct video_device *vfl;		if(minor>=VIDEO_NUM_DEVICES)		return -ENODEV;	lock_kernel();	vfl=video_device[minor];	if(vfl==NULL) {		retval = -ENODEV;		goto error_out;	}#if LINUX_VERSION_CODE >= 0x020300	if (vfl->fops) {		unlock_kernel();		if (vfl->fops->open)			return vfl->fops->open(inode,file);		else			return 0;	}#endif	if(vfl->busy) {		retval = -EBUSY;		goto error_out;	}	vfl->busy=1;		/* In case vfl->open sleeps */#if LINUX_VERSION_CODE >= 0x020403	if (vfl->owner)		__MOD_INC_USE_COUNT(vfl->owner);#endif	unlock_kernel();		if(vfl->open)	{		err=vfl->open(vfl,0);	/* Tell the device it is open */		if(err)		{			vfl->busy=0;#if LINUX_VERSION_CODE >= 0x020403			if (vfl->owner)				__MOD_DEC_USE_COUNT(vfl->owner);#endif			return err;		}	}	return 0;error_out:	unlock_kernel();	return retval;}/* *	Last close of a video for Linux device */	inline int video_release(struct inode *inode, struct file *file){	struct video_device *vfl;	lock_kernel();	vfl=video_device[MINOR(inode->i_rdev)];#if LINUX_VERSION_CODE >= 0x020300	if (vfl->fops) {		unlock_kernel();		if (vfl->fops->release)			return vfl->fops->release(inode,file);		else			return 0;	}#endif	if(vfl->close)		vfl->close(vfl);	vfl->busy=0;#if LINUX_VERSION_CODE >= 0x020403	if (vfl->owner)		__MOD_DEC_USE_COUNT(vfl->owner);#endif	unlock_kernel();	return 0;}inline int video_ioctl(struct inode *inode, struct file *file,	unsigned int cmd, unsigned long arg){	struct video_device *vfl=video_device[MINOR(inode->i_rdev)];	int err;#if LINUX_VERSION_CODE >= 0x020300	if (vfl->fops) {		if (vfl->fops->ioctl)			return vfl->fops->ioctl(inode,file,cmd,arg);		else			return -EINVAL;	}#endif	err=vfl->ioctl(vfl, cmd, (void *)arg);	if(err!=-ENOIOCTLCMD)		return err;		switch(cmd)	{		default:			return -EINVAL;	}}/* *	We need to do MMAP support */  #if LINUX_VERSION_CODE >= 0x020100inline int video_mmap(struct file *file, struct vm_area_struct *vma){	int ret = -EINVAL;	struct video_device *vfl=video_device[MINOR(file->f_dentry->d_inode->i_rdev)];#if LINUX_VERSION_CODE >= 0x020300	if (vfl->fops) {		if (vfl->fops->mmap)			return vfl->fops->mmap(file,vma);		else			return -EINVAL;	}#endif /* 2.3.x and up */#else /* pre 2.1.x */inline int video_mmap(struct inode * ino, struct file * file,		      struct vm_area_struct * vma){	int ret = -EINVAL;	struct video_device *vfl=video_device[MINOR(ino->i_rdev)];#endif	if(vfl->mmap) {		lock_kernel();		ret = vfl->mmap(vfl, (char *)vma->vm_start, 				(unsigned long)(vma->vm_end-vma->vm_start));		unlock_kernel();	}	return ret;}#if (LINUX_VERSION_CODE >= 0x020300) && defined(CONFIG_PROC_FS) static void videodev_proc_create_dev (struct video_device *vfd, char *name); static void videodev_proc_destroy_dev (struct video_device *vfd); static void v4l2_proc_create_dev (struct v4l2_device *vfd, char *name); static void v4l2_proc_destroy_dev (struct v4l2_device *vfd);#endif /* *	Video For Linux device drivers request registration here. */ #if LINUX_VERSION_CODE >= 0x020405int video_register_device(struct video_device *vfd, int type, int nr)#elseint video_register_device(struct video_device *vfd, int type)#endif{	int i=0;	int base;	int err;	int end;	char *name_base;		switch(type)	{		case VFL_TYPE_GRABBER:			base=0;			end=64;			name_base = "video";			break;		case VFL_TYPE_VTX:			base=192;			end=224;			name_base = "vtx";			break;		case VFL_TYPE_VBI:			base=224;			end=240;			name_base = "vbi";			break;		case VFL_TYPE_RADIO:			base=64;			end=128;			name_base = "radio";			break;		default:			return -1;	}		for(i=base;i<end;i++)	{		if((video_device[i]==NULL)&&(v4l2_device[i]==NULL))		{#if (defined(CONFIG_PROC_FS) && (LINUX_VERSION_CODE >= 0x020300)) \     || defined(CONFIG_DEVFS_FS)			char name[16];#endif			video_device[i]=vfd;			vfd->minor=i;			/* The init call may sleep so we book the slot out			   then call */			MOD_INC_USE_COUNT;			if(vfd->initialize)			{				err=vfd->initialize(vfd);				if(err<0)				{					video_device[i]=NULL;					MOD_DEC_USE_COUNT;					return err;				}			}#ifdef CONFIG_DEVFS_FS			sprintf (name, "v4l/%s%d", name_base, i - base);			/*			 * Start the device root only.  Anything else

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人av综合在线| 欧美日韩国产综合一区二区| 欧美日韩国产一级| 亚洲激情欧美激情| 亚洲欧美福利一区二区| 亚洲综合999| 国产精品自拍毛片| 欧美亚洲综合另类| 日韩欧美一区二区在线视频| 国产aⅴ综合色| 成人免费视频免费观看| 欧美精品 日韩| 国产亚洲欧美一区在线观看| 亚洲人精品午夜| 欧美亚洲一区二区在线| 麻豆精品精品国产自在97香蕉| 国产精品亚洲专一区二区三区| 中文字幕乱码一区二区免费| 久久激情五月婷婷| 国产成人av一区二区三区在线观看| 欧美精品1区2区3区| 精彩视频一区二区三区| 91麻豆精品国产91久久久久久 | 国产精品18久久久久久久久| 国产午夜精品美女毛片视频| 97精品超碰一区二区三区| 日韩一区和二区| 丁香五精品蜜臀久久久久99网站| 亚洲三级在线免费| 成人精品一区二区三区中文字幕| 一级女性全黄久久生活片免费| av中文字幕在线不卡| 久久婷婷综合激情| 久久疯狂做爰流白浆xx| 综合久久给合久久狠狠狠97色| 欧美乱熟臀69xxxxxx| 成人在线视频一区二区| 亚洲成人激情综合网| 在线亚洲免费视频| 一区二区欧美在线观看| 亚洲精品一区二区三区福利| 国产一区二区三区香蕉| 国产三级三级三级精品8ⅰ区| 欧美天堂亚洲电影院在线播放| 国产精选一区二区三区| 日日夜夜免费精品视频| 欧美一级理论片| 色播五月激情综合网| 亚洲高清视频中文字幕| 欧美精品v日韩精品v韩国精品v| 国产suv精品一区二区883| 日韩成人dvd| 久久综合999| 91麻豆精品国产91| 在线观看网站黄不卡| 丰满亚洲少妇av| 国产一区二区三区在线观看精品| 婷婷亚洲久悠悠色悠在线播放 | 首页亚洲欧美制服丝腿| 国产精品大尺度| 91久久香蕉国产日韩欧美9色| 国产一区二区免费看| 天使萌一区二区三区免费观看| 亚洲日本青草视频在线怡红院| 久久男人中文字幕资源站| 91影院在线免费观看| 亚洲人妖av一区二区| 日本一区二区视频在线| 日本乱码高清不卡字幕| 99在线热播精品免费| 国产成+人+日韩+欧美+亚洲| 国产麻豆午夜三级精品| 美国三级日本三级久久99| 日韩av一区二区在线影视| 亚洲五月六月丁香激情| 一区二区三区四区高清精品免费观看| 国产精品久久久久婷婷| 最新不卡av在线| 亚洲视频免费观看| 亚洲精品免费在线观看| 亚洲精品高清在线观看| 亚洲综合在线观看视频| 亚洲成人免费影院| 奇米精品一区二区三区四区 | 亚洲免费视频中文字幕| 中文字幕乱码日本亚洲一区二区| 中文字幕精品一区二区三区精品| 国产精品视频麻豆| 欧美videossexotv100| 一本色道亚洲精品aⅴ| 首页国产丝袜综合| 六月丁香综合在线视频| 国产精品中文欧美| 波多野结衣视频一区| 色系网站成人免费| 欧美日韩国产色站一区二区三区| 欧美老肥妇做.爰bbww| 日韩女优制服丝袜电影| 亚洲国产高清aⅴ视频| 亚洲免费观看在线视频| 午夜一区二区三区在线观看| 麻豆精品在线视频| 国产91在线看| 欧美日韩精品综合在线| 精品久久国产老人久久综合| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲另类在线制服丝袜| 狂野欧美性猛交blacked| 国产高清亚洲一区| 欧美无砖专区一中文字| 精品粉嫩aⅴ一区二区三区四区| 国产精品午夜免费| 婷婷综合五月天| 成人午夜又粗又硬又大| 在线观看av一区二区| 久久免费视频色| 亚洲综合一区二区三区| 国产在线播精品第三| 欧美性生活大片视频| 久久人人97超碰com| 亚洲综合成人在线| 国产丶欧美丶日本不卡视频| 91成人国产精品| 国产色爱av资源综合区| 婷婷久久综合九色国产成人 | 日本欧美在线观看| 成人h动漫精品一区二区| 欧美精品黑人性xxxx| 欧美激情在线一区二区三区| 五月天国产精品| 91蜜桃婷婷狠狠久久综合9色| 欧美一级欧美三级| 日韩一区二区三区在线| 亚洲欧洲成人精品av97| 日韩一区欧美小说| 麻豆精品蜜桃视频网站| 在线免费亚洲电影| 国产农村妇女精品| 蜜臀久久99精品久久久久久9| kk眼镜猥琐国模调教系列一区二区| 日韩午夜精品电影| 亚洲成人av电影| 91影院在线免费观看| 亚洲国产精品v| 激情综合网av| 欧美videossexotv100| 午夜电影网亚洲视频| 在线看国产一区二区| 国产精品盗摄一区二区三区| 国产精品99久久久久久久女警| 欧美精品一二三| 亚洲福利一区二区| 91国产成人在线| 亚洲欧美精品午睡沙发| 高清视频一区二区| 久久精品亚洲麻豆av一区二区| 久久精品久久99精品久久| 欧美日韩国产三级| 丝袜美腿高跟呻吟高潮一区| 欧美日精品一区视频| www精品美女久久久tv| 青青草91视频| 日韩一卡二卡三卡四卡| 日本aⅴ亚洲精品中文乱码| 欧美卡1卡2卡| 蜜桃视频免费观看一区| 91精品黄色片免费大全| 日本欧美加勒比视频| 欧美一区二区三区四区五区| 偷窥少妇高潮呻吟av久久免费 | 欧美一区二区三区在线观看| 日韩精品一二三四| 欧美一级片免费看| 黑人巨大精品欧美一区| 欧美三级在线播放| 丝袜a∨在线一区二区三区不卡| 欧美剧在线免费观看网站 | 在线免费观看日本一区| 亚洲一区二区三区在线播放| 在线亚洲一区观看| 视频一区二区中文字幕| 欧美一区二区三区视频| 久久国产三级精品| 国产欧美综合在线| 91小视频免费观看| 亚洲国产美女搞黄色| 日韩你懂的在线观看| 久久99精品国产麻豆婷婷洗澡| 久久女同互慰一区二区三区| 99视频热这里只有精品免费| 一区二区三国产精华液| 日韩视频永久免费| 国产精品一区二区在线看| 亚洲免费电影在线| 欧美一区二区三区免费观看视频| 国产精品一区专区| 亚洲第一久久影院| 日韩久久免费av| 色综合欧美在线视频区| 另类小说视频一区二区|