linux设备驱动之i2c i2c_master_send

对于写I2C寄存器,我们需要做的就是给 i2c_master_send 函数传入两个字节的数据即可,
i2c_master_send 接口的三个参数:client 为此次与主机通信的从机,buf 为发送的数据指针,count 为发送数据的字节数。
示例如下:
static int xxxx_i2c_write( struct i2c_client* client,uint8_t reg,uint8_t data)  
{  
    unsigned char buffer[2];  
      
    buffer[0] = reg;  
    buffer[1] = data;  
      
    if( 2!= i2c_master_send(client,buffer,2) ) {  
        printk( KERN_ERR " xxxx_i2c_write fail! \n" );  
        return -1;  
    }      
    return 0;  
}
读时序需要做的操作是,先向I2C总线上写入需要读的寄存器地址,然后读I2C总线上的值。
i2c_master_recv 接口的三个参数:client 为此次与主机通信的从机,buf 为接收的数据指针,count 为接收数据的字节数。
示例如下:
static int xxxx_i2c_read( struct i2c_client* client,uint8_t reg,uint8_t *data)  
{  
    // write reg addr     
    if( 1!= i2c_master_send(client,&reg,1) ) {  
        printk( KERN_ERR " xxxx_i2c_read fail! \n" );  
        return -1;  
    }      
    // wait  
    msleep(10);  
    // read  
    if( 1!= i2c_master_recv(client,data,1) ) {  
        printk( KERN_ERR " xxxx_i2c_read fail! \n" );  
        return -1;  
    }      
      
    return 0;  
}
i2c_transfer的参数:其中 adap 为此次主机与从机通信的适配器;msgs 为通信的数据包,这里可以是单个或多个数据包;num 用于指定数据包的个数,
如果大于1则表明将进行不止一次的通信。通信一次就需要寻址一次,如果需要多次通信就需要多次寻址。
int i2c_transfer(struct i2c_adapter *adap, struct i2c_msg *msgs, int num);
有的情况下我们要读一个寄存器的值,就需要先向从机发送一个寄存器地址然后再接收数据,这样如果想自己封装一个接口就需要将 num 设置为2。
接口的返回值如果失败则为负数,如果成功则返回传输的数据包个数。
比如读一个寄存器的接口可以按照如下方式封装:
static int read_reg(struct i2c_client *client, unsigned char reg, unsigned char *data)  
{  
    int ret;  
 
    struct i2c_msg msgs[] = {  
        {  
            .addr   = client->addr,  
            .flags  = 0,  
            .len    = 1,  
            .buf    = &reg,  // 寄存器地址  
        },  
        {  
            .addr   = client->addr,  
            .flags  = I2C_M_RD,  
            .len    = 1,  
            .buf    = data,  // 寄存器的值  
        },  
    };  
 
    ret = i2c_transfer(client->adapter, msgs, 2);  // 这里 num = 2,通信成功 ret = 2  
    if (ret < 0)  
        tp_err("%s error: %d\n", __func__, ret);  
 
    return ret;  
}
另一种接口封装:
static unsigned char read_reg(struct i2c_client *client, unsigned char reg)  
{  
    unsigned char buf;  
 
    i2c_master_send(client, &reg, 1);  // 发送寄存器地址  
    i2c_master_recv(client, &buf, 1);  // 接收寄存器的值  
 
    return  buf;  

  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值