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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? i2c-core.c

?? linux下S3C2410的I2C總線的驅(qū)動
?? C
?? 第 1 頁 / 共 3 頁
字號:
			break;	if (I2C_CLIENT_MAX == i) {		printk(KERN_WARNING " i2c-core.o: unregister_client "				    "[%s] not found\n",			client->name);		return -ENODEV;	}		if( (client->flags & I2C_CLIENT_ALLOW_USE) && 	    (client->usage_count>0))		return -EBUSY;		if (adapter->client_unregister != NULL) 		if ((res = adapter->client_unregister(client))) {			printk("i2c-core.o: client_unregister [%s] failed, "			       "client not detached",client->name);			return res;		}	adapter->clients[i] = NULL;	adapter->client_count--;	DEB(printk("i2c-core.o: client [%s] unregistered.\n",client->name));	return 0;}void i2c_inc_use_client(struct i2c_client *client){	if (client->driver->inc_use != NULL)		client->driver->inc_use(client);	if (client->adapter->inc_use != NULL)		client->adapter->inc_use(client->adapter);}void i2c_dec_use_client(struct i2c_client *client){		if (client->driver->dec_use != NULL)		client->driver->dec_use(client);	if (client->adapter->dec_use != NULL)		client->adapter->dec_use(client->adapter);}struct i2c_client *i2c_get_client(int driver_id, int adapter_id, 					struct i2c_client *prev){	int i,j;		/* Will iterate through the list of clients in each adapter of adapters-list	   in search for a client that matches the search criteria. driver_id or 	   adapter_id are ignored if set to 0. If both are ignored this returns 	   first client found. */		i = j = 0;  		/* set starting point */ 	if(prev)	{		if(!(prev->adapter))			return (struct i2c_client *) -EINVAL;				for(j=0; j < I2C_ADAP_MAX; j++)			if(prev->adapter == adapters[j])				break;				/* invalid starting point? */		if (I2C_ADAP_MAX == j) {			printk(KERN_WARNING " i2c-core.o: get_client adapter for client:[%s] not found\n",				prev->name);			return (struct i2c_client *) -ENODEV;		}					for(i=0; i < I2C_CLIENT_MAX; i++)			if(prev == adapters[j]->clients[i])				break;				/* invalid starting point? */		if (I2C_CLIENT_MAX == i) {			printk(KERN_WARNING " i2c-core.o: get_client client:[%s] not found\n",				prev->name);			return (struct i2c_client *) -ENODEV;		}					i++; /* start from one after prev */	}		for(; j < I2C_ADAP_MAX; j++)	{		if(!adapters[j])			continue;					if(adapter_id && (adapters[j]->id != adapter_id))			continue;				for(; i < I2C_CLIENT_MAX; i++)		{			if(!adapters[j]->clients[i])				continue;							if(driver_id && (adapters[j]->clients[i]->driver->id != driver_id))				continue;			if(adapters[j]->clients[i]->flags & I2C_CLIENT_ALLOW_USE)					return adapters[j]->clients[i];		}		i = 0;	}	return 0;}int i2c_use_client(struct i2c_client *client){	if(client->flags & I2C_CLIENT_ALLOW_USE) {		if (client->flags & I2C_CLIENT_ALLOW_MULTIPLE_USE) 			client->usage_count++;		else {			if(client->usage_count > 0) 				return -EBUSY;			 else 				client->usage_count++;		}	}	i2c_inc_use_client(client);	return 0;}int i2c_release_client(struct i2c_client *client){	if(client->flags & I2C_CLIENT_ALLOW_USE) {		if(client->usage_count>0)			client->usage_count--;		else		{			printk(KERN_WARNING " i2c-core.o: dec_use_client used one too many times\n");			return -EPERM;		}	}		i2c_dec_use_client(client);		return 0;}/* ---------------------------------------------------- * The /proc functions * ---------------------------------------------------- */#ifdef CONFIG_PROC_FS#if (LINUX_VERSION_CODE <= KERNEL_VERSION(2,3,27))/* Monitor access to /proc/bus/i2c*; make unloading i2c-proc impossible   if some process still uses it or some file in it */void monitor_bus_i2c(struct inode *inode, int fill){	if (fill)		MOD_INC_USE_COUNT;	else		MOD_DEC_USE_COUNT;}#endif /* (LINUX_VERSION_CODE <= KERNEL_VERSION(2,3,37)) *//* This function generates the output for /proc/bus/i2c */int read_bus_i2c(char *buf, char **start, off_t offset, int len, int *eof,                  void *private){	int i;	int nr = 0;	/* Note that it is safe to write a `little' beyond len. Yes, really. */	for (i = 0; (i < I2C_ADAP_MAX) && (nr < len); i++)		if (adapters[i]) {			nr += sprintf(buf+nr, "i2c-%d\t", i);			if (adapters[i]->algo->smbus_xfer) {				if (adapters[i]->algo->master_xfer)					nr += sprintf(buf+nr,"smbus/i2c");				else					nr += sprintf(buf+nr,"smbus    ");			} else if (adapters[i]->algo->master_xfer)				nr += sprintf(buf+nr,"i2c       ");			else				nr += sprintf(buf+nr,"dummy     ");			nr += sprintf(buf+nr,"\t%-32s\t%-32s\n",			              adapters[i]->name,			              adapters[i]->algo->name);		}	return nr;}/* This function generates the output for /proc/bus/i2c-? */ssize_t i2cproc_bus_read(struct file * file, char * buf,size_t count,                          loff_t *ppos){	struct inode * inode = file->f_dentry->d_inode;	char *kbuf;	struct i2c_client *client;	int i,j,k,order_nr,len=0,len_total;	int order[I2C_CLIENT_MAX];	if (count > 4000)		return -EINVAL; 	len_total = file->f_pos + count;	/* Too bad if this gets longer (unlikely) */	if (len_total > 4000)		len_total = 4000;	for (i = 0; i < I2C_ADAP_MAX; i++)		if (adapters[i]->inode == inode->i_ino) {		/* We need a bit of slack in the kernel buffer; this makes the		   sprintf safe. */			if (! (kbuf = kmalloc(count + 80,GFP_KERNEL)))				return -ENOMEM;			/* Order will hold the indexes of the clients			   sorted by address */			order_nr=0;			for (j = 0; j < I2C_CLIENT_MAX; j++) {				if ((client = adapters[i]->clients[j]) && 				    (client->driver->id != I2C_DRIVERID_I2CDEV))  {					for(k = order_nr; 					    (k > 0) && 					    adapters[i]->clients[order[k-1]]->					             addr > client->addr; 					    k--)						order[k] = order[k-1];					order[k] = j;					order_nr++;				}			}			for (j = 0; (j < order_nr) && (len < len_total); j++) {				client = adapters[i]->clients[order[j]];				len += sprintf(kbuf+len,"%02x\t%-32s\t%-32s\n",				              client->addr,				              client->name,				              client->driver->name);			}			len = len - file->f_pos;			if (len > count)				len = count;			if (len < 0) 				len = 0;			if (copy_to_user (buf,kbuf+file->f_pos, len)) {				kfree(kbuf);				return -EFAULT;			}			file->f_pos += len;			kfree(kbuf);			return len;		}	return -ENOENT;}int i2cproc_init(void){	struct proc_dir_entry *proc_bus_i2c;	i2cproc_initialized = 0;	if (! proc_bus) {		printk("i2c-core.o: /proc/bus/ does not exist");		i2cproc_cleanup();		return -ENOENT; 	} 	proc_bus_i2c = create_proc_entry("i2c",0,proc_bus);	if (!proc_bus_i2c) {		printk("i2c-core.o: Could not create /proc/bus/i2c");		i2cproc_cleanup();		return -ENOENT; 	}	proc_bus_i2c->read_proc = &read_bus_i2c;#if (LINUX_VERSION_CODE >= KERNEL_VERSION(2,3,27))	proc_bus_i2c->owner = THIS_MODULE;#else	proc_bus_i2c->fill_inode = &monitor_bus_i2c;#endif /* (LINUX_VERSION_CODE >= KERNEL_VERSION(2,3,27)) */	i2cproc_initialized += 2;	return 0;}static void i2cproc_cleanup(void){	if (i2cproc_initialized >= 1) {		remove_proc_entry("i2c",proc_bus);		i2cproc_initialized -= 2;	}}#endif /* def CONFIG_PROC_FS *//* ---------------------------------------------------- * the functional interface to the i2c busses. * ---------------------------------------------------- */int i2c_transfer(struct i2c_adapter * adap, struct i2c_msg msgs[],int num){	int ret;	if (adap->algo->master_xfer) { 	 	DEB2(printk("i2c-core.o: master_xfer: %s with %d msgs.\n",		            adap->name,num));		I2C_LOCK(adap);		ret = adap->algo->master_xfer(adap,msgs,num);		I2C_UNLOCK(adap);		return ret;	} else {		printk("i2c-core.o: I2C adapter %04x: I2C level transfers not supported\n",		       adap->id);		return -ENOSYS;	}}int i2c_master_send(struct i2c_client *client,const char *buf ,int count){	int ret;	struct i2c_adapter *adap=client->adapter;	struct i2c_msg msg;	if (client->adapter->algo->master_xfer) {		msg.addr   = client->addr;		msg.flags = client->flags & I2C_M_TEN;		msg.len = count;		(const char *)msg.buf = buf;			DEB2(printk("i2c-core.o: master_send: writing %d bytes on %s.\n",			count,client->adapter->name));			I2C_LOCK(adap);		ret = adap->algo->master_xfer(adap,&msg,1);		I2C_UNLOCK(adap);		/* if everything went ok (i.e. 1 msg transmitted), return #bytes		 * transmitted, else error code.		 */		return (ret == 1 )? count : ret;	} else {		printk("i2c-core.o: I2C adapter %04x: I2C level transfers not supported\n",		       client->adapter->id);		return -ENOSYS;	}}int i2c_master_recv(struct i2c_client *client, char *buf ,int count){	struct i2c_adapter *adap=client->adapter;	struct i2c_msg msg;	int ret;	if (client->adapter->algo->master_xfer) {		msg.addr   = client->addr;		msg.flags = client->flags & I2C_M_TEN;		msg.flags |= I2C_M_RD;		msg.len = count;		msg.buf = buf;		DEB2(printk("i2c-core.o: master_recv: reading %d bytes on %s.\n",			count,client->adapter->name));			I2C_LOCK(adap);		ret = adap->algo->master_xfer(adap,&msg,1);		I2C_UNLOCK(adap);			DEB2(printk("i2c-core.o: master_recv: return:%d (count:%d, addr:0x%02x)\n",			ret, count, client->addr));			/* if everything went ok (i.e. 1 msg transmitted), return #bytes	 	* transmitted, else error code.	 	*/		return (ret == 1 )? count : ret;	} else {		printk("i2c-core.o: I2C adapter %04x: I2C level transfers not supported\n",		       client->adapter->id);		return -ENOSYS;	}}//for iic slave receive//by threewaterint i2c_slave_recv(struct i2c_client *client, unsigned short *buf ,int maxcount){	struct i2c_adapter *adap=client->adapter;	int ret;	if (client->adapter->algo->slave_recv) {		DEB2(printk("i2c-core.o: slave_recv: reading %d maxbytes on %s.\n",			maxcount,client->adapter->name));			I2C_LOCK(adap);		ret = adap->algo->slave_recv(adap,buf,maxcount);		I2C_UNLOCK(adap);			DEB2(printk("i2c-core.o: slave_recv: return:%d (count:%d)\n",			ret, maxcount));			/* if everything went ok (i.e. 1 msg transmitted), return #bytes	 	* transmitted, else error code.	 	*/		return ret;	} else {		printk("i2c-core.o: I2C adapter %04x: I2C level transfers not supported\n",		       client->adapter->id);		return -ENOSYS;	}}int i2c_control(struct i2c_client *client,	unsigned int cmd, unsigned long arg){	int ret = 0;	struct i2c_adapter *adap = client->adapter;	DEB2(printk("i2c-core.o: i2c ioctl, cmd: 0x%x, arg: %#lx\n", cmd, arg));	switch ( cmd ) {		case I2C_RETRIES:			adap->retries = arg;			break;		case I2C_TIMEOUT:			adap->timeout = arg;			break;		//add by threewater		case I2C_SET_OWNADDR:			if(!adap->algo->set_ownaddress)				return -EINVAL;			adap->algo->set_ownaddress(adap, arg);			break;		case I2C_GET_OWNADDR:		{			unsigned long ownaddress=adap->algo->get_ownaddress(adap);			if(!adap->algo->get_ownaddress)				return -EINVAL;			if (copy_to_user( (unsigned long*)arg, 				&(ownaddress), sizeof(ownaddress)) ) 				return -EFAULT;			return 0;		}		default:			if (adap->algo->algo_control!=NULL)				ret = adap->algo->algo_control(adap,cmd,arg);	}	return ret;}/* ---------------------------------------------------- * the i2c address scanning function * Will not work for 10-bit addresses!

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久国产人妖系列| 国产毛片精品视频| 国产农村妇女精品| 欧美撒尿777hd撒尿| 国产成人免费在线视频| 日韩国产成人精品| 亚洲精品中文在线影院| 国产视频一区在线观看| 日韩亚洲电影在线| 色悠久久久久综合欧美99| 久久99精品久久久| 亚洲va欧美va国产va天堂影院| 精品99一区二区三区| 欧美日韩在线播放一区| 波多野结衣精品在线| 国内不卡的二区三区中文字幕 | 亚洲欧美一区二区在线观看| 欧美成人r级一区二区三区| 欧美日韩一区国产| 91看片淫黄大片一级| 国产美女视频91| 麻豆成人久久精品二区三区小说| 亚洲成a人在线观看| 一区二区在线看| 亚洲欧美日韩国产综合在线| 国产欧美精品一区二区色综合| 日韩欧美成人一区| 日韩一区二区免费视频| 欧美日韩一区高清| 欧美另类变人与禽xxxxx| 91高清视频在线| 色婷婷久久综合| 91丝袜美腿高跟国产极品老师 | 欧美日韩一区 二区 三区 久久精品| 成人av网址在线| 成人深夜视频在线观看| 国产精品影视网| 国产成人av网站| 国产宾馆实践打屁股91| 国产99久久久国产精品潘金 | 不卡的av中国片| aaa国产一区| 91丨porny丨首页| 色美美综合视频| 在线观看亚洲精品| 欧美日韩免费高清一区色橹橹 | 在线观看免费亚洲| 91麻豆文化传媒在线观看| 99久久精品免费观看| 91麻豆免费在线观看| 91成人免费电影| 欧美精品日韩精品| 欧美mv和日韩mv的网站| 久久久久久电影| 亚洲国产精品激情在线观看| 18成人在线视频| 夜夜嗨av一区二区三区| 一区二区三区日韩欧美精品| 午夜精品在线视频一区| 奇米色一区二区三区四区| 国产美女娇喘av呻吟久久| 波多野结衣在线一区| 在线观看网站黄不卡| 宅男噜噜噜66一区二区66| 精品999在线播放| 中文字幕不卡的av| 一区av在线播放| 久久99精品国产麻豆婷婷洗澡| 成人免费看的视频| 91网站在线观看视频| 在线观看亚洲精品视频| 日韩精品资源二区在线| 中文字幕乱码日本亚洲一区二区| 亚洲精品亚洲人成人网| 奇米亚洲午夜久久精品| 成人精品视频一区二区三区| 欧美揉bbbbb揉bbbbb| 26uuu国产电影一区二区| 亚洲欧洲日韩一区二区三区| 亚洲成精国产精品女| 国产乱码精品1区2区3区| 欧美中文一区二区三区| 精品成人一区二区三区四区| 亚洲精品免费电影| 国产一区二区三区精品视频| 色噜噜偷拍精品综合在线| 欧美成人高清电影在线| 亚洲综合免费观看高清完整版 | 亚洲国产欧美在线人成| 国产精品系列在线观看| 欧美色网站导航| 2022国产精品视频| 亚洲一区二区三区在线看| 国产精品影视在线观看| 欧美裸体一区二区三区| 欧美xingq一区二区| 亚洲欧美色图小说| 国产资源在线一区| 在线播放视频一区| 亚洲日本一区二区三区| 国产主播一区二区三区| 在线成人av影院| 亚洲视频一区在线| 国产精品99久久久久久宅男| 91农村精品一区二区在线| 欧美大片免费久久精品三p| 亚洲精品国产一区二区三区四区在线 | 欧美日本韩国一区二区三区视频| 亚洲国产激情av| 久久国产精品72免费观看| 在线视频观看一区| 国产精品毛片a∨一区二区三区| 日韩**一区毛片| 91国偷自产一区二区三区成为亚洲经典 | 一区二区不卡在线播放| 成人激情开心网| 久久先锋影音av鲁色资源| 麻豆精品视频在线观看免费| 欧美日韩在线播放| 一区二区成人在线视频| 99久久99久久免费精品蜜臀| 国产精品天干天干在线综合| 国产精品一区二区三区99| 欧美一区二区三区在线观看视频| 亚洲国产精品视频| 91行情网站电视在线观看高清版| 亚洲日本免费电影| 91老司机福利 在线| 国产精品人成在线观看免费| 国产99久久久久久免费看农村| 26uuu国产电影一区二区| 国产一区二区三区免费| 2021久久国产精品不只是精品| 麻豆精品在线观看| 日韩一级精品视频在线观看| 日韩中文字幕一区二区三区| 欧美日韩国产一级二级| 午夜视频久久久久久| 欧美日韩视频一区二区| 丝袜美腿亚洲一区| 91精品国产91久久综合桃花 | 亚洲一区二区偷拍精品| 欧美三级乱人伦电影| 日韩av二区在线播放| 欧美一区二区三区公司| 久草热8精品视频在线观看| 精品国产一区二区三区忘忧草| 狠狠色丁香久久婷婷综合_中| 国产亚洲欧美日韩俺去了| 成人免费看片app下载| 亚洲女人的天堂| 欧美美女网站色| 国产一区二区视频在线播放| 国产精品午夜在线| 色婷婷综合久久久| 日韩精品五月天| 亚洲国产成人午夜在线一区 | 精品国产免费人成电影在线观看四季 | 91国产成人在线| 日韩经典中文字幕一区| 2023国产精品| 99热精品一区二区| 亚洲成国产人片在线观看| 日韩一区二区精品| 粉嫩一区二区三区性色av| **网站欧美大片在线观看| 欧美日韩精品欧美日韩精品一 | 亚洲色图视频免费播放| 欧美性猛交xxxxxx富婆| 久久精品久久综合| 国产精品国产三级国产aⅴ原创 | 欧美哺乳videos| 9l国产精品久久久久麻豆| 亚洲成人一区在线| 久久久久久久久久久久电影 | 成人中文字幕合集| 亚洲国产一区二区视频| 精品国产乱码91久久久久久网站| 成人性生交大片| 天堂av在线一区| 国产女主播一区| 日韩一区二区精品| 91色婷婷久久久久合中文| 蜜臀av一区二区在线观看| 国产精品久久久久久久久免费丝袜 | 成人激情小说乱人伦| 中文字幕中文字幕一区| 欧美一区二区三区免费观看视频| 三级成人在线视频| 欧美国产日韩在线观看| 欧美乱熟臀69xxxxxx| 懂色av一区二区三区免费观看| 午夜激情一区二区| 欧美经典一区二区三区| 欧美一级黄色录像| 91福利视频网站| 成人av网站在线观看免费| 精品一区二区三区在线播放| 亚洲一区二区欧美日韩| 国产精品久久久久一区二区三区共|