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

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

?? i2c-algo-biths.c

?? I2C總線LINUX驅動程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
	printk(KERN_INFO "i2c-algo-biths.o: %s bus test\n", adap->name);	while ( test[i][0]!=-1 ) {		ssda = test[i][0];		sscl = test[i][1];		adap->errors = 0;		__setsda(ssda, T_min);		gsda = __getsda() ? 1 : 0;		errors = adap->errors & (_HS_HW_FAIL | _HS_SDA_ARB);		if (errors)			printk(KERN_WARNING "i2c-algo-biths.o: %s %s\n", adap->name,			       i2c_strerr(errflag(errors)));	    		__setscl(sscl, T_min);		gscl = __getscl() ? 1 : 0;		errors = adap->errors & (_HS_HW_FAIL | _HS_TIMEOUT);		if (errors)			printk(KERN_WARNING "i2c-algo-biths.o: %s %s\n", adap->name,			       i2c_strerr(errflag(errors)));		printk(KERN_DEBUG "i2c-algo-biths.o: %s SCL: %d  SDA: %d\n", adap->name, gscl, gsda);		if ( sscl!=gscl )			printk(KERN_WARNING "i2c-algo-biths.o: %s SCL set %d, got %d!\n", adap->name, sscl, gscl);		if ( ssda!=gsda )			printk(KERN_WARNING "i2c-algo-biths.o: %s SDA set %d, got %d!\n", adap->name, ssda, gsda);		if ( (adap->errors) || sscl!=gscl || ssda!=gsda )			break;		i++;	}    	__setsda(1,0);	__setscl(1,0);	adap->errors = 0;	if (test[i][0]==-1) {		printk(KERN_INFO "i2c-algo-biths.o: %s passed bus test.\n",adap->name);		return 0;	} else {		printk(KERN_INFO "i2c-algo-biths.o: %s failed bus test.\n",adap->name);		return -ENODEV;	}}/* doAddress transmits the address in the necessary format to handle * reads, writes as well as 10bit-addresses. */static void doAddress(struct i2c_algo_biths_data *adap, struct i2c_msg *msg) {	unsigned char addr[2];	int count;	if ( msg->flags & I2C_M_TEN ) { 		/* a ten bit address */		count = 2;		addr[0] = 0xf0 | (( msg->addr >> 7) & 0x03);		addr[1] = msg->addr & 0x7f;		/* try extended address code ... and the remaining 8 bit address */		TRY(i2c_outb(adap, msg->flags, addr, &count));		if ( msg->flags & I2C_M_RD ) {			TRY(i2c_start(adap));						/* okay, now switch into reading mode */			count = 1;			addr[0] |= 0x01;			TRY(i2c_outb(adap, msg->flags, addr, &count));		}	} else {		/* normal 7bit address	*/		count = 1;		addr[0] = ( msg->addr << 1 );		if (msg->flags & I2C_M_RD )			addr[0] |= 1;		if (msg->flags & I2C_M_REV_DIR_ADDR )			addr[0] ^= 1;		TRY(i2c_outb(adap, msg->flags, addr, &count));	}}/* * return values: * 1 ACK * 0 IGNORED client NAK * -EREMOTEIO  client NAK * -ETIMEDOUT  from sclhi() */static int bit_xfer(struct i2c_adapter *i2c_adap,		    struct i2c_msg msgs[], int num){	struct i2c_msg *msg = msgs;	struct i2c_algo_biths_data *adap = i2c_adap->algo_data;	int mn, j, state;	enum { MSG_INIT, MSG_START, MSG_ADDRESS, MSG_DATA, MSG_READY, MSG_STOP, MSG_EXIT };	state = MSG_INIT;	mn=0;	adap->dstr=NULL;	if (i2c_debug>=FATAL_PROTOCOL) {		adap->dstr = kmalloc(PROTO_MAX_DUMP, GFP_KERNEL);		if (adap->dstr) {			*adap->dstr = 0;		} else {			printk(KERN_DEBUG "i2c-algo-biths.o %s: missing protocol dump (-ENOMEM)\n", adap->name);		}	}	for (j=0; j<num; j++) msgs[j].err = 0; // unprocessed	do switch (state) {	    	    case MSG_INIT:		    msg = &msgs[mn];		    if ((msg->flags & I2C_M_NOSTART) && (mn)) {			    state = MSG_DATA;			    break;		    }	    case MSG_START:			    i2c_start(adap);		    if (adap->errors) {			    state = MSG_STOP;				    break;		    }			    	    case MSG_ADDRESS:		    doAddress(adap, msg);		    if (adap->errors) {			    state = MSG_STOP;			    break;		    }	    case MSG_DATA:		    j = msg->len;		    if ( msg->flags & I2C_M_RD ) {			    i2c_inb(adap, msg->flags, msg->buf, &j);		    } else {			    i2c_outb(adap, msg->flags, msg->buf, &j);		    }		    msg->done = msg->len - j;		    if (adap->errors) {			    state = MSG_STOP;			    break;		    }		    case MSG_READY:		    mn++;		    if (mn<num) {			    msg->err = errflag(adap->errors);			    debug_protocol(adap, msg->err);			    state = MSG_INIT;			    break;		    }	    case MSG_STOP:		    msg->err = errflag(adap->errors);		    i2c_stop(adap);		    j = 0;		    while (adap->errors) {			    if ( ++j > 10) {				    msg->err = -ENODEV;				    break;			    }			    i2c_stop(adap);		    }		    debug_protocol(adap, msg->err);		    state = MSG_EXIT;		    break;	    default: /* not reached */		    state = MSG_EXIT;		    msg->err = -EINVAL;		    break;		    		  	} while (state != MSG_EXIT);		if (adap->dstr) kfree(adap->dstr);	for (j=0; j<num; j++)		debug_printout(i2c_adap, j, msgs[j].err);	return (msg->err < 0) ? msg->err : mn;}static u32 bit_func(struct i2c_adapter *i2c_adap){	return I2C_FUNC_I2C | I2C_FUNC_SMBUS_EMUL |	       I2C_FUNC_10BIT_ADDR | I2C_FUNC_PROTOCOL_MANGLING;}/* -----exported algorithm data: -------------------------------------	*/static struct i2c_algorithm i2c_algo_biths = {	.name		= "Bit-shift algorithm",	.id		= I2C_ALGO_BIT,	.master_xfer	= bit_xfer,	.functionality	= bit_func,};#if ALGO_BIT_COMPATIBILITY #include "i2c-algo-bit.h"static _HS_ATTR_ void _old_setscl(void *hw_data, int hw_state){	struct i2c_algo_bit_data *old = hw_data;	old->setscl(old->data, hw_state & _HS_SCL);}static _HS_ATTR_ void _old_setsda(void *hw_data, int hw_state){	struct i2c_algo_bit_data *old = hw_data;	old->setsda(old->data, hw_state & _HS_SDA);}static _HS_ATTR_ int _old_getscl(void *hw_data){	struct i2c_algo_bit_data *old = hw_data;	return old->getscl(old->data);}static _HS_ATTR_ int _old_getsda(void *hw_data){	struct i2c_algo_bit_data *old = hw_data;	return old->getsda(old->data);}static _HS_ATTR_ void _old_setstate(struct i2c_algo_biths_data *adap){	adap->hw_state = adap->ctrl;}static struct i2c_algo_biths_data _old_template = {	.setstate	= _old_setstate,	.setsda		= _old_setsda,	.setscl		= _old_setscl,	.getsda		= _old_getsda,	.getscl		= _old_getscl,};/*  * registering functions to load algorithms at runtime  */int i2c_bit_add_bus(struct i2c_adapter *i2c_adap){	int i; 	struct i2c_algo_bit_data *old_adap = i2c_adap->algo_data;	struct i2c_algo_biths_data *adap;	adap = kmalloc(sizeof(struct i2c_algo_biths_data), GFP_KERNEL);	if (adap==NULL)		return -ENOMEM;	memcpy(adap, &_old_template, sizeof(struct i2c_algo_biths_data));	adap->hw_data = old_adap;	adap->xloops = old_adap->udelay * 0x0863; /* 1/4 vs 1/2 cycle, 0x10c6 / 2 */	adap->timeout = old_adap->timeout;	i2c_adap->algo_data = adap;	return i2c_biths_add_bus(i2c_adap);}int i2c_bit_del_bus(struct i2c_adapter *i2c_adap){	int res;	if ((res = i2c_biths_del_bus(i2c_adap)) < 0)		return res;	kfree(i2c_adap->algo_data);	return 0;}EXPORT_SYMBOL(i2c_bit_add_bus);EXPORT_SYMBOL(i2c_bit_del_bus);#endif#ifdef rdtscl/* TSC stuff from arch/i386/lib/delay.c */static _HS_ATTR_ void i2c_tsc_set(struct i2c_algo_biths_data *adap){	rdtscl(adap->bclock);}static _HS_ATTR_ void i2c_tsc_run(struct i2c_algo_biths_data *adap){	unsigned long now, loops;	loops = ((long long) adap->xloops * current_cpu_data.loops_per_jiffy) >> 32; 	loops *= HZ;	do	{		rep_nop();		rdtscl(now);	} while ( (now - adap->bclock) < loops );}#else static _HS_ATTR_ void i2c_udelay_set(struct i2c_algo_biths_data *adap) {}static _HS_ATTR_ void i2c_udelay_run(struct i2c_algo_biths_data *adap){	int usecs;	/* adap->xloops = usecs * 0x000010c6 / 2; */	usecs = ((adap->xloops + 0x0863) >> 12); 	if (adap->ctrl & _HS_DBL_DT)		usecs<<=1;	udelay(usecs);}#endif /* rdtscl *//*  * registering functions to load algorithms at runtime  */int i2c_biths_add_bus(struct i2c_adapter *i2c_adap){	struct i2c_algo_biths_data *adap = i2c_adap->algo_data;	/* get name */	adap->name = i2c_adap->name;	adap->dstr = 0; // no protocol dump buffer	if (adap->set_timer == NULL) {#ifdef rdtscl 	/* if (x86_udelay_tsc) here instead ? */		adap->set_timer = i2c_tsc_set;		adap->run_timer = i2c_tsc_run;#else		adap->set_timer = i2c_udelay_set;		adap->run_timer = i2c_udelay_run;#endif	}	if (bit_test) {		int ret = test_bus(adap);		if (ret<0)			return ret;	}	DEB1(printk(KERN_DEBUG "i2c-algo-biths.o: hw routines for %s registered.\n",	            i2c_adap->name));#ifdef rdtscl	DEB1(printk(KERN_DEBUG "i2c-algo-biths.o:  ... will use rdtscl() for bus clock\n"));#else	DEB1(printk(KERN_DEBUG "i2c-algo-biths.o:  ... will use udelay() for bus clock\n"));#endif		/* register new adapter to i2c module... */	i2c_adap->id |= i2c_algo_biths.id;	i2c_adap->algo = &i2c_algo_biths;	i2c_adap->timeout = HZ;	/* default values, should	*/	i2c_adap->retries = 3;	/* be replaced by defines	*/	i2c_add_adapter(i2c_adap);	return 0;}int i2c_biths_del_bus(struct i2c_adapter *i2c_adap){	return i2c_del_adapter(i2c_adap);}EXPORT_SYMBOL(i2c_biths_add_bus);EXPORT_SYMBOL(i2c_biths_del_bus);MODULE_AUTHOR("Ky鰏ti M鋖kki <kmalkki@cc.hut.fi>");MODULE_DESCRIPTION("I2C-Bus bit-banging algorithm");MODULE_LICENSE("GPL");MODULE_PARM(bit_test, "i");MODULE_PARM(i2c_debug,"i");MODULE_PARM_DESC(bit_test, "Test the lines of the bus to see if it is stuck");MODULE_PARM_DESC(i2c_debug, "debug level - 1 use; 2 fatal, 3 +proto; 4 all, 5 +proto");

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩国产美| a级精品国产片在线观看| 亚洲欧洲无码一区二区三区| 欧美精品国产精品| 欧美在线色视频| 成人avav在线| 国产资源在线一区| 蜜臀av国产精品久久久久| 日韩理论在线观看| 国产欧美一区二区三区沐欲| 欧美午夜精品一区二区三区| av午夜精品一区二区三区| 久久成人av少妇免费| 一区二区三区免费看视频| 亚洲品质自拍视频| 亚洲免费在线视频一区 二区| 久久―日本道色综合久久| 日韩欧美亚洲一区二区| 91精品在线观看入口| 日韩免费成人网| 精品福利在线导航| 欧美激情资源网| 国产精品久久久久久妇女6080| 亚洲丝袜美腿综合| 自拍偷拍欧美精品| 日日摸夜夜添夜夜添精品视频| 国产乱国产乱300精品| 国产精品18久久久久久vr| 美女尤物国产一区| 欧美性猛交一区二区三区精品| 日韩三级电影网址| 亚洲在线视频网站| 成人性生交大片免费看中文网站| 欧美三级韩国三级日本三斤| 国产色一区二区| 精品一区二区三区免费视频| 色综合久久天天综合网| 国产午夜精品久久久久久免费视| 亚洲一区日韩精品中文字幕| 成人国产精品免费观看| 日韩欧美精品在线| 日韩激情视频在线观看| 欧美亚洲综合色| 亚洲美女免费在线| 99久免费精品视频在线观看| 欧美激情在线看| 日韩va欧美va亚洲va久久| 国产91精品精华液一区二区三区 | 国产精品系列在线| 视频一区欧美精品| www.亚洲人| 国产情人综合久久777777| 免费在线看成人av| 在线免费亚洲电影| 亚洲欧美乱综合| av一区二区三区黑人| 久久精品人人做人人爽97| 美腿丝袜一区二区三区| 91精品国产乱码久久蜜臀| 亚洲综合另类小说| 欧美写真视频网站| 亚洲午夜影视影院在线观看| 日本道色综合久久| 亚洲精品国产无套在线观| 91免费观看视频| 亚洲精品乱码久久久久久黑人| 成年人网站91| 亚洲女同ⅹxx女同tv| 91久久精品日日躁夜夜躁欧美| 亚洲精品大片www| 欧美午夜精品久久久久久孕妇| 亚洲精品免费视频| 欧美日韩视频在线一区二区| 午夜视频在线观看一区| 欧美丰满一区二区免费视频| 免费观看成人av| 国产夜色精品一区二区av| 国产宾馆实践打屁股91| 欧美高清一级片在线观看| 91看片淫黄大片一级在线观看| 亚洲男人天堂一区| 欧美一个色资源| 成人美女视频在线看| 午夜欧美在线一二页| 久久青草国产手机看片福利盒子| www.欧美日韩国产在线| 亚洲国产另类精品专区| 欧美成人一区二区| www.在线欧美| 久久99久久99| 一二三区精品视频| 久久看人人爽人人| 欧美在线短视频| 国产一区二三区| 天天做天天摸天天爽国产一区| 精品99999| 欧美高清精品3d| av成人老司机| 国产精品一卡二卡| 亚洲国产色一区| 亚洲欧美一区二区三区国产精品 | www.亚洲激情.com| 久久精品国产99久久6| 亚洲一区二区三区不卡国产欧美| 久久只精品国产| 欧美一区二区三区四区久久| 91一区二区在线观看| 成人av免费在线| 成人黄色在线网站| youjizz国产精品| 成人av高清在线| 91影院在线观看| 不卡视频免费播放| 东方欧美亚洲色图在线| 美女视频网站黄色亚洲| 美女脱光内衣内裤视频久久网站 | 天天综合天天做天天综合| 亚洲国产视频一区| 日韩成人伦理电影在线观看| 日本亚洲视频在线| 精油按摩中文字幕久久| 黄一区二区三区| 成人免费高清视频| 91丨九色丨尤物| 91久久精品一区二区三| 欧美性极品少妇| 日韩欧美一区二区视频| 久久尤物电影视频在线观看| 久久久久久久久久美女| 国产精品久久久久久久裸模| 亚洲九九爱视频| 免费成人在线观看| 国产精品456| 色8久久精品久久久久久蜜| 欧美色手机在线观看| 久久一区二区视频| 中文字幕在线不卡国产视频| 亚洲在线免费播放| 国产永久精品大片wwwapp | 99免费精品视频| 欧美日韩在线播放| 26uuu国产日韩综合| 精品播放一区二区| 国产精品人人做人人爽人人添| 一区二区在线观看免费| 精品一区二区影视| 欧美影视一区二区三区| 久久久777精品电影网影网| 亚洲码国产岛国毛片在线| 国内外成人在线视频| 欧美在线你懂得| 国产精品久久久久三级| 免费高清视频精品| 91成人国产精品| 国产精品久久久久影院| 精品在线播放午夜| 欧美日韩激情一区| 亚洲精品日韩综合观看成人91| 激情五月激情综合网| 91精品国产综合久久精品| 国产精品99久久久| 日韩欧美国产电影| 亚洲国产美国国产综合一区二区| 成人黄色av电影| 国产欧美日韩久久| 国产大陆精品国产| 久久久久久久一区| 国产电影一区在线| 国产欧美一区二区三区在线看蜜臀| 精品影视av免费| 精品国产露脸精彩对白| 久久激情五月激情| 精品国产一区二区亚洲人成毛片 | a在线欧美一区| 亚洲免费av高清| 欧美午夜在线观看| 一区二区三区欧美| 91精品国产一区二区三区香蕉| 秋霞影院一区二区| 久久麻豆一区二区| voyeur盗摄精品| 亚洲国产视频直播| 91精品国产一区二区三区蜜臀 | 一个色在线综合| 欧美一区二区三区免费视频 | 韩国精品主播一区二区在线观看| 精品乱人伦一区二区三区| 国产精品资源网站| 亚洲精品五月天| 欧美sm美女调教| 色婷婷av一区二区三区之一色屋| 亚洲成人免费视频| 中文av一区二区| 欧美日韩不卡在线| 成人永久免费视频| 午夜久久久久久| 夜夜嗨av一区二区三区四季av | 91精品国产综合久久福利| 成人精品亚洲人成在线| 久久aⅴ国产欧美74aaa|