iwpriv配置失败的问题追踪[ioctl调用过程解析]

本文分析了在执行iwpriv配置时遇到的ioctl错误问题。通过跟踪从用户空间到内核空间的ioctl调用流程,发现错误源于在app中iw_get_ext()函数分配的空间不足,导致在net/wireless/wext-priv.c中的iw_handler_get_private判断失败。

现象:执行 iwpriv  athXXX  XXXX ,  ioctl报错


bugfix:

             【  app  】 [ iwpriv.c]  print_priv_info   --->   [iwlib.c] iw_get_priv_info  --->   iw_get_ext(skfd, ifname, SIOCGIWPRIV, &wrq)   --->   ioctl(skfd, request, pwrq)

  

             【kernel】上述ioctl实际上通过系统调用进入kernel space,          

                fs/Ioctl.c

SYSCALL_DEFINE3(ioctl, unsigned int, fd,unsigned int, cmd, unsigned long, arg)

{

……………………………………………………………………..

         error= do_vfs_ioctl(filp, fd, cmd, arg);//调用虚拟文件系统的ioctl

……………………………………………………………..

}

                do_vfs_ioctl   --->   vfs_ioctl(filp, cmd, arg)   --->   filp->f_op->unlocked_ioctl(filp, cmd, arg)

               net/socket.c

static const struct file_operations socket_file_ops = {
    .owner =    THIS_MODULE,
    .llseek =    no_llseek,
    .aio_read =    sock_aio_read,
    .aio_write =    sock_aio_write,
    .poll =        sock_poll,
    .unlocked_ioctl = sock_ioctl,
#ifdef CONFIG_COMPAT
    .compat_ioctl = compat_sock_ioctl,
#endif
    .mmap =        sock_mmap,
    .open =        sock_no_open,    /* special open code to disallow open via /proc */
    .release =    sock_close,
    .fasync =    sock_fasync,
    .sendpage =    sock_sendpage,
    .splice_write = generic_splice_sendpage,
    .splice_read =    sock_splice_read,
};
              static long sock_ioctl(struct file *file, unsigned cmd, unsigned long arg)

              ..............

             #ifdef CONFIG_WEXT_CORE
                  if (cmd >= SIOCIWFIRST && cmd <= SIOCIWLAST) {
                     err = dev_ioctl(net, cmd, argp);
                  } else
             #endif

            net/core/dev.c
            dev_ioctl   --->   [net/wireless/wext-core.c] wext_handle_ioctl   --->   wext_ioctl_dispatch   --->   [net/wireless/wext-priv.c] iw_handler_get_private

             if (wrqu->data.length < dev->wireless_handlers->num_private_args)

             ..........

             追踪发现这里判断失败导致问题,向上追其根源:app中 iw_get_ext(skfd, ifname, SIOCGIWPRIV, &wrq)  分配的空间不足导致的问题


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值