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

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

?? vfc_i2c.c

?? 底層驅動開發
?? C
字號:
/* * drivers/sbus/char/vfc_i2c.c * * Driver for the Videopix Frame Grabber. *  * Functions that support the Phillips i2c(I squared C) bus on the vfc *  Documentation for the Phillips I2C bus can be found on the  *  phillips home page * * Copyright (C) 1996 Manish Vachharajani (mvachhar@noc.rutgers.edu) * *//* NOTE: It seems to me that the documentation regarding thepcd8584t/pcf8584 does not show the correct way to address the i2c bus.Based on the information on the I2C bus itself and the remainder ofthe Phillips docs the following algorithims apper to be correct.  I amfairly certain that the flowcharts in the phillips docs are wrong. */#include <linux/kernel.h>#include <linux/string.h>#include <linux/slab.h>#include <linux/errno.h>#include <linux/sched.h>#include <linux/wait.h>#include <linux/delay.h>#include <asm/openprom.h>#include <asm/oplib.h>#include <asm/io.h>#include <asm/system.h>#include <asm/sbus.h>#if 0 #define VFC_I2C_DEBUG#endif#include "vfc.h"#include "vfc_i2c.h"#define WRITE_S1(__val) \	sbus_writel(__val, &dev->regs->i2c_s1)#define WRITE_REG(__val) \	sbus_writel(__val, &dev->regs->i2c_reg)#define VFC_I2C_READ (0x1)#define VFC_I2C_WRITE (0x0)     /******   The i2c bus controller chip on the VFC is a pcd8584t, but  phillips claims it doesn't exist.  As far as I can tell it is  identical to the PCF8584 so I treat it like it is the pcf8584.    NOTE: The pcf8584 only cares  about the msb of the word you feed it *****/int vfc_pcf8584_init(struct vfc_dev *dev) {	/* This will also choose register S0_OWN so we can set it. */	WRITE_S1(RESET);	/* The pcf8584 shifts this value left one bit and uses	 * it as its i2c bus address.	 */	WRITE_REG(0x55000000);	/* This will set the i2c bus at the same speed sun uses,	 * and set another magic bit.	 */	WRITE_S1(SELECT(S2));	WRITE_REG(0x14000000);		/* Enable the serial port, idle the i2c bus and set	 * the data reg to s0.	 */	WRITE_S1(CLEAR_I2C_BUS);	udelay(100);	return 0;}void vfc_i2c_delay_no_busy(struct vfc_dev *dev, unsigned long usecs) {	schedule_timeout_uninterruptible(usecs_to_jiffies(usecs));}void inline vfc_i2c_delay(struct vfc_dev *dev) { 	vfc_i2c_delay_no_busy(dev, 100);}int vfc_init_i2c_bus(struct vfc_dev *dev){	WRITE_S1(ENABLE_SERIAL | SELECT(S0) | ACK);	vfc_i2c_reset_bus(dev);	return 0;}int vfc_i2c_reset_bus(struct vfc_dev *dev) {	VFC_I2C_DEBUG_PRINTK((KERN_DEBUG "vfc%d: Resetting the i2c bus\n",			      dev->instance));	if(dev == NULL)		return -EINVAL;	if(dev->regs == NULL)		return -EINVAL;	WRITE_S1(SEND_I2C_STOP);	WRITE_S1(SEND_I2C_STOP | ACK);	vfc_i2c_delay(dev);	WRITE_S1(CLEAR_I2C_BUS);	VFC_I2C_DEBUG_PRINTK((KERN_DEBUG "vfc%d: I2C status %x\n",			      dev->instance,			      sbus_readl(&dev->regs->i2c_s1)));	return 0;}int vfc_i2c_wait_for_bus(struct vfc_dev *dev) {	int timeout = 1000; 	while(!(sbus_readl(&dev->regs->i2c_s1) & BB)) {		if(!(timeout--))			return -ETIMEDOUT;		vfc_i2c_delay(dev);	}	return 0;}int vfc_i2c_wait_for_pin(struct vfc_dev *dev, int ack){	int timeout = 1000; 	int s1;	while ((s1 = sbus_readl(&dev->regs->i2c_s1)) & PIN) {		if (!(timeout--))			return -ETIMEDOUT;		vfc_i2c_delay(dev);	}	if (ack == VFC_I2C_ACK_CHECK) {		if(s1 & LRB)			return -EIO; 	}	return 0;}#define SHIFT(a) ((a) << 24)int vfc_i2c_xmit_addr(struct vfc_dev *dev, unsigned char addr, char mode) { 	int ret, raddr;#if 1	WRITE_S1(SEND_I2C_STOP | ACK);	WRITE_S1(SELECT(S0) | ENABLE_SERIAL);	vfc_i2c_delay(dev);#endif	switch(mode) {	case VFC_I2C_READ:		raddr = SHIFT(((unsigned int)addr | 0x1));		WRITE_REG(raddr);		VFC_I2C_DEBUG_PRINTK(("vfc%d: receiving from i2c addr 0x%x\n",				      dev->instance, addr | 0x1));		break;	case VFC_I2C_WRITE:		raddr = SHIFT((unsigned int)addr & ~0x1);		WRITE_REG(raddr);		VFC_I2C_DEBUG_PRINTK(("vfc%d: sending to i2c addr 0x%x\n",				      dev->instance, addr & ~0x1));		break;	default:		return -EINVAL;	};	WRITE_S1(SEND_I2C_START);	vfc_i2c_delay(dev);	ret = vfc_i2c_wait_for_pin(dev,VFC_I2C_ACK_CHECK); /* We wait							      for the							      i2c send							      to finish							      here but							      Sun							      doesn't,							      hmm */	if (ret) {		printk(KERN_ERR "vfc%d: VFC xmit addr timed out or no ack\n",		       dev->instance);		return ret;	} else if (mode == VFC_I2C_READ) {		if ((ret = sbus_readl(&dev->regs->i2c_reg) & 0xff000000) != raddr) {			printk(KERN_WARNING 			       "vfc%d: returned slave address "			       "mismatch(%x,%x)\n",			       dev->instance, raddr, ret);		}	}		return 0;}int vfc_i2c_xmit_byte(struct vfc_dev *dev,unsigned char *byte) {	int ret;	u32 val = SHIFT((unsigned int)*byte);	WRITE_REG(val);	ret = vfc_i2c_wait_for_pin(dev, VFC_I2C_ACK_CHECK); 	switch(ret) {	case -ETIMEDOUT: 		printk(KERN_ERR "vfc%d: VFC xmit byte timed out or no ack\n",		       dev->instance);		break;	case -EIO:		ret = XMIT_LAST_BYTE;		break;	default:		break;	};	return ret;}int vfc_i2c_recv_byte(struct vfc_dev *dev, unsigned char *byte, int last) {	int ret;	if (last) {		WRITE_REG(NEGATIVE_ACK);		VFC_I2C_DEBUG_PRINTK(("vfc%d: sending negative ack\n",				      dev->instance));	} else {		WRITE_S1(ACK);	}	ret = vfc_i2c_wait_for_pin(dev, VFC_I2C_NO_ACK_CHECK);	if(ret) {		printk(KERN_ERR "vfc%d: "		       "VFC recv byte timed out\n",		       dev->instance);	}	*byte = (sbus_readl(&dev->regs->i2c_reg)) >> 24;	return ret;}int vfc_i2c_recvbuf(struct vfc_dev *dev, unsigned char addr,		    char *buf, int count){	int ret, last;	if(!(count && buf && dev && dev->regs) )		return -EINVAL;	if ((ret = vfc_i2c_wait_for_bus(dev))) {		printk(KERN_ERR "vfc%d: VFC I2C bus busy\n", dev->instance);		return ret;	}	if ((ret = vfc_i2c_xmit_addr(dev, addr, VFC_I2C_READ))) {		WRITE_S1(SEND_I2C_STOP);		vfc_i2c_delay(dev);		return ret;	}		last = 0;	while (count--) {		if (!count)			last = 1;		if ((ret = vfc_i2c_recv_byte(dev, buf, last))) {			printk(KERN_ERR "vfc%d: "			       "VFC error while receiving byte\n",			       dev->instance);			WRITE_S1(SEND_I2C_STOP);			ret = -EINVAL;		}		buf++;	}	WRITE_S1(SEND_I2C_STOP | ACK);	vfc_i2c_delay(dev);	return ret;}int vfc_i2c_sendbuf(struct vfc_dev *dev, unsigned char addr, 		    char *buf, int count) {	int ret;		if (!(buf && dev && dev->regs))		return -EINVAL;		if ((ret = vfc_i2c_wait_for_bus(dev))) {		printk(KERN_ERR "vfc%d: VFC I2C bus busy\n", dev->instance);		return ret;	}		if ((ret = vfc_i2c_xmit_addr(dev, addr, VFC_I2C_WRITE))) {		WRITE_S1(SEND_I2C_STOP);		vfc_i2c_delay(dev);		return ret;	}		while(count--) {		ret = vfc_i2c_xmit_byte(dev, buf);		switch(ret) {		case XMIT_LAST_BYTE:			VFC_I2C_DEBUG_PRINTK(("vfc%d: "					      "Receiver ended transmission with "					      " %d bytes remaining\n",					      dev->instance, count));			ret = 0;			goto done;			break;		case 0:			break;		default:			printk(KERN_ERR "vfc%d: "			       "VFC error while sending byte\n", dev->instance);			break;		};		buf++;	}done:	WRITE_S1(SEND_I2C_STOP | ACK);	vfc_i2c_delay(dev);	return ret;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品福利一二区| 久久国产乱子精品免费女| 国产最新精品免费| 日韩久久久久久| 一区二区三区在线播放| 国产精品影音先锋| 国产日本亚洲高清| 国产精品1区2区3区在线观看| 久久伊人蜜桃av一区二区| 精品中文字幕一区二区| 久久新电视剧免费观看| 国产精品一区专区| 国产精品视频一二三| 91在线无精精品入口| 亚洲精品免费在线播放| 制服.丝袜.亚洲.中文.综合| 亚洲一级不卡视频| 欧美男女性生活在线直播观看| 日韩—二三区免费观看av| 欧美一级精品在线| 国产成人啪午夜精品网站男同| 国产精品免费视频观看| 色噜噜久久综合| 美国三级日本三级久久99| 国产无遮挡一区二区三区毛片日本| 成人免费观看男女羞羞视频| 欧美亚洲国产bt| 一区二区三区加勒比av| 日韩免费观看高清完整版| 成人中文字幕合集| 午夜精品久久久久| 国产精品免费看片| 日韩三级视频在线观看| 不卡一二三区首页| 琪琪一区二区三区| 亚洲一区二区黄色| 中文字幕在线不卡国产视频| 538在线一区二区精品国产| 国产在线精品免费av| 亚洲第一在线综合网站| 亚洲国产高清在线观看视频| 91麻豆精品国产91久久久使用方法| 国产成人亚洲精品狼色在线| 老司机免费视频一区二区三区| 亚洲精品写真福利| 日韩一区中文字幕| 亚洲一区在线观看免费观看电影高清| 日韩欧美精品在线视频| 在线观看91视频| 一本在线高清不卡dvd| 成人精品在线视频观看| 成人av资源下载| 成人自拍视频在线| 99精品国产视频| 日本高清不卡视频| 在线这里只有精品| 欧美中文一区二区三区| 欧美性猛片xxxx免费看久爱| 色狠狠桃花综合| 色香蕉久久蜜桃| 69av一区二区三区| 精品日韩一区二区三区| 2022国产精品视频| 欧美国产欧美综合| 亚洲蜜臀av乱码久久精品| 亚洲国产日韩一区二区| 丝袜诱惑制服诱惑色一区在线观看 | 国产精品伦理在线| 亚洲人成网站影音先锋播放| 亚洲男女一区二区三区| 亚洲自拍偷拍麻豆| 国产精品一区二区久久不卡| 99精品热视频| 日韩美女在线视频| 亚洲欧洲日韩在线| 久久久久青草大香线综合精品| 欧美色老头old∨ideo| 26uuu久久天堂性欧美| 最近日韩中文字幕| 免费在线视频一区| av午夜精品一区二区三区| 欧美日韩另类一区| 国产欧美日韩三级| 日韩av电影天堂| 色综合色综合色综合色综合色综合| 91精品国产综合久久久蜜臀粉嫩| 久久久久久免费网| 免费日韩伦理电影| 欧美在线视频全部完| 国产精品久久久久四虎| 另类欧美日韩国产在线| 91麻豆免费看| 中文字幕一区二| 成人深夜福利app| 久久看人人爽人人| 黄色精品一二区| 欧美美女激情18p| 亚洲国产精品欧美一二99| 白白色 亚洲乱淫| 国产精品视频一二三区| av在线不卡网| 亚洲精品国产成人久久av盗摄 | 成熟亚洲日本毛茸茸凸凹| 欧美大片在线观看一区二区| 五月天视频一区| 3751色影院一区二区三区| 一区二区三区av电影 | 久久97超碰色| 国产午夜亚洲精品理论片色戒 | 免费观看在线综合| 欧美不卡123| www.久久久久久久久| 亚洲免费av在线| 欧美一区二区三区四区五区 | 国内外成人在线视频| 国产欧美精品一区二区三区四区 | 国产在线精品视频| 亚洲日本在线天堂| 欧美日韩精品高清| 国产一区二区主播在线| 亚洲激情图片一区| 欧美r级在线观看| 不卡一区在线观看| 性久久久久久久久久久久| 精品国产乱码久久久久久影片| 国产成人精品一区二区三区四区| 综合久久久久综合| 色婷婷国产精品| 日韩av在线播放中文字幕| 中文字幕欧美激情一区| 欧美精三区欧美精三区| 懂色一区二区三区免费观看| 亚洲r级在线视频| 中文字幕一区二区三中文字幕| 欧美一级二级在线观看| 99久久综合色| 国产91露脸合集magnet | 亚洲激情综合网| 国产网站一区二区三区| 日韩精品专区在线影院观看| 95精品视频在线| 成人av网站在线观看| 激情深爱一区二区| 久久精品国产网站| 日韩精品每日更新| 午夜av一区二区| 亚洲精品精品亚洲| 玉足女爽爽91| 亚洲国产精品影院| 亚洲国产日韩a在线播放性色| 亚洲欧美一区二区不卡| 日韩毛片精品高清免费| 亚洲精品自拍动漫在线| 亚洲三级在线播放| 亚洲成人资源网| 喷白浆一区二区| 韩国精品主播一区二区在线观看 | 亚洲综合免费观看高清在线观看| 国产精品色噜噜| 亚洲综合激情网| 久热成人在线视频| 成人av在线播放网站| 色视频一区二区| 欧美一区二区三区视频免费播放| 欧美xxx久久| 亚洲免费看黄网站| 日本va欧美va精品发布| 久久不见久久见免费视频1| 国产一区二区三区在线观看精品 | 韩国av一区二区三区四区| 成人影视亚洲图片在线| 欧美男女性生活在线直播观看 | 91在线云播放| 日韩亚洲欧美一区| 亚洲免费在线看| 久久精品噜噜噜成人av农村| 国产精品18久久久| 欧美美女直播网站| 国产精品不卡视频| 国产专区欧美精品| 欧美亚洲综合在线| 国产精品久久久久久久久动漫| 日韩av电影天堂| 在线观看视频一区二区欧美日韩| 精品精品欲导航| 午夜日韩在线电影| 亚洲一区在线视频| 国模冰冰炮一区二区| 7878成人国产在线观看| 专区另类欧美日韩| 国产福利一区二区| 久久精品亚洲国产奇米99| 免费的国产精品| 7777精品伊人久久久大香线蕉经典版下载 | 天天操天天干天天综合网| 91同城在线观看| 亚洲精品日韩综合观看成人91| 成人免费视频caoporn| 国产日产欧美一区二区视频| 精品亚洲成a人在线观看|