您的位置:逆风者 VC++ 正文
 添加时间:2007-11-25 原文发表:2007-11-25 人气:89 来源:vckbase.com

作者:iexcy

差不多把vckbase.com里CE相关的文章都看完了,但是没有看到与I2C相关的文章。由于我现在所做的是CE下I2C通信,所以把自己总结的经验给大家分享一下。PS:其实在这条路上我也是新手一个。
逆风编程精品
现在大多数的CE系统都对稳定性和速度的要求及高,所以I2C通信快速和稳定性是它在CE系统上运用非常广泛,至少我现在所从事的项目和我所知道的项目很多的地方都运用到了I2C接口。
I2C的驱动是按照流驱动来做的,所以对I2C上的设备进行操作时和对串口的读写操作一样非常简单,用的是createfile,writefile,readfile,不同的地方就是要用DeviceIoControl来设置波特率,主从模式和寄存器的模式,这些相应的值CPU的生产厂家会给你。最重要的是要真正了解自己所操作的设备的I2C协议,那对设备操作起来就相当的容易了。
其实我是学纯软件的,刚接触I2C这个东西时是真的一问三不知,但当我在和I2C打交道一年之后发现,I2C真是一个通用的东西,只要支持I2C的硬件设备在CE下都可以用相同的代码去进行操作。这里相同的代码的意思是说形式完全一样,具体的操作命令值就要仔细阅读设备的I2C协议了。请大家不要误解。

一:打开I2C接口:

hT2C = CreateFile(TEXT("I2C1:"),
		  GENERIC_READ|GENERIC_WRITE,
		  0, NULL, OPEN_EXISTING,
		  FILE_ATTRIBUTE_NORMAL, NULL);
if (hT2C == INVALID_HANDLE_VALUE)
{

	if (GetLastError() == ERROR_DEV_NOT_EXIST)
	{
		//         register I2C device driver
		hDriver = RegisterDevice(TEXT("I2C"), 1, TEXT("I2C.DLL"), 0);
		if (!hDriver)
		{
			RETAILMSG(1, (TEXT("Failed to register I2C device driver.\r\n")));
		}
		hT2C = CreateFile(TEXT("I2C1:"),
				GENERIC_READ|GENERIC_WRITE,
				0, NULL, OPEN_EXISTING,
				FILE_ATTRIBUTE_NORMAL, NULL);
	}
	
	if (hT2C == INVALID_HANDLE_VALUE)
	{
	        dwErrorCode = GetLastError();
		return   dwErrorCode ;
	}
}


//set mode: master

dwIoControlCode = I2C_MASTER_MODE;//这个值CPU厂家给
DeviceIoControl(hT2C, IOCTL_I2C_SET_MODE,
    (PVOID)&dwIoControlCode, sizeof(DWORD), NULL, 0, &dwRet, NULL);

//set baudrate: 

DeviceIoControl(hT2C, IOCTL_I2C_SET_BAUDRATE,//dwData  CPU厂家给
	(PVOID)&dwData, sizeof(DWORD), NULL, 0, &dwRet, NULL);

//set buffer mode: single

dwIoControlCode = I2C_SINGLE_STAGE;
DeviceIoControl(hT2C, IOCTL_I2C_SET_BUFFER_MODE,//dwIoControlCode  CPU厂家给
    (PVOID)&dwIoControlCode, sizeof(DWORD), NULL, 0, &dwRet, NULL);
二:写I2C数据
//写校验码
WriteFile ( hT2C, BUFFER, writesize, &wRetSize, NULL);

//判断存储是否成功
if (!wRetSize)
{
	dwErrorCode = GetLastError();
	CloseHandle( hT2C );
	return  1; 
}
这里得说明一下,writefile的第5个参数必须为NULL,因为CE系统是不支持重叠的。writefile是BOOL型的,刚开始我用writefile的返回值来判断操作是否成功,结果判断结果根本不准确,用writefile完成之后实际写的大小来判断操作是否成功才是最准确的。
读操作和写操作基本一样,就不详细说明了。
相关文章

文件过滤系统驱动开发Filemon学习笔记
DynamicLayout-VC 6.0对话框动态布局解决方
用命令模式实现对象存储——对象与关系数据
探讨性能测试中的计时问题
对OpenCV中的平面划分相关函数使用探索
让你的软件界面更漂亮(六)-- 仿QQ主界面之L
软件框架的利器、TangramMini组件应用教程六
利用IJG JPEG Library压缩图像为jpg格式
用递归的方法画分形图
MFC中基于对话框程序快捷键的实现
简单录、放音并保存为wav文件程序
动态创建控件支持事件响应并可保存与读取
如何实现由列表控件控制的属性表
多线程管理类
浅谈输入法编程
MFC 通用控件的初始化
基于GDI+的数字图像处理
运动搜索算法之钻石搜索(Ver1.0)
VC6下的GDI+双缓冲
使用SNMP编辑(添加/删除/修改)ARP表

相关评论


本文章所属分类:首页 VC++

  热门关键字: