Universal Serial Bus (USB)

This document provides recommendations for the design and development of USB components. The goal of this document is to enable ecosystem partners to build a device with optimized USB functionality.

USB features in Windows 10

Windows 10 supports:

  • Dual Role controllers, which can function as either a USB Host or a USB Device. For example, a phone can connect to a PC as a USB device or it can connect to other USB peripherals as a USB host.

  • USB Type C, a flippable, reversible USB connector approximately the same size as a USB micro-B connector. In addition, USB Type-C provides support for the following features:

    • USB 3.1 Gen 2 (10Gb/s)
    • Power Delivery, enabling devices and systems to provide and consume up to 20V, 5A.
    • Alternate Modes, enabling non-USB protocols such as DisplayPort, Thunderbolt, or MHL to use the USB Type-C connector.
    • Billboard error message
  • USB 2.0, 3.0, and now USB 3.1, allowing OEMs to easily choose from a wide variety of controllers and peripherals.

  • Universal drivers can be built for USB peripherals that run on all Windows 10 Devices, from Internet-of-Things (IOT) to servers.

Partners are recommended to test these features by using the Hardware Lab Kit and to visit the USB Core Team blog for updated info about features and HLK tests, including these posts related to Windows 10:

USB scenarios for Windows 10 devices

Windows 10 enables hardware vendors to innovate and build great Dual Role and USB Type-C systems. A few examples of the scenarios enabled by USB features in Windows 10 are illustrated below:

  • Replace proprietary docking connectors with industry standard USB Type-C connector

  • Faster charging via USB Type-C current and/or Power Delivery

  • Allow for external USB peripherals to charge the system

  • Output video/audio over USB Type-C using Alternate Modes

  • Connect USB peripherals to Windows Mobile devices

  • Write Universal Applications that can interact with custom USB peripherals

example of new usb scenarios for a windows 10 desktop system

Figure 1 Example of new USB scenarios for a Windows 10 Desktop system

example of new usb scenarios for a windows 10 mobile device

Figure 2 Example of new USB scenarios for a Windows 10 Mobile device

Guidelines for USB for Windows 10

  • In general, USB should “just work” with minimal user interaction.
  • Hardware/firmware is expected to make the initial policy decisions introduced with the Dual Role, Power Delivery, and Alternate Mode features.
  • Windows will make policy adjustments to improve the user experience and help the user to troubleshoot issues if things go wrong.
  • Partners should ensure their USB hardware (such as systems, hubs, cables, or accessories) can interoperate with other USB hardware coming to or already on the market. We encourage participation in USB-IF-hosted interoperability and compliance events.
  • We recommend supporting the DisplayPort Alternate Mode for outputting video/audio over USB Type-C.
  • For systems with multiple USB ports that have different USB capabilities, we recommend making it clear to the customer which ports have which capabilities. For example, an icon imprinted next to the USB port can be used to show that the port supports Alternate Modes and Power Delivery.
  • Partners should follow the latest ACPI spec for how to properly describe their USB ports, such as the _UPC and _PLD methods.

Minimum hardware requirements for USB

USB is optional for all devices and computers that run Windows 10. Windows 10 supports the following USB controllers:

For the complete set of hardware requirements for Windows 10, see Minimum hardware requirements.

Windows Hardware Compatibility Program specifications for USB

The Windows Hardware Compatibility Program leverages tests in the Windows Hardware Lab Kit (HLK), which OEMs can use to help diagnose issues early in the development process, ensure driver compatibility with Windows, and optionally certify devices or systems. Tests in the HLK can validate Dual Role and Function mode on any Windows 10 edition.

The System.Fundamentals.SystemUSB.SystemExposesUSBPort Windows Hardware Compatibility Program requirement lists which USB controller types are recommended, supported, or not supported.

Maintained guidelines for USB from Windows 8.1

These guidelines from Windows 8.1 are maintained for Windows 10.

Hardware

For improved power efficiency and performance, it is recommended USB Host Controllers are at least USB 3.0 compatible with an XHCI controller integrated into the SoC or chipset. The operating system supports standard EHCI and XHCI 1.0 controllers, including debug registers. If the host controller is not fully compatible with the published standard specifications, the deviations must be documented and support for the host controller is determined on a case-by-case basis. In addition, the debug capability is important for XHCI host controllers.

USB Host Controller Interface Remarks
XHCI 1.0+Errata or higher (including debug capability) Required per the Windows HLK starting from June 2012
EHCI Supported
UHCI/OHCI Companion Controllers Not-supported

Blogs

USB Core Team blog

Windows Hardware Certification blog

Videos

Docking

Enabling New USB Connectivity Scenarios

Building New Apps for USB Accessories

Building great USB 3.0 devices

Integrating with the Windows Device Experience

Running Windows from an External USB drive with Windows To Go

Windows 10: What's new for USB

Universal Serial Bus (USB) Drivers

Setting Up a USB 3.0 Connection in Visual Studio

Setting Up a USB 3.0 Connection Manually

USB Reference