AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 691286
Accepted
rur2641
rur2641
Asked: 2022-02-19 15:37:05 +0800 CST2022-02-19 15:37:05 +0800 CST 2022-02-19 15:37:05 +0800 CST

为什么 usb_control_msg 需要 0.25 秒才能完成

  • 772

我正在通过调用向 USB 设备发送同步控制消息usb_control_msg。完成需要 0.25 秒。这是正常的/预期的吗?USB 端口为 USB 3.0。该器件是赛普拉斯 FX3 模块。对 Windows 系统(相同端口、设备、FX3 固件)进行的类似测试在更短的时间内返回每条消息。在 Linux 中,我注意到发送的第一条消息需要 10 微秒才能完成,而接下来的 19 条左右则需要 0.25 秒才能完成。还有另一条消息会很快完成,然后是另外 19 条左右的消息会很慢。此外,我无法发送设置数据长度超过 8 个字节的控制消息。我将尝试实现异步消息,但最好知道是否可以针对同步调用改进这种行为。

ktime_t start_time = ktime_get();
int ret = usb_control_msg(device, usb_sndctrlpipe(device, 0), 0, 0x40, 0, 0, &command_data_payload, 8, 5000);

if (ret < 0)
   printk(KERN_ERR "Messaged failed: %d\n", ret);
else
   printk("message took: %llu\n", ktime_get() - message_start_time);

更正:我不知道我在比较中使用的 Windows 应用程序是使用同步调用还是异步调用。我一定会尝试使用异步调用来实现测试。

更新:使用异步调用,消息发送得更快,但调用完成回调仍需要 0.25 秒。对于按顺序发送的 20 条消息,其中 1 条在很短的时间内完成,其他的则每条耗时 0.25 秒。可能延迟是 FX3 USB 设备模块的功能。此外,在 Windows 上仔细检查后,消息也大多需要 0.25 秒才能完成,其中一些完成得更快。

kernel usb
  • 1 1 个回答
  • 26 Views

1 个回答

  • Voted
  1. Best Answer
    rur2641
    2022-02-25T15:17:55+08:002022-02-25T15:17:55+08:00

    我猜是因为异步消息是按顺序发送的,很快就出去了,但是完成回调和来自 USB 设备的响应仍然需要 0.25 秒才能发生,延迟是因为赛普拉斯 FX3 模块。我还包括异步消息的代码。

    static struct usb_ctrlrequest ctrl_request;
    static ktime_t last_time = 0;
    
    static void write_control_callback(struct urb *urb)
    {
       ktime_t now_time = ktime_get();
       if (last_time != 0)
           printk("skel_write_bulk_callback: %llu\n", now_time - last_time);
       last_time = now_time;
    }
    
    static long send_command(uint8_t * command_data_payload)
    {
       int ret;
       struct urb * cUrb;
       void * buf;
    
       cUrb = usb_alloc_urb(0, GFP_KERNEL);
       if (!cUrb)
          return 1;
    
       buf = usb_alloc_coherent(device, 32, GFP_KERNEL, &cUrb->transfer_dma);
       if (!buf)
          return 1;
    
       memcpy(buf, command_data_payload, 32);  
    
       ctrl_request.bRequest = 0;
       ctrl_request.bRequestType = 0x40;
       ctrl_request.wValue = 0;
       ctrl_request.wIndex = 0;
       ctrl_request.wLength = 32;
    
       usb_fill_control_urb(cUrb, device, usb_sndctrlpipe(device, 0), (unsigned char*)(&ctrl_request),
    buf, 32, skel_write_bulk_callback, NULL);
    
       ret = usb_submit_urb(cUrb, GFP_KERNEL);
       if (ret)
          printk("could not submit urb\n");
    }
    

    警告!!!:我没有在这段代码中正确释放分配的缓冲区。

    • 0

相关问题

  • Linux Mint 内核损坏

  • 将 USBIP 用于正在移除和重新连接的设备

  • Linux 内核开发人员如何处理数百万行代码的工作?他们是一种方法吗?[关闭]

  • 通过标签将根文件系统传递给linux内核

  • 以 root 用户身份访问文件系统

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve