我有一个关于传输参数的问题想咨询,
我需要将一些参数从用户空间传输到内核空间,但其中一个丢失了(当我从内核空间检查时值不正确)。但我不知道它为什么会丢失。
下面是我的一些代码和日志,丢失的参数是 write_flag,我在用户空间中将 write_flag 设置为整数(2)。
但是当我在内核空间中打印 write_flag 时,它完全错误(1651866136)。一些参数像操作码和参数一样被毫无问题地传输。
[ 859.877750] user.write_flag:1651866136, idata->ic.write_flag:1651866136
[ 859.883133] user.opcode:8, idata->ic.opcode:8
[ 859.887421] user.arg:0, idata->ic.arg:0
有没有人可以给我一些想法来解决这个问题,write_flag 的数据类型是 int,opcode 和 arg 是 __u32。
谢谢。
HAL 方面:
LOGI("dev->fd:%d, cmd_idx:%d, arg:%d.",dev->fd,mmc_local_cmd->opcode, mmc_local_cmd->arg);
LOGI("dev->write_flag:%d.",mmc_local_cmd->write_flag);
ret = ioctl(dev->fd,MMC_IOC_CMD,&mmc_local_cmd);
内核端:
if (copy_from_user(&idata->ic, user, sizeof(idata->ic))) {
err = -EFAULT;
goto idata_err;
}
/*FIXME: write_flag is incorrect before copy_from_user execute */
printk("user.write_flag:%d, idata->ic.write_flag:%d\n",user->write_flag, idata->ic.write_flag);
printk("user.opcode:%d, idata->ic.opcode:%d\n",user->opcode, idata->ic.opcode);
printk("user.arg:%d, idata->ic.arg:%d\n",user->arg, idata->ic.arg);