0

valgrind 在 ioctl() 行上给我以下错误:我不确定如何避免这样的错误。

==2764== 错误摘要:来自 1 个上下文的 1 个错误(被抑制:0 来自 0)
==2764==
==2764== 1 个上下文 1 中的错误:
==2764==系统调用参数 ioctl(I2C_RDWR)。 msgs 指向未初始化的字节
==2764== 在 0x4E08EFEC:ioctl (syscall-template.S:81)
==2764== by 0x871F: imxSend_i2cMsg (imx6qi2c_wrapper.c:54)
==2764== by 0x87CB: imxSend_i2cByte (imx6qi2c_wrapper.c:84)
==2764== by 0x86D3: main (imx6qi2c_test.c:30)
==2764== 地址 0x7db99b82 在线程 1 的堆栈上
==2764== 未初始化的值是由堆栈分配创建的
= =2764== 在 0x875C:imxSend_i2cByte (imx6qi2c_wrapper.c:66)

imx6qi2c_wrapper.c 中的代码如下:

int imxSend_i2cMsg(const int i2c_fd,
                   struct i2c_msg *i2cMsgArray,         
                   const unsigned int arraySize){
    int ret=0;
    struct i2c_rdwr_ioctl_data ioctl_pack;

    ioctl_pack.nmsgs=arraySize;
    ioctl_pack.msgs=i2cMsgArray;

    ret=ioctl(i2c_fd,I2C_RDWR,&ioctl_pack);

    return ret;
}

并且“i2cMsgArray”在本地的另一个函数中声明。

int imxSend_i2cByte(const int i2c_fd,
                      const unsigned char i2cAddress,
                      const unsigned char devRegister,
                      const unsigned char value){
    struct i2c_msg i2cmsg[I2CMSGS_TOTAL_WR];
    int ret=0,i=0;

    for (i=0;i<I2CMSGS_TOTAL_WR;i++){
        i2cmsg[i].buf=malloc(2*sizeof(char));
    } 

    i2cmsg[0].addr=i2cAddress;
    i2cmsg[0].flags=I2C_M_WR;
    i2cmsg[0].len=2;
    i2cmsg[0].buf[0]=devRegister;
    i2cmsg[0].buf[1]=value;

    ret=imxSend_i2cMsg(i2c_fd,&i2cmsg[0],I2CMSGS_TOTAL_WR);
    if (ret<0){
        printf("i2cmsg failed.errno is %d, %s\n",errno,strerror(errno));
    } 

    for (i=0;i<I2CMSGS_TOTAL_WR;i++){
        free(i2cmsg[i].buf);
    }
    return ret;
}

未初始化的字节在哪里?

4

1 回答 1

0

好的,只是为了完成,我在这里复制了作为评论给出的答案(但知道答案的用户从未将答案发布为答案)。

memset to 0 on i2cmsg will solve your problem
于 2015-07-22T17:23:23.857 回答