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

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

?? vfc_i2c.c

?? 優龍2410linux2.6.8內核源代碼
?? 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_wakeup(struct vfc_dev *dev) {	/* Used to profile code and eliminate too many delays */	VFC_I2C_DEBUG_PRINTK(("vfc%d: Delaying\n", dev->instance));	wake_up(&dev->poll_wait);}void vfc_i2c_delay_no_busy(struct vfc_dev *dev, unsigned long usecs) {	init_timer(&dev->poll_timer);	dev->poll_timer.expires = jiffies + 		((unsigned long)usecs*(HZ))/1000000;	dev->poll_timer.data=(unsigned long)dev;	dev->poll_timer.function=(void *)(unsigned long)vfc_i2c_delay_wakeup;	add_timer(&dev->poll_timer);	sleep_on(&dev->poll_wait);	del_timer(&dev->poll_timer);}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一区二区三区免费野_久草精品视频
久久国产福利国产秒拍| 亚洲精品视频在线看| 99麻豆久久久国产精品免费优播| 亚洲欧美在线视频| 日韩欧美一区电影| 欧美亚洲日本国产| 成人夜色视频网站在线观看| 日韩影院在线观看| 中文字幕一区二区三区精华液| 欧美zozozo| 欧美日韩成人高清| 99视频精品在线| 成人免费看片app下载| 日日欢夜夜爽一区| 亚洲精品国久久99热| 久久久久国产一区二区三区四区| 欧美一区二区免费| 欧美日韩中文字幕一区二区| 不卡的av在线| 国产精品77777竹菊影视小说| 日韩黄色免费电影| 一个色综合网站| 中文字幕精品在线不卡| 337p粉嫩大胆色噜噜噜噜亚洲| 欧美日韩国产小视频在线观看| 97超碰欧美中文字幕| 国产成人亚洲精品狼色在线| 韩国一区二区在线观看| 日韩国产欧美在线观看| 亚洲高清免费在线| 青青青爽久久午夜综合久久午夜| 一区二区三区视频在线看| 亚洲丝袜自拍清纯另类| 中文字幕不卡在线观看| 日本一区二区三区免费乱视频 | 欧美日韩免费高清一区色橹橹| 99精品视频一区| av福利精品导航| 成人18视频在线播放| 91在线无精精品入口| 国产免费成人在线视频| 久久国产剧场电影| 蜜臀久久99精品久久久久宅男| 久久久久九九视频| 欧美日韩电影在线播放| 一区二区欧美国产| 国产午夜亚洲精品理论片色戒 | 成人av网站在线观看免费| 不卡的看片网站| 91精品国产黑色紧身裤美女| 国产亚洲成aⅴ人片在线观看| 夜夜嗨av一区二区三区中文字幕 | 91亚洲国产成人精品一区二区三| 欧美日韩一区不卡| 久久精品男人天堂av| 亚洲精品国产a久久久久久| 秋霞影院一区二区| 91免费看视频| 久久男人中文字幕资源站| 亚洲午夜免费电影| 国产高清精品久久久久| 欧美日韩在线不卡| 国产精品乱码人人做人人爱| 日韩高清不卡在线| aaa亚洲精品一二三区| 6080午夜不卡| 成人免费在线播放视频| 久久se精品一区精品二区| 在线观看日韩av先锋影音电影院| 久久只精品国产| 视频一区中文字幕国产| 成人av电影在线网| 精品国产亚洲一区二区三区在线观看| 亚洲精品一二三| 国产成人精品综合在线观看| 91精品免费在线| 亚洲最新视频在线观看| 国产成人99久久亚洲综合精品| 5858s免费视频成人| 亚洲精品免费在线观看| 高清不卡一区二区在线| 精品理论电影在线| 日本欧美在线观看| 欧美日韩小视频| 亚洲欧美一区二区三区久本道91| 色综合天天狠狠| 中文字幕精品一区| 国产一区福利在线| 日韩欧美三级在线| 日韩vs国产vs欧美| 欧美巨大另类极品videosbest| 玉米视频成人免费看| www.日韩精品| 中文字幕在线视频一区| 国产精品一区二区三区99| 日韩欧美亚洲国产另类| 日韩中文字幕91| 欧美亚洲一区二区在线| 亚洲免费高清视频在线| 91在线观看高清| 国产精品天干天干在线综合| 国产高清亚洲一区| 久久久不卡影院| 精品一区二区三区免费观看| 欧美一区二区三区小说| 亚瑟在线精品视频| 欧美日韩精品福利| 奇米一区二区三区| 欧美一级爆毛片| 久久精品国产999大香线蕉| 日韩欧美不卡一区| 国产一区二区美女诱惑| 久久免费午夜影院| 成人永久免费视频| 亚洲欧美激情视频在线观看一区二区三区 | 亚洲一本大道在线| 在线看不卡av| 偷拍日韩校园综合在线| 91精品久久久久久蜜臀| 麻豆精品视频在线观看视频| 日韩三级免费观看| 韩日av一区二区| 国产精品视频免费| av在线一区二区三区| 一区二区三区小说| 欧美精品日韩一区| 精一区二区三区| 国产欧美精品一区aⅴ影院| 成人aaaa免费全部观看| 亚洲最大的成人av| 欧美一区二区啪啪| 国产成人在线视频免费播放| 18成人在线观看| 欧美精品一卡两卡| 国产麻豆一精品一av一免费| 亚洲人快播电影网| 日韩欧美视频一区| 91亚洲精品一区二区乱码| 亚洲成人免费在线观看| 2021国产精品久久精品| 一本一道综合狠狠老| 秋霞午夜鲁丝一区二区老狼| 国产精品久久夜| 欧美剧在线免费观看网站| 国产91清纯白嫩初高中在线观看 | 波多野结衣91| 视频一区二区中文字幕| 国产午夜精品一区二区三区四区| 91蜜桃在线观看| 捆绑紧缚一区二区三区视频| 国产精品国产三级国产有无不卡 | 天天av天天翘天天综合网| 久久蜜桃av一区二区天堂 | 亚洲欧美乱综合| 精品久久人人做人人爰| 99视频一区二区| 麻豆精品国产91久久久久久| 自拍视频在线观看一区二区| 日韩欧美中文字幕公布| 色婷婷狠狠综合| 国产精品一二三区| 亚洲18女电影在线观看| 国产精品不卡在线| 日韩一区二区精品葵司在线| 91免费视频网| 国产精品99久| 美日韩一区二区三区| 亚洲欧美偷拍卡通变态| 2020国产精品| 在线不卡一区二区| 99re这里只有精品6| 精品无码三级在线观看视频 | 成人午夜免费视频| 日本欧美一区二区在线观看| 亚洲精品视频免费观看| 久久久国产精品麻豆| 欧美一区二区免费| 欧洲在线/亚洲| 成人精品小蝌蚪| 国产酒店精品激情| 蜜乳av一区二区| 亚洲国产成人精品视频| 亚洲精品视频观看| 中文字幕一区二区不卡| 国产亚洲精品中文字幕| 精品日韩欧美在线| 制服丝袜中文字幕一区| 91福利社在线观看| gogo大胆日本视频一区| 国产成人综合亚洲网站| 麻豆国产91在线播放| 日韩成人免费电影| 亚洲国产一二三| 夜夜精品视频一区二区| 亚洲欧美区自拍先锋| 亚洲日本在线天堂| 1区2区3区精品视频| 中文字幕在线免费不卡| 亚洲欧洲国产日本综合| 中文av字幕一区|