为什么有些ioctl案例总是失败?

why some ioctl cases always fails?

最近在练习一个简单的ioctl驱动,三个命令:print,get,set

在 ioctl switch 语句中,它看起来像这样的伪代码:

switch (cmd) {
case "print":
    break;
case "get":
    break;
case "set":
    break;
default:
    break;
}

但是,print case 可以正确执行,而get 和set case 则不能。 因此,我得到了输出

[ 2682.940000] mymem_ioctl: <---Switch Command =27395--->
[ 2682.940000] getdata=80046b01 80046b01setdata=40046b02 40046b02print=6b03 6b03
[ 2682.950000] <---ORG IOCPRINT :test_var=-1095999702--->
[ 2682.960000] <---IOCPRINT complete:test_var=111--->
cmd:6b03, arg=10 success
SETDATA cmd:40046b02
ioctl_setdata error
GETDATA cmd:80046b01
ioctl_getdata error

我尝试解码 ioctl 命令,但一切看起来都很好。

getdata=0x80046b01 => 1000 0000 0000 0100 ....
setdata=0x40046b02 => 0100 0000 0000 0100 ....
print=0x6b03

0100 is size of int 
6b is my magic number 'k'
01,02,03 is the number of function(get,set,print)

我不知道为什么...有人可以帮忙吗?

内核版本是2.6.38,下面是我的代码

@第 14 行

_IOC_NR(cmd)!=MYMEMDEV_IOC_MAXNR

应该可以检查

_IOC_NR(cmd) <= MYMEMDEV_IOC_MAXNR

另外,我求求你,遵循内核编码风格。这将使我们更容易以这种方式提供帮助。
http://lxr.free-electrons.com/source/Documentation/CodingStyle