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

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

?? i2c-dev.c

?? linux 內核源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*    i2c-dev.c - i2c-bus driver, char device interface    Copyright (C) 1995-97 Simon G. Vogl    Copyright (C) 1998-99 Frodo Looijaard <frodol@dds.nl>    Copyright (C) 2003 Greg Kroah-Hartman <greg@kroah.com>    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.    This program is distributed in the hope that it will be useful,    but WITHOUT ANY WARRANTY; without even the implied warranty of    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the    GNU General Public License for more details.    You should have received a copy of the GNU General Public License    along with this program; if not, write to the Free Software    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.*//* Note that this is a complete rewrite of Simon Vogl's i2c-dev module.   But I have used so much of his original code and ideas that it seems   only fair to recognize him as co-author -- Frodo *//* The I2C_RDWR ioctl code is written by Kolja Waschk <waschk@telos.de> */#include <linux/kernel.h>#include <linux/module.h>#include <linux/fs.h>#include <linux/slab.h>#include <linux/init.h>#include <linux/list.h>#include <linux/i2c.h>#include <linux/i2c-dev.h>#include <asm/uaccess.h>static struct i2c_driver i2cdev_driver;/* * An i2c_dev represents an i2c_adapter ... an I2C or SMBus master, not a * slave (i2c_client) with which messages will be exchanged.  It's coupled * with a character special file which is accessed by user mode drivers. * * The list of i2c_dev structures is parallel to the i2c_adapter lists * maintained by the driver model, and is updated using notifications * delivered to the i2cdev_driver. */struct i2c_dev {	struct list_head list;	struct i2c_adapter *adap;	struct device *dev;};#define I2C_MINORS	256static LIST_HEAD(i2c_dev_list);static DEFINE_SPINLOCK(i2c_dev_list_lock);static struct i2c_dev *i2c_dev_get_by_minor(unsigned index){	struct i2c_dev *i2c_dev;	spin_lock(&i2c_dev_list_lock);	list_for_each_entry(i2c_dev, &i2c_dev_list, list) {		if (i2c_dev->adap->nr == index)			goto found;	}	i2c_dev = NULL;found:	spin_unlock(&i2c_dev_list_lock);	return i2c_dev;}static struct i2c_dev *get_free_i2c_dev(struct i2c_adapter *adap){	struct i2c_dev *i2c_dev;	if (adap->nr >= I2C_MINORS) {		printk(KERN_ERR "i2c-dev: Out of device minors (%d)\n",		       adap->nr);		return ERR_PTR(-ENODEV);	}	i2c_dev = kzalloc(sizeof(*i2c_dev), GFP_KERNEL);	if (!i2c_dev)		return ERR_PTR(-ENOMEM);	i2c_dev->adap = adap;	spin_lock(&i2c_dev_list_lock);	list_add_tail(&i2c_dev->list, &i2c_dev_list);	spin_unlock(&i2c_dev_list_lock);	return i2c_dev;}static void return_i2c_dev(struct i2c_dev *i2c_dev){	spin_lock(&i2c_dev_list_lock);	list_del(&i2c_dev->list);	spin_unlock(&i2c_dev_list_lock);	kfree(i2c_dev);}static ssize_t show_adapter_name(struct device *dev,				 struct device_attribute *attr, char *buf){	struct i2c_dev *i2c_dev = i2c_dev_get_by_minor(MINOR(dev->devt));	if (!i2c_dev)		return -ENODEV;	return sprintf(buf, "%s\n", i2c_dev->adap->name);}static DEVICE_ATTR(name, S_IRUGO, show_adapter_name, NULL);/* ------------------------------------------------------------------------- *//* * After opening an instance of this character special file, a file * descriptor starts out associated only with an i2c_adapter (and bus). * * Using the I2C_RDWR ioctl(), you can then *immediately* issue i2c_msg * traffic to any devices on the bus used by that adapter.  That's because * the i2c_msg vectors embed all the addressing information they need, and * are submitted directly to an i2c_adapter.  However, SMBus-only adapters * don't support that interface. * * To use read()/write() system calls on that file descriptor, or to use * SMBus interfaces (and work with SMBus-only hosts!), you must first issue * an I2C_SLAVE (or I2C_SLAVE_FORCE) ioctl.  That configures an anonymous * (never registered) i2c_client so it holds the addressing information * needed by those system calls and by this SMBus interface. */static ssize_t i2cdev_read (struct file *file, char __user *buf, size_t count,                            loff_t *offset){	char *tmp;	int ret;	struct i2c_client *client = (struct i2c_client *)file->private_data;	if (count > 8192)		count = 8192;	tmp = kmalloc(count,GFP_KERNEL);	if (tmp==NULL)		return -ENOMEM;	pr_debug("i2c-dev: i2c-%d reading %zd bytes.\n",		iminor(file->f_path.dentry->d_inode), count);	ret = i2c_master_recv(client,tmp,count);	if (ret >= 0)		ret = copy_to_user(buf,tmp,count)?-EFAULT:ret;	kfree(tmp);	return ret;}static ssize_t i2cdev_write (struct file *file, const char __user *buf, size_t count,                             loff_t *offset){	int ret;	char *tmp;	struct i2c_client *client = (struct i2c_client *)file->private_data;	if (count > 8192)		count = 8192;	tmp = kmalloc(count,GFP_KERNEL);	if (tmp==NULL)		return -ENOMEM;	if (copy_from_user(tmp,buf,count)) {		kfree(tmp);		return -EFAULT;	}	pr_debug("i2c-dev: i2c-%d writing %zd bytes.\n",		iminor(file->f_path.dentry->d_inode), count);	ret = i2c_master_send(client,tmp,count);	kfree(tmp);	return ret;}/* This address checking function differs from the one in i2c-core   in that it considers an address with a registered device, but no   bound driver, as NOT busy. */static int i2cdev_check_addr(struct i2c_adapter *adapter, unsigned int addr){	struct list_head *item;	struct i2c_client *client;	int res = 0;	mutex_lock(&adapter->clist_lock);	list_for_each(item, &adapter->clients) {		client = list_entry(item, struct i2c_client, list);		if (client->addr == addr) {			if (client->driver)				res = -EBUSY;			break;		}	}	mutex_unlock(&adapter->clist_lock);	return res;}static int i2cdev_ioctl(struct inode *inode, struct file *file,		unsigned int cmd, unsigned long arg){	struct i2c_client *client = (struct i2c_client *)file->private_data;	struct i2c_rdwr_ioctl_data rdwr_arg;	struct i2c_smbus_ioctl_data data_arg;	union i2c_smbus_data temp;	struct i2c_msg *rdwr_pa;	u8 __user **data_ptrs;	int i,datasize,res;	unsigned long funcs;	dev_dbg(&client->adapter->dev, "ioctl, cmd=0x%02x, arg=0x%02lx\n",		cmd, arg);	switch ( cmd ) {	case I2C_SLAVE:	case I2C_SLAVE_FORCE:		/* NOTE:  devices set up to work with "new style" drivers		 * can't use I2C_SLAVE, even when the device node is not		 * bound to a driver.  Only I2C_SLAVE_FORCE will work.		 *		 * Setting the PEC flag here won't affect kernel drivers,		 * which will be using the i2c_client node registered with		 * the driver model core.  Likewise, when that client has		 * the PEC flag already set, the i2c-dev driver won't see		 * (or use) this setting.		 */		if ((arg > 0x3ff) ||		    (((client->flags & I2C_M_TEN) == 0) && arg > 0x7f))			return -EINVAL;		if (cmd == I2C_SLAVE && i2cdev_check_addr(client->adapter, arg))			return -EBUSY;		/* REVISIT: address could become busy later */		client->addr = arg;		return 0;	case I2C_TENBIT:		if (arg)			client->flags |= I2C_M_TEN;		else			client->flags &= ~I2C_M_TEN;		return 0;	case I2C_PEC:		if (arg)			client->flags |= I2C_CLIENT_PEC;		else			client->flags &= ~I2C_CLIENT_PEC;		return 0;	case I2C_FUNCS:		funcs = i2c_get_functionality(client->adapter);		return put_user(funcs, (unsigned long __user *)arg);	case I2C_RDWR:		if (copy_from_user(&rdwr_arg,				   (struct i2c_rdwr_ioctl_data __user *)arg,				   sizeof(rdwr_arg)))			return -EFAULT;		/* Put an arbitrary limit on the number of messages that can		 * be sent at once */		if (rdwr_arg.nmsgs > I2C_RDRW_IOCTL_MAX_MSGS)			return -EINVAL;		rdwr_pa = (struct i2c_msg *)			kmalloc(rdwr_arg.nmsgs * sizeof(struct i2c_msg),			GFP_KERNEL);		if (rdwr_pa == NULL) return -ENOMEM;		if (copy_from_user(rdwr_pa, rdwr_arg.msgs,				   rdwr_arg.nmsgs * sizeof(struct i2c_msg))) {			kfree(rdwr_pa);			return -EFAULT;		}		data_ptrs = kmalloc(rdwr_arg.nmsgs * sizeof(u8 __user *), GFP_KERNEL);		if (data_ptrs == NULL) {			kfree(rdwr_pa);			return -ENOMEM;		}		res = 0;		for( i=0; i<rdwr_arg.nmsgs; i++ ) {			/* Limit the size of the message to a sane amount;			 * and don't let length change either. */			if ((rdwr_pa[i].len > 8192) ||			    (rdwr_pa[i].flags & I2C_M_RECV_LEN)) {				res = -EINVAL;				break;			}			data_ptrs[i] = (u8 __user *)rdwr_pa[i].buf;			rdwr_pa[i].buf = kmalloc(rdwr_pa[i].len, GFP_KERNEL);			if(rdwr_pa[i].buf == NULL) {				res = -ENOMEM;				break;			}			if(copy_from_user(rdwr_pa[i].buf,				data_ptrs[i],				rdwr_pa[i].len)) {					++i; /* Needs to be kfreed too */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
2021中文字幕一区亚洲| 国产精品麻豆欧美日韩ww| 2023国产精华国产精品| 一区二区成人在线| 国产成人午夜片在线观看高清观看| 成人性生交大片免费看视频在线| 欧美精品自拍偷拍| 日韩理论片中文av| 国产电影一区二区三区| 欧美一区二区二区| 亚洲成人免费电影| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 日韩理论电影院| 国产精品一区二区久久不卡| 欧美精品精品一区| 亚洲午夜久久久久久久久久久| 国产成人精品免费| 久久综合99re88久久爱| 久久精品国产亚洲5555| 欧美一区三区二区| 欧美aⅴ一区二区三区视频| 欧美性色欧美a在线播放| 国产精品久久久久影院亚瑟| 国产乱色国产精品免费视频| 日韩欧美中文一区| 婷婷综合五月天| 91超碰这里只有精品国产| 亚洲线精品一区二区三区| 色婷婷久久综合| 亚洲免费视频中文字幕| 色综合天天视频在线观看 | 精品嫩草影院久久| 六月丁香婷婷久久| 精品入口麻豆88视频| 久久99国产乱子伦精品免费| 日韩欧美视频在线 | 午夜精彩视频在线观看不卡| 在线观看国产91| 亚洲成av人片在线观看| 制服丝袜在线91| 紧缚捆绑精品一区二区| 久久嫩草精品久久久久| 成人黄色在线视频| 亚洲精品国产视频| 欧美精选在线播放| 久久国产三级精品| 中文一区二区在线观看 | 国产aⅴ综合色| 欧美国产日韩在线观看| 91原创在线视频| 香蕉久久一区二区不卡无毒影院| 91精选在线观看| 精品一区二区三区在线视频| 国产日韩欧美不卡| 欧美在线不卡视频| 老司机精品视频线观看86| 中文一区一区三区高中清不卡| 色噜噜狠狠成人网p站| 日本中文字幕一区| 中文字幕av资源一区| 欧美亚洲丝袜传媒另类| 黑人巨大精品欧美一区| 最新成人av在线| 777久久久精品| 国产91精品露脸国语对白| 亚洲精品国产无天堂网2021| 日韩视频不卡中文| 成人高清视频在线| 日本欧美一区二区| 欧美韩国一区二区| 欧美一区二区黄| 91精彩视频在线| 国产在线精品视频| 亚瑟在线精品视频| 欧美国产欧美综合| 91精品国产高清一区二区三区蜜臀| 国产成人精品免费网站| 日本人妖一区二区| 最新国产成人在线观看| 久久午夜色播影院免费高清| 欧美视频精品在线| www.66久久| 激情五月婷婷综合| 亚洲国产精品久久不卡毛片| 欧美韩日一区二区三区| 日韩欧美中文字幕制服| 在线观看国产日韩| 99久久婷婷国产综合精品电影| 精品一区二区三区在线观看国产| 一区二区三区小说| 国产精品久久久久影院| 欧美精品一区二区蜜臀亚洲| 欧美综合亚洲图片综合区| 国产河南妇女毛片精品久久久| 日本不卡免费在线视频| 亚洲一区二区视频在线观看| 亚洲欧洲精品一区二区精品久久久| 日韩一区二区三区免费看| 欧美视频一区在线| 欧美在线不卡一区| 91福利社在线观看| 色狠狠色狠狠综合| 色噜噜久久综合| 色综合色狠狠天天综合色| 成年人国产精品| 成人精品视频一区二区三区 | 国产精品嫩草久久久久| 欧美国产一区视频在线观看| 精品国产1区2区3区| 精品国产乱码久久久久久牛牛| 日韩视频在线你懂得| 精品久久久久香蕉网| 日韩精品在线看片z| 日韩欧美国产一区在线观看| 91麻豆精品国产91久久久资源速度| 欧美视频完全免费看| 欧美精品粉嫩高潮一区二区| 欧美精品黑人性xxxx| 日韩免费电影一区| 精品剧情在线观看| 国产亚洲欧美日韩日本| 亚洲国产成人午夜在线一区| 久久久精品人体av艺术| 国产日产精品1区| 国产精品激情偷乱一区二区∴| 中文字幕一区二区视频| 一区二区在线观看免费视频播放| 国产精品不卡在线| 一区二区三区久久久| 日本色综合中文字幕| 国产精品综合一区二区三区| 成人黄色免费短视频| 欧美性猛交xxxx黑人交| 欧美一区二区三区喷汁尤物| www国产亚洲精品久久麻豆| 中文字幕国产精品一区二区| 亚洲色图清纯唯美| 亚洲大片免费看| 久久 天天综合| 国产成人精品影院| 欧美中文字幕不卡| 日韩欧美在线网站| 中文字幕一区二区三区在线观看| 亚洲国产一区二区三区| 激情综合一区二区三区| av爱爱亚洲一区| 欧美日韩国产综合草草| 久久久精品黄色| 亚洲精品久久久蜜桃| 久久99日本精品| 99久久99精品久久久久久| 91精品在线一区二区| 国产精品国产a级| 日韩av在线播放中文字幕| 成人午夜在线免费| 91精品国产aⅴ一区二区| 中文子幕无线码一区tr| 麻豆精品在线观看| 91视频.com| 久久婷婷国产综合精品青草 | 久久精品国产秦先生| 99久久精品国产观看| 欧美成人欧美edvon| 一区二区三区四区视频精品免费 | 久久九九99视频| 亚洲成人自拍网| 成人a级免费电影| 日韩精品一区二区三区中文不卡 | 精品亚洲porn| 精品免费国产二区三区| 亚洲美女免费视频| 亚洲国产精品成人综合色在线婷婷 | 精品中文字幕一区二区小辣椒 | 亚洲综合激情网| 成人免费毛片片v| 欧美精品一区二区不卡| 亚洲一区在线电影| 成人综合婷婷国产精品久久蜜臀| 欧美一区二区在线看| 亚洲国产一二三| 9色porny自拍视频一区二区| 国产亚洲欧洲997久久综合| 男男视频亚洲欧美| 欧美日韩精品久久久| 有坂深雪av一区二区精品| 成人禁用看黄a在线| 国产日韩亚洲欧美综合| 黄色日韩网站视频| 日韩午夜精品电影| 日韩高清在线不卡| 欧美久久久久免费| 午夜日韩在线观看| 欧美无砖砖区免费| 色综合激情久久| 亚洲国产成人av| 亚洲6080在线| 欧美日韩另类国产亚洲欧美一级| 一区二区三区在线观看动漫 | 欧美精品少妇一区二区三区| 亚洲一级二级三级在线免费观看|