tiny6410在I2c用户态中的程序设计eeprom
2016-03-16 17:24
323 查看
在读写的过程中,发现写数据成功但是读取数据却失败,猜测是因为iic的读写操作过快,故在写操作后给一定的延迟,进而读写成功。
代码如下:
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <unistd.h>
#include <sys/ioctl.h>
#include <linux/types.h>
struct i2c_msg {
unsigned short addr; /* slave address */
unsigned short flags;
unsigned short len; /* msg length */
unsigned char *buf; /* pointer to msg data */
};
struct i2c_rdwr_ioctl_data {
struct i2c_msg *msgs; /* pointers to i2c_msgs */
unsigned int nmsgs; /* number of i2c_msgs */
};
#define I2C_RDWR 0x0707 /* Combined R/W transfer (one STOP only) */
int main()
{
int fd;
struct i2c_rdwr_ioctl_data eeprom_data;
//1. 打开设备文件
fd = open( "/dev/i2c-0", O_RDWR );
if( fd == -1 )
{
printf("error open failed\r\n");
return ;
}
//2. 构造写数据到eeprom的消息
eeprom_data.msgs = (struct i2c_msg *)malloc( 2*sizeof(struct i2c_msg) );
eeprom_data.nmsgs = 1;
eeprom_data.msgs[0].len = 2;
eeprom_data.msgs[0].addr = 0x50;
eeprom_data.msgs[0].flags = 0;
eeprom_data.msgs[0].buf = (unsigned char *)malloc(2);
eeprom_data.msgs[0].buf[0] = 0x10;
eeprom_data.msgs[0].buf[1] = 0x60;
//3. 使用ioctl写入数据
if( 0>ioctl( fd, I2C_RDWR, (unsigned long)&eeprom_data))
{
printf("error write\n");
return ;
}
sleep(1);
//4. 构造从eeprom读取数据的消息
eeprom_data.nmsgs = 2;
eeprom_data.msgs[0].len = 1;
eeprom_data.msgs[0].addr = 0x50;
eeprom_data.msgs[0].flags = 0;
eeprom_data.msgs[0].buf[0] = 0x10;
eeprom_data.msgs[1].len = 1;
eeprom_data.msgs[1].addr = 0x50;
eeprom_data.msgs[1].flags = 1;
eeprom_data.msgs[1].buf = (unsigned char *)malloc(2);
eeprom_data.msgs[1].buf[0] = 0;
//5. 使用ioctl读出数据
if( -1 == ioctl( fd, I2C_RDWR, (unsigned long)&eeprom_data))
{
printf("error read\n");
return ;
}
printf("buff[0]=%x\n",eeprom_data.msgs[1].buf[0]);
//6. 关闭设备
close(fd);
}
代码如下:
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <unistd.h>
#include <sys/ioctl.h>
#include <linux/types.h>
struct i2c_msg {
unsigned short addr; /* slave address */
unsigned short flags;
unsigned short len; /* msg length */
unsigned char *buf; /* pointer to msg data */
};
struct i2c_rdwr_ioctl_data {
struct i2c_msg *msgs; /* pointers to i2c_msgs */
unsigned int nmsgs; /* number of i2c_msgs */
};
#define I2C_RDWR 0x0707 /* Combined R/W transfer (one STOP only) */
int main()
{
int fd;
struct i2c_rdwr_ioctl_data eeprom_data;
//1. 打开设备文件
fd = open( "/dev/i2c-0", O_RDWR );
if( fd == -1 )
{
printf("error open failed\r\n");
return ;
}
//2. 构造写数据到eeprom的消息
eeprom_data.msgs = (struct i2c_msg *)malloc( 2*sizeof(struct i2c_msg) );
eeprom_data.nmsgs = 1;
eeprom_data.msgs[0].len = 2;
eeprom_data.msgs[0].addr = 0x50;
eeprom_data.msgs[0].flags = 0;
eeprom_data.msgs[0].buf = (unsigned char *)malloc(2);
eeprom_data.msgs[0].buf[0] = 0x10;
eeprom_data.msgs[0].buf[1] = 0x60;
//3. 使用ioctl写入数据
if( 0>ioctl( fd, I2C_RDWR, (unsigned long)&eeprom_data))
{
printf("error write\n");
return ;
}
sleep(1);
//4. 构造从eeprom读取数据的消息
eeprom_data.nmsgs = 2;
eeprom_data.msgs[0].len = 1;
eeprom_data.msgs[0].addr = 0x50;
eeprom_data.msgs[0].flags = 0;
eeprom_data.msgs[0].buf[0] = 0x10;
eeprom_data.msgs[1].len = 1;
eeprom_data.msgs[1].addr = 0x50;
eeprom_data.msgs[1].flags = 1;
eeprom_data.msgs[1].buf = (unsigned char *)malloc(2);
eeprom_data.msgs[1].buf[0] = 0;
//5. 使用ioctl读出数据
if( -1 == ioctl( fd, I2C_RDWR, (unsigned long)&eeprom_data))
{
printf("error read\n");
return ;
}
printf("buff[0]=%x\n",eeprom_data.msgs[1].buf[0]);
//6. 关闭设备
close(fd);
}
相关文章推荐
- 动画完全解析(二):补间动画原理及自定义动画
- Django~static files (e.g. images, JavaScript, CSS)
- Monkey信息自动收集脚本
- axis2开发之---打arr包(2)
- ionic应用集成极光推送插件jpush
- 几种的实现动画效果2
- android防止按钮连续点击开启多次界面
- 清理linux内存cache
- FZU 2113 Jason的特殊爱好 [数位DP]
- Android实现屏幕旋转方法总结
- Java基础自学笔记001
- 自定义Android Studio工程模板
- CUBRID学习笔记 21 查看主键外键索引
- sizeof和strlen小结
- Android消息推送2----Mina框架的使用
- 【EJB基础】session bean
- 含所有运算符重载的讲解(附实例)
- 通过生日获取年龄
- Linux笔记(48)——环境变量配置文件
- postDelayed方法和removeCallbacks方法的使用