爆款云主机2核4G限时秒杀,88元/年起!
查看详情

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
热门活动
  • 618智算钜惠季 爆款云主机2核4G限时秒杀,88元/年起!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 首保服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      windows USB 设备驱动开发-USB复合设备的电源管理

      首页 知识中心 软件开发 文章详情页

      windows USB 设备驱动开发-USB复合设备的电源管理

      2024-09-10 08:20:45 阅读次数:33

      USB,控制器,驱动开发

      通用串行总线 (USB) 3.0 规范定义了一项称为 设备挂起的新功能。 该功能使复合设备的单个功能能够独立于其他功能进入低功耗状态。 考虑一个复合设备,它为键盘定义一个设备,为鼠标定义另一个设备。 用户使键盘功能保持工作状态,但在一段时间内不移动鼠标。 鼠标的客户端驱动程序可以检测设备的空闲状态,并在键盘功能保持工作状态时发送设备挂起状态。

      无论设备中任何功能的电源状态如何,整个设备都可以转换为挂起状态。 如果某个特定设备和整个设备进入挂起状态,则当设备处于挂起状态时,以及在整个设备的暂停进入和退出过程中,设备的挂起状态将保留。

      与 USB 2.0 设备的远程唤醒功能类似,USB 3.0 复合设备中的单个功能可以从低功耗状态唤醒,而不会影响其他功能的电源状态。 此功能称为 设备远程唤醒。 主机通过发送协议请求在设备固件中设置远程唤醒位来显式启用该功能。 此过程称为 支持设备进行远程唤醒。

      如果某个设备已准备好进行远程唤醒,则当处于挂起状态时设备在物理设备上发生用户事件时保留足够的电源来生成唤醒 恢复信号 。 由于该恢复信号,客户端驱动程序随后可以退出关联设备的挂起状态。 在复合设备中的鼠标功能示例中,当用户摆动处于空闲状态的鼠标时,鼠标设备会向主机发送恢复信号。 在主机上,USB 驱动程序堆栈检测哪个设备唤醒,并将通知传播到相应设备的客户端驱动程序。 然后,客户端驱动程序可以唤醒设备并进入工作状态。

      对于客户端驱动程序,发送设备以挂起状态并唤醒设备的步骤类似于将整个设备发送到挂起状态的单设备设备驱动程序。 以下过程总结了这些步骤。

      • 检测关联设备何时处于空闲状态。
      • (IRP) 发送空闲 I/O 请求数据包。
      • 通过 (IRP) 发送等待唤醒 I/O 请求数据包,提交请求以支持其设备进行远程唤醒。
      • 通过将 Dx 电源 IRP (D2 或 D3) 将设备转换为低功耗状态。

      复合驱动程序为复合设备中的每个设备创建一个物理设备对象 (PDO) ,并处理客户端驱动程序 (设备设备堆栈) 的 FDO 发送的电源请求。 为了使客户端驱动程序成功进入和退出其设备的挂起状态,复合驱动程序必须支持设备挂起和远程唤醒功能,并处理收到的电源请求。

      在 Windows 8 中,USB 3.0 设备的 USB 驱动程序堆栈支持这些功能。 此外,设备挂起和设备远程唤醒实现已添加到 Microsoft 提供的 USB 泛型父驱动程序 (Usbccgp.sys,它是Windows 默认复合驱动程序)。 如果要编写自定义复合驱动程序,则驱动程序必须按照以下过程处理与设备挂起和远程唤醒请求相关的请求。

      步骤 1:确定 USB 驱动程序堆栈是否支持功能挂起

      在复合驱动程序的 start-device 例程 (IRP_MN_START_DEVICE) 中,执行以下步骤:

      • 1.调用 USBD_QueryUsbCapability 例程以确定基础 USB 驱动程序堆栈是否支持功能挂起功能。 调用需要你在上一次调用 USBD_CreateHandle 例程中获得的有效 USBD 句柄。成功调用 USBD_QueryUsbCapability 可确定基础 USB 驱动程序堆栈是否支持功能挂起。 调用可能会返回错误代码,指示 USB 驱动程序堆栈不支持功能挂起或连接的设备不是 USB 3.0 多功能设备。
      • 2.如果 USBD_QueryUsbCapability 调用指示支持设备挂起,请将复合设备注册到基础 USB 驱动程序堆栈。 若要注册复合设备,必须发送 IOCTL_INTERNAL_USB_REGISTER_COMPOSITE_DEVICE I/O 控制请求。 
      • 3. 注册请求使用 REGISTER_COMPOSITE_DEVICE 结构来指定有关复合驱动程序的信息。 请确保将 CapabilityFunctionSuspend 设置为 1 以指示复合驱动程序支持设备挂起。
      步骤 2:处理空闲 IRP

      客户端驱动程序可以发送空闲的 IRP, 查看 IOCTL_INTERNAL_USB_SUBMIT_IDLE_NOTIFICATION。 客户端驱动程序检测到设备的空闲状态后发送请求。 IRP 包含指向回调完成例程的指针, 客户端驱动程序实现的称为 空闲回调。 在空闲回调中,客户端在将设备发送到挂起状态之前执行任务,例如取消挂起的 I/O 传输。
       备注

      对于 USB 3.0 设备的客户端驱动程序,空闲 IRP 机制是可选的。 但是,大多数客户端驱动程序都编写为支持 USB 2.0 和 USB 3.0 设备。 若要支持 USB 2.0 设备,驱动程序必须发送空闲 IRP,因为复合驱动程序依赖于该 IRP 来跟踪每个设备的电源状态。 如果所有设备都处于空闲状态,复合驱动程序会将整个设备发送到挂起状态。

      从客户端驱动程序接收空闲 IRP 后,复合驱动程序必须立即调用空闲回调,以通知客户端驱动程序,客户端驱动程序可能会将设备发送到挂起状态。

      步骤 3:发送远程唤醒通知的请求

      客户端驱动程序可以通过提交将次要功能代码设置为 IRP_MN_WAIT_WAKE ( 等待唤醒 IRP) 的IRP_MJ_POWER IRP 来提交请求,以为其设备提供远程唤醒。 仅当驱动程序因用户事件而进入工作状态时,客户端驱动程序才会提交此请求。

      收到等待唤醒 IRP 后,复合驱动程序必须将 IOCTL_INTERNAL_USB_REQUEST_REMOTE_WAKE_NOTIFICATION I/O 控制请求发送到 USB 驱动程序堆栈。 请求使 USB 驱动程序堆栈能够在堆栈收到有关恢复信号的通知时通知复合驱动程序。 IOCTL_INTERNAL_USB_REQUEST_REMOTE_WAKE_NOTIFICATION使用 REQUEST_REMOTE_WAKE_NOTIFICATION 结构来指定请求参数。 复合驱动程序必须指定的值之一是用于远程唤醒的设备的设备句柄。 复合驱动程序在上一个请求中获取该句柄,以将复合设备注册到 USB 驱动程序堆栈。

      在请求的 IRP 中,复合驱动程序提供指向 (远程唤醒) 完成例程的指针,该例程由复合驱动程序实现。

      以下示例代码演示如何发送远程唤醒请求。

      /*++
      
      Description:
          This routine sends a IOCTL_INTERNAL_USB_REQUEST_REMOTE_WAKE_NOTIFICATION request
          to the USB driver stack. The IOCTL is completed by the USB driver stack
          when the function wakes up from sleep.
      
          Parameters:
          parentFdoExt: The device context associated with the FDO for the
          composite driver.
      
          functionPdoExt: The device context associated with the PDO (created by
          the composite driver) for the client driver.
      --*/
      
      VOID
      SendRequestForRemoteWakeNotification(
          __inout PPARENT_FDO_EXT parentFdoExt,
          __inout PFUNCTION_PDO_EXT functionPdoExt
      )
      
      {
          PIRP                                irp;
          REQUEST_REMOTE_WAKE_NOTIFICATION    remoteWake;
          PIO_STACK_LOCATION                  nextStack;
          NTSTATUS                            status;
      
          // Allocate an IRP
          irp =  IoAllocateIrp(parentFdoExt->topDevObj->StackSize, FALSE);
      
          if (irp)
          {
      
              //Initialize the USBDEVICE_REMOTE_WAKE_NOTIFICATION structure
              remoteWake.Version = 0;
              remoteWake.Size = sizeof(REQUEST_REMOTE_WAKE_NOTIFICATION);
              remoteWake.UsbdFunctionHandle = functionPdoExt->functionHandle;
              remoteWake.Interface = functionPdoExt->baseInterfaceNumber;
      
              nextStack = IoGetNextIrpStackLocation(irp);
      
              nextStack->MajorFunction = IRP_MJ_INTERNAL_DEVICE_CONTROL;
              nextStack->Parameters.DeviceIoControl.IoControlCode = IOCTL_INTERNAL_USB_REQUEST_REMOTE_WAKE_NOTIFICATION;
      
              nextStack->Parameters.Others.Argument1 = &remoteWake;
      
              // Caller's completion routine will free the IRP when it completes.
      
              SetCompletionRoutine(functionPdoExt->debugLog,
                                   parentFdoExt->fdo,
                                   irp,
                                   CompletionRemoteWakeNotication,
                                   (PVOID)functionPdoExt,
                                   TRUE, TRUE, TRUE);
      
              // Pass the IRP
              IoCallDriver(parentFdoExt->topDevObj, irp);
      
          }
      
          return;
      }

      IOCTL_INTERNAL_USB_REQUEST_REMOTE_WAKE_NOTIFICATION请求在唤醒过程中由 USB 驱动程序堆栈完成,当它收到有关恢复信号的通知时。 在此期间,USB 驱动程序堆栈还会调用远程唤醒完成例程。

      复合驱动程序必须使等待-唤醒 IRP 保持挂起状态,并将其排队以供以后处理。 当 USB 驱动程序堆栈调用驱动程序的远程唤醒完成例程时,复合驱动程序必须完成该 IRP。

      步骤 4:发送请求以支持子设备进行远程唤醒

      若要将设备发送到低功耗状态,客户端驱动程序会提交 IRP_MN_SET_POWER IRP,请求将 Windows 驱动程序模型 (WDM) 设备电源状态更改为 D2 或 D3。 通常,如果驱动程序提前发送等待唤醒 IRP 以请求远程唤醒,则客户端驱动程序会发送 D2 IRP。 否则,客户端驱动程序会发送 D3 IRP。

      收到 D2 IRP 后,复合驱动程序必须首先确定等待唤醒 IRP 是否正在等待客户端驱动程序发送的请求。 如果该 IRP 处于挂起状态,则复合驱动程序必须支持设备进行远程唤醒。 为此,复合驱动程序必须将SET_FEATURE控制请求发送到设备的第一个接口,使设备能够发送恢复信号。 若要发送控制请求,请通过调用 USBD_UrbAllocate 例程来分配 URB 结构,并调用 UsbBuildFeatureRequest 宏以格式化SET_FEATURE请求的 URB。 在调用中,将 URB_FUNCTION_SET_FEATURE_TO_INTERFACE 指定为操作代码,将 USB_FEATURE_FUNCTION_SUSPEND 指定为功能选择器。 在 Index 参数中,设置最有效字节的 位 1 。 该值将复制到传输的设置数据包中的 wIndex 字段。

      以下示例演示如何发送SET_FEATURE控制请求。

      /*++
      
      Routine Description:
      
      Sends a SET_FEATURE for REMOTE_WAKEUP to the device using a standard control request.
      
      Parameters:
      parentFdoExt: The device context associated with the FDO for the
      composite driver.
      
      functionPdoExt: The device context associated with the PDO (created by
      the composite driver) for the client driver.
      
      Returns:
      
      NTSTATUS code.
      
      --*/
      VOID
          NTSTATUS SendSetFeatureControlRequestToSuspend(
          __inout PPARENT_FDO_EXT parentFdoExt,
          __inout PFUNCTION_PDO_EXT functionPdoExt,
          )
      
      {
          PURB                            urb
          PIRP                            irp;
          PIO_STACK_LOCATION              nextStack;
          NTSTATUS                        status;
      
          status = USBD_UrbAllocate(parentFdoExt->usbdHandle, &urb);
      
          if (!NT_SUCCESS(status))
          {
              //USBD_UrbAllocate failed.
              goto Exit;
          }
      
          //Format the URB structure.
          UsbBuildFeatureRequest (
              urb,
              URB_FUNCTION_SET_FEATURE_TO_INTERFACE, // Operation code
              USB_FEATURE_FUNCTION_SUSPEND,          // feature selector
              functionPdoExt->firstInterface,           // first interface of the function
              NULL);
      
          irp =  IoAllocateIrp(parentFdoExt->topDevObj->StackSize, FALSE);
      
          if (!irp)
          {
              // IoAllocateIrp failed.
              status = STATUS_INSUFFICIENT_RESOURCES;
      
              goto Exit;
          }
      
          nextStack = IoGetNextIrpStackLocation(irp);
      
          nextStack->MajorFunction = IRP_MJ_INTERNAL_DEVICE_CONTROL;
      
          nextStack->Parameters.DeviceIoControl.IoControlCode = IOCTL_INTERNAL_USB_SUBMIT_URB;
      
          //  Attach the URB to the IRP.
          USBD_AssignUrbToIoStackLocation(nextStack, (PURB)urb);
      
          // Caller's completion routine will free the IRP when it completes.
          SetCompletionRoutine(functionPdoExt->debugLog,
              parentFdoExt->fdo,
              irp,
              CompletionForSuspendControlRequest,
              (PVOID)functionPdoExt,
              TRUE, TRUE, TRUE);
      
      
          // Pass the IRP
          IoCallDriver(parentFdoExt->topDevObj, irp);
      
      
      Exit:
          if (urb)
          {
              USBD_UrbFree( parentFdoExt->usbdHandle, urb);
          }
      
          return status;
      
      }

      然后,复合驱动程序将 D2 IRP 向下发送到 USB 驱动程序堆栈。 如果所有其他设备都处于挂起状态,USB 驱动程序堆栈将通过操作控制器上的某些端口寄存器来挂起端口。

      在鼠标功能示例中,由于远程唤醒功能已启用 (请参阅步骤 4) ,因此当用户摆动鼠标时,鼠标设备会在上游主控制器的线路上生成恢复信号。 然后,控制器通过发送包含唤醒设备相关信息的通知数据包来通知 USB 驱动程序堆栈。 

      收到通知数据包后,USB 驱动程序堆栈将完成挂起 的IOCTL_INTERNAL_USB_REQUEST_REMOTE_WAKE_NOTIFICATION 请求 (请参阅步骤 3) ,并调用 (请求中指定的并由复合驱动程序实现的远程唤醒) 完成回调例程。 当通知到达复合驱动程序时,它会通过完成客户端驱动程序先前发送的等待唤醒 IRP,通知相应的客户端驱动程序设备已进入工作状态。

      在 远程唤醒完成例程中,复合驱动程序应将工作项排队以完成挂起的等待唤醒 IRP。 对于 USB 3.0 设备,复合驱动程序仅唤醒发送恢复信号的设备,并使其他设备处于挂起状态。 对工作项进行排队可确保与 USB 2.0 设备的功能驱动程序的现有实现兼容。

      工作线程完成等待-唤醒 IRP 并调用客户端驱动程序的完成例程。 然后,完成例程发送 D0 IRP 以进入工作状态的设备。 在完成等待-唤醒 IRP 之前,复合驱动程序应调用 PoSetSystemWake ,将等待唤醒 IRP 标记为导致系统从挂起状态中唤醒的 IRP。 Power Manager 记录 Windows (ETW) 事件跟踪, (全局系统通道) 中查看,其中包含有关唤醒系统的设备的信息。

      USB 设备的远程唤醒

      在暂停时可以响应外部唤醒信号的 USB 设备据说具有 远程唤醒 功能。 具有远程唤醒功能的设备示例包括鼠标、键盘、USB 集线器、调制解调器 (环形唤醒) 、NIC、电缆插入唤醒。 所有这些设备都能够生成远程唤醒信号。 无法生成远程唤醒信号的设备包括摄像机、大容量存储设备、音频设备和打印机。

      支持远程唤醒信号的设备驱动程序必须发出 IRP_MN_WAIT_WAKE IRP(也称为等待唤醒 IRP)来支持设备进行远程唤醒。 支持具有 Wake-Up 功能的设备部分中介绍了等待唤醒机制。

      USB 设备上的远程唤醒

      在 USB 术语中,设置 USB 设备DEVICE_REMOTE_WAKEUP功能时,会启用远程唤醒。 USB 规范指定主机软件必须在“仅在将设备置于睡眠状态之前”设备上设置远程唤醒功能。

      因此,在收到设备的等待唤醒 IRP 后,USB 堆栈不会在设备上设置DEVICE_REMOTE_WAKEUP功能。 相反,它会等待,直到收到 IRP_MN_SET_POWER 请求,将设备的 WDM 设备状态更改为 D1/D2。 在大多数情况下,当 USB 堆栈收到此请求时,它会在设备上设置远程唤醒功能,并通过暂停设备的上游端口使设备进入睡眠状态。 设计和调试驱动程序时,应记住,通过等待唤醒 IRP 在软件中为 USB 设备提供唤醒与通过设置远程唤醒功能在硬件中为设备提供唤醒之间存在着松散的关系。

      当收到将设备更改为 D3 睡眠状态的请求时,USB 堆栈不会为设备启用远程唤醒,因为根据 WDM 电源模型,D3 中的设备无法唤醒系统。

      连接或分离 USB 设备时的唤醒行为

      WDM 电源模式的 USB 实现的另一个独特方面是连接 USB 集线器以便进行远程唤醒。 如果总线上的 USB 叶设备用于唤醒,则 USB 堆栈还会为 USB 主机控制器提供唤醒的支持,但它不一定将任何 USB 集线器上游设备支持。 仅当 USB 堆栈配置为在连接时唤醒系统并分离 (插头/拔出) 事件时,USB 集线器驱动程序才会为集线器提供远程唤醒。

      UHCI) USB 主机控制器 (通用主机控制器接口不区分根集线器端口上的远程唤醒信号和连接更改事件。 这意味着,当 USB 设备连接到根集线器端口或从根集线器端口断开连接时,如果 UHCI 控制器后面至少有一个设备用于唤醒,系统将始终从低系统电源状态唤醒。

      版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://blog.csdn.net/m0_72813396/article/details/140255216,作者:sului,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

      上一篇:windows USB 设备驱动开发-开发Type C接口的驱动程序(一)

      下一篇:windows USB 设备驱动开发-USB电源管理(三)

      相关文章

      2025-05-07 09:08:54

      【网络】数据流(Data Workflow)Routes(路由)、Controllers(控制器)、Models(模型) 和 Middleware(中间件)

      在图片中,数据流(Data Workflow)描述了应用程序中数据的流动过程,涉及 Routes(路由)、Controllers(控制器)、Models(模型) 和 Middleware(中间件)。作为初学者,理解这些组件及其联系是掌握 Web 应用程序开发的关键。

      2025-05-07 09:08:54
      中间件 , 定义 , 控制器 , 请求 , 路由
      2025-04-15 09:24:56

      深入Kafka:如何保证数据一致性与可靠性?

      幂等性是一个非常重要的概念,特别是在分布式系统中。简单来说,幂等性就是保证在消息重发时,消费者不会重复处理,即使在消费者收到重复消息时,重复处理也要保证最终结果的一致性。

      2025-04-15 09:24:56
      Kafka , Leader , Zookeeper , 控制器 , 消息
      2025-04-09 09:13:17

      单片机基础1:串口与蓝牙和Python相连

      单片机基础1:串口与蓝牙和Python相连

      2025-04-09 09:13:17
      USB , 单片机 , 换行
      2025-03-24 08:45:46

      Android 判断是否有可用摄像头(前置,后置,USB外接)

      Android 判断是否有可用摄像头(前置,后置,USB外接)

      2025-03-24 08:45:46
      Android , Java , kotlin , USB
      2025-02-11 09:38:01

      初始Java篇(JavaSE基础语法)(7)抽象类和接口(上)

      在面向对象的概念中,所有的对象都是通过类来描绘的,但是反过来,并不是所有的类都是用来描绘对象的,如果一个类中没有包含足够的信息来描绘一个具体的对象,这样的类就是抽象类。

      2025-02-11 09:38:01
      USB , 子类 , 抽象 , 抽象类 , 接口 , 方法
      2025-01-06 08:42:49

      深入解析MVC架构(Model-View-Controller Architecture)

      MVC架构是一种用于构建用户界面的软件设计模式,最早在1970年代由Trygve Reenskaug提出。该模式将系统划分为三个主要部分:模型(Model)、视图(View)和控制器(Controller)。这种分离的方式旨在提高代码的模块化程度,促进代码的重用和维护。

      2025-01-06 08:42:49
      MVC , 展示 , 控制器 , 架构 , 模型 , 用户 , 视图
      2024-12-24 10:25:10

      文件系统和I/O设备管理

      文件系统实现文件的“按名存取”是通过文件系统中的目录结构和文件控制块来实现的。

      2024-12-24 10:25:10
      控制器 , 文件 , 文件系统 , 设备
      2024-12-20 07:55:40

      mvc模式详解

      MVC 模式是一种软件设计模式,它将应用程序分为三个主要组件:模型(Model)、视图(View)、控制器(Controller)。每个组件负责不同的职责,实现了代码的分层和解耦,使得系统更易于维护和扩展。

      2024-12-20 07:55:40
      MVC , 应用程序 , 控制器 , 模型 , 模式 , 组件 , 视图
      2024-12-05 08:50:14

      Linux内核源码-USB驱动分析

      通用串行总线(USB)主要用于连接主机和外部设备(协调主机和设备之间的通讯),USB 设备不能主动向主机发送数据。USB 总线采用拓扑(树形),主机侧和设备侧的 USB 控制器(Host 和 UDC),每个总线只要一个主机控制器。

      2024-12-05 08:50:14
      struct , USB , 主机 , 控制器 , 源码 , 设备
      2024-12-05 08:50:06

      Linux源码阅读笔记-USB设备驱动架构

      USB系统主机端提供为4个引脚的A型接口,USB外围设备通过4个引脚的B型接口和主机端连接。那4个引脚(一条电压线VBUS、一条地线GND、一条正方向传输数据的D+和一条反方向传输数据的D-线。)USB主机和USB设备收发器可以采用相同型号的芯片。

      2024-12-05 08:50:06
      USB , 传输 , 引脚 , 模式 , 端点 , 视图 , 设备
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5246564

      查看更多

      最新文章

      单片机基础1:串口与蓝牙和Python相连

      2025-04-09 09:13:17

      Android 判断是否有可用摄像头(前置,后置,USB外接)

      2025-03-24 08:45:46

      初始Java篇(JavaSE基础语法)(7)抽象类和接口(上)

      2025-02-11 09:38:01

      mvc模式详解

      2024-12-20 07:55:40

      Linux内核源码-USB驱动分析

      2024-12-05 08:50:14

      Linux源码阅读笔记-USB设备驱动架构

      2024-12-05 08:50:06

      查看更多

      热门文章

      【ASP.NET Core】MVC操作方法如何绑定Stream类型的参数

      2023-06-21 06:41:05

      可维护性高、可视化的自动化测试平台哪里找?试试Apipost

      2024-03-18 08:30:50

      驱动开发:内核CR3切换读写内存

      2023-05-04 09:00:09

      驱动开发:内核读取SSDT表基址

      2023-05-04 09:00:09

      windows USB 设备驱动程序开发-USB 设备模拟 (一)

      2024-09-10 08:20:45

      windows USB 设备驱动开发-USB 功能控制器驱动开发(一)

      2024-09-10 08:20:45

      查看更多

      热门标签

      java Java python 编程开发 代码 开发语言 算法 线程 Python html 数组 C++ 元素 javascript c++
      查看更多

      相关产品

      弹性云主机

      随时自助获取、弹性伸缩的云服务器资源

      天翼云电脑(公众版)

      便捷、安全、高效的云电脑服务

      对象存储

      高品质、低成本的云上存储服务

      云硬盘

      为云上计算资源提供持久性块存储

      查看更多

      随机文章

      windows USB 设备驱动开发-处理批传输的静态流

      windows USB设备驱动开发-开发USB 设备端驱动

      windows USB 设备驱动开发- 不同模型下的控制传输

      windows USB 设备驱动开发-USB带宽

      驱动开发:内核读取SSDT表基址

      windows USB设备驱动开发-双角色驱动

      • 7*24小时售后
      • 无忧退款
      • 免费备案
      • 专家服务
      售前咨询热线
      400-810-9889转1
      关注天翼云
      • 旗舰店
      • 天翼云APP
      • 天翼云微信公众号
      服务与支持
      • 备案中心
      • 售前咨询
      • 智能客服
      • 自助服务
      • 工单管理
      • 客户公告
      • 涉诈举报
      账户管理
      • 管理中心
      • 订单管理
      • 余额管理
      • 发票管理
      • 充值汇款
      • 续费管理
      快速入口
      • 天翼云旗舰店
      • 文档中心
      • 最新活动
      • 免费试用
      • 信任中心
      • 天翼云学堂
      云网生态
      • 甄选商城
      • 渠道合作
      • 云市场合作
      了解天翼云
      • 关于天翼云
      • 天翼云APP
      • 服务案例
      • 新闻资讯
      • 联系我们
      热门产品
      • 云电脑
      • 弹性云主机
      • 云电脑政企版
      • 天翼云手机
      • 云数据库
      • 对象存储
      • 云硬盘
      • Web应用防火墙
      • 服务器安全卫士
      • CDN加速
      热门推荐
      • 云服务备份
      • 边缘安全加速平台
      • 全站加速
      • 安全加速
      • 云服务器
      • 云主机
      • 智能边缘云
      • 应用编排服务
      • 微服务引擎
      • 共享流量包
      更多推荐
      • web应用防火墙
      • 密钥管理
      • 等保咨询
      • 安全专区
      • 应用运维管理
      • 云日志服务
      • 文档数据库服务
      • 云搜索服务
      • 数据湖探索
      • 数据仓库服务
      友情链接
      • 中国电信集团
      • 189邮箱
      • 天翼企业云盘
      • 天翼云盘
      ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
      公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
      • 用户协议
      • 隐私政策
      • 个人信息保护
      • 法律声明
      备案 京公网安备11010802043424号 京ICP备 2021034386号