分类: C/C++
2008-04-03 13:30:29
差不多把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完成之后实际写的大小来判断操作是否成功才是最准确的。