爆款云主机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 设备驱动开发- 不同模型下的控制传输

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

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

      2024-09-10 08:20:51 阅读次数:38

      USB,设备,驱动开发

      在不同的模型下,USB控制传输会有不同的特点,但是任何控制传输的目标都始终是默认端点。 接收者是设备的实体,其信息(描述符、状态等)是主机感兴趣的。请求可进一步分为:配置请求、功能请求和状态请求。

      发送配置请求以从设备获取信息,以便主机可以对其进行配置,例如GET_DESCRIPTOR请求。 这些请求也可能是主机发送的写入请求,目的是在设备中设置特定的配置或备用设置。
      客户端驱动程序发送功能请求以启用或禁用设备、接口或端点支持的某些布尔设备设置。
      状态请求 使主机能够获取或设置设备、端点或接口的 USB 定义状态位。

      下面我们借助代码来仔细分析一下:

      驱动程序模型

      下面是三种常见的驱动模式

      • 内核模式驱动程序框架
      • 用户模式驱动程序框架
      • WinUSB
      前提条件

      在客户端驱动程序能够枚举管道之前,请确保客户端驱动程序必须已创建框架 USB 目标设备对象。

      注意如果使用 Microsoft Visual Studio Professional 2012 随附的 USB 模板,则模板代码会执行这些任务。 模板代码会获取目标设备对象的句柄并将其存储在设备上下文中。

      KMDF 客户端驱动程序:KMDF 客户端驱动程序必须调用 WdfUsbTargetDeviceCreateWithParameters 方法来获取 WDFUSBDEVICE 句柄。

      UMDF 客户端驱动程序:UMDF 客户端驱动程序必须通过查询框架目标设备对象获取 IWDFUsbTargetDevice 指针。 

      控制传输最重要的方面是正确设置设置令牌的格式。 在发送请求之前,请收集以下信息集:

      • 请求的方向:从主机到设备,或者从设备到主机;
      • 请求的接收者:设备、接口、端点或其他;
      • 请求的类别:标准、类或供应商;可以从官方的 USB 规范中获取所有此类信息;
      • 请求的类型,例如 GET_DESCRIPTPOR 请求。 有关详细信息,请参阅 USB 规范中的 9.5 节;
      • wValue 和 wIndex 值。 这些值取决于请求的类型;

      所有 UMDF 驱动程序必须与内核模式驱动程序通信才能通过设备发送和接收数据。 对于 USB UMDF 驱动程序,内核模式驱动程序始终是 Microsoft 提供的驱动程序 WinUSB (Winusb.sys)。

      每当 UMDF 启动程序针对 USB 驱动程序堆栈发出请求时,Windows I/O 管理器就会将该请求发送给 WinUSB。 收到请求后,WinUSB 会处理请求,或者将其转发给 USB 驱动程序堆栈。

      Microsoft 定义的用于发送控制传输请求的方法

      主机上的 USB 客户端驱动程序启动的大多数控制请求是用于获取有关设备的信息、配置设备或发送供应商控制命令。 所有这些请求可以分为以下类别:

      • 标准请求 在 USB 规范中定义。 发送标准请求的目的是获取有关设备、其配置、接口和端点的信息。 每个请求的接收者取决于请求的类型。 接收方可以是设备、接口或端点;
      • 类请求 由特定的设备类规范定义;
      • 供应商请求 由供应商提供,取决于设备支持的请求;

      Microsoft 提供的 USB 堆栈处理与设备进行的所有协议通信,如前面的跟踪所示。 此驱动程序会公开设备驱动程序接口 (DDI),后者允许客户端驱动程序以多种方式发送控制传输。 如果客户端驱动程序是 Windows Driver Foundation (WDF) 驱动程序,则它可以直接调用例程来发送常见类型的控制请求。 WDF 本质上支持 KMDF 和 UMDF 的控制传输。

      某些类型的控制请求不通过 WDF 公开。 对于这些请求,客户端驱动程序可以使用 WDF 混合模型。 此模型允许客户端驱动程序构建 WDM URB 样式的请求并设置其格式,然后使用 WDF 框架对象发送这些请求。 混合模型仅适用于内核模式驱动程序。

      UMDF 驱动程序

      请使用下表来确定向 USB 驱动程序堆栈发送控制请求的最佳方式。 

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

      KMDF发送供应商控制传输 -

      以下过程演示了客户端驱动程序如何发送控制传输。 在此示例中,客户端驱动程序发送一个从设备检索固件版本的供应商命令。

      1.声明一个用于供应商命令的常量。 研究硬件规范,确定要使用的供应商命令。

      2.通过调用 WDF_MEMORY_DESCRIPTOR_INIT_BUFFER 宏来声明 WDF_MEMORY_DESCRIPTOR 结构并将其初始化。 此结构会在 USB 驱动程序完成请求后从设备接收响应。

      3.指定发送选项,具体取决于你是以同步方式还是异步方式发送请求:

      • 如果通过调用 WdfUsbTargetDeviceSendControlTransferSynchronously 以同步方式发送请求,请指定超时值。 该值很重要,因为如果没有超时值,则可能无限期阻止线程。

      为此,请通过调用 WDF_REQUEST_SEND_OPTIONS_INIT 宏声明 WDF_REQUEST_SEND_OPTIONS 结构并将其初始化。 将该选项指定为 WDF_REQUEST_SEND_OPTION_TIMEOUT。

      接下来,通过调用 WDF_REQUEST_SEND_OPTIONS_SET_TIMEOUT 宏设置超时值。

      • 如果以异步方式发送请求,请实施一个完成例程。 释放完成例程中所有分配的资源。

      4.声明一个 WDF_USB_CONTROL_SETUP_PACKET 结构,使之包含设置令牌,然后将结构格式化。 为此,请调用 WDF_USB_CONTROL_SETUP_PACKET_INIT_VENDOR 宏来格式化设置数据包。 在调用中指定请求的方向、接收者、发送-请求选项(已在步骤 3 中初始化)以及供应商命令的常量。

      5.通过调用 WdfUsbTargetDeviceSendControlTransferSynchronously 或 WdfUsbTargetDeviceFormatRequestForControlTransfer 来发送请求。

      6.检查框架返回的 NTSTATUS 值,并检查接收的值。

      以下代码示例将控制传输请求发送到 USB 设备,以便检索其固件版本。 请求以异步方式发送,客户端驱动程序指定一个 5 秒的相对超时值(以 100 纳秒为单位)。 驱动程序将接收的响应存储在驱动程序定义的设备上下文中。

      enum {
          USBFX2_GET_FIRMWARE_VERSION = 0x1,
      ....
      
      } USBFX2_VENDOR_COMMANDS; 
      
      #define WDF_TIMEOUT_TO_SEC              ((LONGLONG) 1 * 10 * 1000 * 1000)  // defined in wdfcore.h
      
      const __declspec(selectany) LONGLONG
                  DEFAULT_CONTROL_TRANSFER_TIMEOUT = 5 * -1 * WDF_TIMEOUT_TO_SEC; 
      
      
      typedef struct _DEVICE_CONTEXT
      {
      
          ...
             union {
              USHORT      VersionAsUshort;
              struct {
                  BYTE Minor;
                  BYTE Major;
              } Version;
          } Firmware; // Firmware version.
      
      } DEVICE_CONTEXT, *PDEVICE_CONTEXT;
      
      
      __drv_requiresIRQL(PASSIVE_LEVEL)
      VOID  GetFirmwareVersion(
          __in PDEVICE_CONTEXT DeviceContext
      )
      {
          NTSTATUS                        status;
          WDF_USB_CONTROL_SETUP_PACKET    controlSetupPacket;
          WDF_REQUEST_SEND_OPTIONS        sendOptions;
          USHORT                          firmwareVersion;
          WDF_MEMORY_DESCRIPTOR           memoryDescriptor;
      
          PAGED_CODE();
      
          firmwareVersion = 0;
      
          WDF_MEMORY_DESCRIPTOR_INIT_BUFFER(&memoryDescriptor, (PVOID) &firmwareVersion, sizeof(firmwareVersion));
      
          WDF_REQUEST_SEND_OPTIONS_INIT(
                                        &sendOptions,
                                        WDF_REQUEST_SEND_OPTION_TIMEOUT
                                        );
      
          WDF_REQUEST_SEND_OPTIONS_SET_TIMEOUT(
                                               &sendOptions,
                                               DEFAULT_CONTROL_TRANSFER_TIMEOUT
                                               );
      
          WDF_USB_CONTROL_SETUP_PACKET_INIT_VENDOR(&controlSetupPacket,
                                              BmRequestDeviceToHost,       // Direction of the request
                                              BmRequestToDevice,           // Recipient
                                              USBFX2_GET_FIRMWARE_VERSION, // Vendor command
                                              0,                           // Value
                                              0);                          // Index 
      
          status = WdfUsbTargetDeviceSendControlTransferSynchronously(
                                              DeviceContext->UsbDevice,
                                              WDF_NO_HANDLE,               // Optional WDFREQUEST
                                              &sendOptions,
                                              &controlSetupPacket,
                                              &memoryDescriptor,           // MemoryDescriptor
                                              NULL);                       // BytesTransferred 
      
          if (!NT_SUCCESS(status)) 
          {
              KdPrint(("Device %d: Failed to get device firmware version 0x%x\n", DeviceContext->DeviceNumber, status));
              TraceEvents(DeviceContext->DebugLog,
                          TRACE_LEVEL_ERROR,
                          DBG_RUN,
                          "Device %d: Failed to get device firmware version 0x%x\n",
                          DeviceContext->DeviceNumber,
                          status);
          }
          else 
          {
              DeviceContext->Firmware.VersionAsUshort = firmwareVersion;
              TraceEvents(DeviceContext->DebugLog,
                          TRACE_LEVEL_INFORMATION,
                          DBG_RUN,
                          "Device %d: Get device firmware version : 0x%x\n",
                          DeviceContext->DeviceNumber,
                          firmwareVersion);
          }
      
          return;
      }

      UMDF发送 GET_STATUS 的控制传输 -

      以下过程演示了客户端驱动程序如何发送 GET_STATUS 命令的控制传输。 请求的接收者为设备,请求获取 D1-D0 位中的信息。 

      • 包括随附在 OSR USB Fx2 学习工具包的 UMDF 示例驱动程序中的头文件 Usb_hw.h;
      • 声明 WINUSB_CONTROL_SETUP_PACKET 结构;
      • 通过调用帮助器宏 WINUSB_CONTROL_SETUP_PACKET_INIT_GET_STATUS 来初始化设置数据包;
      • 指定 BmRequestToDevice 作为接收者;
      • 在 Index 值中指定 0;
      • 调用帮助器方法 SendControlTransferSynchronously,以同步方式发送请求。此帮助器方法通过调用 IWDFUsbTargetDevice::FormatRequestForControlTransfer 方法将初始化的设置数据包与框架请求对象和传输缓冲区相关联,以这种方式构建请求。 然后,此帮助器方法通过调用 IWDFIoRequest::Send 方法来发送请求。 在此方法返回后,检查返回的值;
      • 若要确定状态指示自驱动还是远程唤醒,请使用 WINUSB_DEVICE_TRAITS 枚举中定义的以下值;

      以下代码示例通过发送控制传输请求来获取设备的状态。 此示例通过调用名为 SendControlTransferSynchronously 的帮助器方法以异步方式发送请求。

      HRESULT
      CDevice::GetDeviceStatus ()
      {
      
          HRESULT hr = S_OK;
      
          USHORT deviceStatus;
          ULONG bytesTransferred;
      
          TraceEvents(TRACE_LEVEL_INFORMATION,
                      DRIVER_ALL_INFO,
                      "%!FUNC!: entry");
      
          // Setup the control packet.
      
          WINUSB_CONTROL_SETUP_PACKET setupPacket;
      
          WINUSB_CONTROL_SETUP_PACKET_INIT_GET_STATUS(
                                            &setupPacket,
                                            BmRequestToDevice,
                                            0);
      
          hr = SendControlTransferSynchronously(
                       &(setupPacket.WinUsb),
                       & deviceStatus,
                       sizeof(USHORT),
                       &bytesReturned
                      );
      
           if (SUCCEEDED(hr))
          {
              if (deviceStatus & USB_GETSTATUS_SELF_POWERED)
              {
                   m_Self_Powered = true;
              } 
              if (deviceStatus & USB_GETSTATUS_REMOTE_WAKEUP_ENABLED)
              {
                   m_remote_wake-enabled = true;
              }
          }
      
          return hr;
       }


      以下代码示例演示了如何实现名为 SendControlTransferSynchronously 的帮助器方法。 此方法以异步方式发送请求。

      HRESULT
      CDevice::SendControlTransferSynchronously(
          _In_ PWINUSB_SETUP_PACKET SetupPacket,
          _Inout_ PBYTE Buffer,
          _In_ ULONG BufferLength,
          _Out_ PULONG LengthTransferred
          )
      {
          HRESULT hr = S_OK;
          IWDFIoRequest *pWdfRequest = NULL;
          IWDFDriver * FxDriver = NULL;
          IWDFMemory * FxMemory = NULL;
          IWDFRequestCompletionParams * FxComplParams = NULL;
          IWDFUsbRequestCompletionParams * FxUsbComplParams = NULL;
      
          *LengthTransferred = 0;
      
          hr = m_FxDevice->CreateRequest( NULL, //pCallbackInterface
                                          NULL, //pParentObject
                                          &pWdfRequest);
      
          if (SUCCEEDED(hr))
          {
              m_FxDevice->GetDriver(&FxDriver);
      
              hr = FxDriver->CreatePreallocatedWdfMemory( Buffer,
                                                          BufferLength,
                                                          NULL,        //pCallbackInterface
                                                          pWdfRequest, //pParetObject
                                                          &FxMemory );
          }
      
          if (SUCCEEDED(hr))
          {
              hr = m_pIUsbTargetDevice->FormatRequestForControlTransfer( pWdfRequest,
                                                                         SetupPacket,
                                                                         FxMemory,
                                                                         NULL); //TransferOffset
          }
      
          if (SUCCEEDED(hr))
          {
              hr = pWdfRequest->Send( m_pIUsbTargetDevice,
                                      WDF_REQUEST_SEND_OPTION_SYNCHRONOUS,
                                      0); //Timeout
          }
      
          if (SUCCEEDED(hr))
          {
              pWdfRequest->GetCompletionParams(&FxComplParams);
      
              hr = FxComplParams->GetCompletionStatus();
          }
      
          if (SUCCEEDED(hr))
          {
              HRESULT hrQI = FxComplParams->QueryInterface(IID_PPV_ARGS(&FxUsbComplParams));
              WUDF_TEST_DRIVER_ASSERT(SUCCEEDED(hrQI));
      
              WUDF_TEST_DRIVER_ASSERT( WdfUsbRequestTypeDeviceControlTransfer ==
                                  FxUsbComplParams->GetCompletedUsbRequestType() );
      
              FxUsbComplParams->GetDeviceControlTransferParameters( NULL,
                                                                   LengthTransferred,
                                                                   NULL,
                                                                   NULL );
          }
      
          SAFE_RELEASE(FxUsbComplParams);
          SAFE_RELEASE(FxComplParams);
          SAFE_RELEASE(FxMemory);
      
          pWdfRequest->DeleteWdfObject(); 
          SAFE_RELEASE(pWdfRequest);
      
          SAFE_RELEASE(FxDriver);
      
          return hr;
      }

      如果使用 Winusb.sys 作为设备的功能驱动程序,则可从应用程序发送控制传输。 若要在 WinUSB 中设置设置数据包的格式,请使用本文中所述的 UMDF 帮助程序宏和结构。 若要发送请求,请调用 WinUsb_ControlTransfer 函数。

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

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

      下一篇:windows USB 驱动开发-URB结构

      相关文章

      2025-05-14 10:03:13

      arm架构下JAVA开发

      ARM(Advanced RISC Machine)是一种基于精简指令集计算(RISC)设计的处理器架构。它以高效、节能著称,因此广泛应用 于从智能手机到物联网设备的各个领域。

      2025-05-14 10:03:13
      Java , JVM , 嵌入式 , 架构 , 设备
      2025-05-06 09:20:29

      【网络】什么是IP地址?Internet Protocol Address

      IP地址(Internet Protocol Address,互联网协议地址) 是分配给每台连接到网络上的设备的唯一标识符。IP地址的作用是标识设备在网络中的位置,使得数据可以正确地发送和接收。它就像是每台设备在网络中的“地址”,是网络通信中不可或缺的基础。

      2025-05-06 09:20:29
      IP , 地址 , 设备 , 路由器
      2025-05-06 09:19:00

      基于SpringBoot实现的小区物业管理系统(含文档)

      基于SpringBoot实现的小区物业管理系统(含文档)

      2025-05-06 09:19:00
      模块 , 管理 , 设备
      2025-04-15 09:18:30

      边缘计算面临的挑战和机遇

      边缘计算也称为边缘处理,边缘计算是一种新兴的计算范式,将计算和数据处理推向接近数据源的边缘设备,解决网络传输的延迟问题。

      2025-04-15 09:18:30
      实时 , 智能 , 计算 , 设备 , 边缘
      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-25 08:52:14

      【存储】块存储、文件存储和对象存储的区别?

      【存储】块存储、文件存储和对象存储的区别?

      2025-02-25 08:52:14
      存储 , 文件 , 文件系统 , 设备
      2025-02-21 08:58:00

      【协议】MQTT、CoAP、HTTP比较,MQTT协议优缺点

      【协议】MQTT、CoAP、HTTP比较,MQTT协议优缺点

      2025-02-21 08:58:00
      HTTP , 协议 , 客户端 , 消息 , 设备
      2025-02-11 09:38:01

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

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

      2025-02-11 09:38:01
      USB , 子类 , 抽象 , 抽象类 , 接口 , 方法
      2024-12-24 10:25:10

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

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

      2024-12-24 10:25:10
      控制器 , 文件 , 文件系统 , 设备
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5247647

      查看更多

      最新文章

      arm架构下JAVA开发

      2025-05-14 10:03:13

      基于SpringBoot实现的小区物业管理系统(含文档)

      2025-05-06 09:19:00

      单片机基础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

      Linux内核源码-USB驱动分析

      2024-12-05 08:50:14

      查看更多

      热门文章

      驱动开发:内核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

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

      2024-09-10 08:20:57

      windows USB 设备驱动开发-USB电源管理(二)

      2024-09-10 08:20:51

      查看更多

      热门标签

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

      相关产品

      弹性云主机

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

      天翼云电脑(公众版)

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

      对象存储

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

      云硬盘

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

      查看更多

      随机文章

      windows USB 设备驱动开发-控制传输的数据包

      Linux源码阅读笔记17-资源分配及总线系统

      windows USB 设备驱动开发-USB描述符

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

      windows USB 设备驱动开发-Microsoft USB 测试工具 (MUTT) 设备

      Linux源码阅读笔记-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号