linux底层i2c读写

首先包含头文件:linux/i2c.h

此头文件有一个重要的结构体:

struct i2c_msg{
    __u16 addr;  从机地址
    __u16 flags; 读写标志
    __u16 len;   消息长度
    __u8 *buf;   消息指针
};

标志

说明
I2C_M_RD0X0001读数据
I2C_M_TEN0X0010使用10位I2C地址
I2C_M_RECV_LEN0X0400收到第一个数据的长度
I2C_M_NO_RD_ACK0X0800忽略读响应
I2C_M_IGNORE_NAK0X1000忽略没有响应情况
I2C_M_REV_DIR_ADDR0X2000发送读标志进行写操作
I2C_M_NOSTART0X4000第一个地址后不再发送地址信息

发送数据时使用内核接口:

int i2c_transfer{struct i2c_adapter *adap, struct i2c_msg *msgs, int num)

写2个字节数据:

struct i2c_msg msg[1];
unsigned char buffer[2];
msg[0].addr = slave_address;
msg[0].flags = 0;
msg[0].len = 2;
msg[0].buf = buffer;
if (i2c_transfer(client.adapter, msg, 1) < 0){pr_err("i2c_test: i2c_transfer failed\n");}

读2个字节数据:

struct i2c_msg msg[1];
unsigned char buffer[2];
msg[0].addr = slave_address;
msg[0].flags = I2C_M_RD;
msg[0].len = 2;
msg[0].buf = buffer;
if (i2c_transfer(client.adapter, msg, 1) < 0){pr_err("i2c_test: i2c_transfer failed\n");}

先写地址再读1个字节数据:

struct i2c_msg msg[2];
unsigned char buffer[2];
msg[0].addr = slave_address;
msg[0].flags = I2C_M_RD;
msg[0].len = 1;
msg[0].buf = buffer;
msg[1].addr = slave_address;
msg[1].flags = 0;
msg[1].len = 1;
msg[1].buf = buffer;
if (i2c_transfer(client.adapter, msg, 2) < 0){pr_err("i2c_test: i2c_transfer failed\n");}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

雲烟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值