Arquitectura HID
La arquitectura de la pila de controladores HID en Windows se basa en el controlador de clase denominado hidclass.sys. Los clientes y los minidrives de transporte acceden al controlador de clase desde el modo de usuario o el modo kernel.
Controlador de clase HID
El controlador de clase HID proporcionado por el sistema es el controlador de función WDM y el controlador de bus para la clase de configuración de dispositivos HID (HIDClass). El componente ejecutable del controlador de clase HID es hidclass.sys. El controlador de clase HID es el pegamento entre los clientes HID y varios transportes, lo que permite escribir un cliente HID de forma independiente desde los transportes. Este nivel de abstracción permite a los clientes seguir funcionando (con poca o ninguna modificación) cuando se introduce un nuevo estándar o un transporte de terceros.
El diagrama siguiente es una representación de la arquitectura HID.
El diagrama anterior incluye:
- Clientes HID: identifica los clientes de Windows y de terceros y sus interfaces.
- Controlador de clase HID: el ejecutable hidclass.sys .
- Minidriver de transporte HID: identifica los transportes de Windows y de terceros y sus interfaces.
Este es el diagrama de pila de dispositivos de un cliente y transporte HID genéricos.
Este es otro diagrama de pila de dispositivos que muestra colecciones de teclado y mouse HID a través de USB.
Clientes HID
Los clientes HID son controladores, servicios o aplicaciones que se comunican con HIDClass.sys y a menudo representan un tipo específico de dispositivo (por ejemplo, sensor, teclado, mouse, etc.). Identifican el dispositivo a través de un identificador de hardware o una colección HID específica y se comunican con la colección HID a través de las instrucciones siguientes.
Los controladores y aplicaciones en modo de usuario y los controladores en modo kernel hacen lo siguiente para operar colecciones HID:
- Los controladores y las aplicaciones en modo de usuario usan rutinas de soporte de HIDClass (HidD_Xxx) para obtener información sobre una colección HID.
- Los controladores en modo kernel, los controladores en modo de usuario y las aplicaciones usan rutinas de soporte de análisis HID (HidP_Xxx) y los controladores en modo kernel usan IOCTL de controladores de clase HID para controlar informes HID.
En la tabla siguiente se simplifica la información.
Mode | Controladores | APLICACIONES |
---|---|---|
Modo usuario | HidD_Xxx | HidP_Xxx |
Modo kernel | HidD_Xxx O IOCTL_HID_xxx | N/D |
Para obtener más información, consulte Apertura de colecciones HID.
Clientes HID admitidos en Windows
Windows admite las siguientes colecciones de nivel superior:
Página Uso | Uso | Notas | Modo de acceso |
---|---|---|---|
0x0001 | 0x0001: 0x0002 | Controlador de clase mouse y controlador de asignador | Exclusivo |
0x0001 | 0x0004: 0x0005 | Controladores de juegos | Compartido |
0x0001 | 0x0006: 0x0007 | Controlador de clase teclado/Teclado y controlador del asignador | Exclusivo |
0x0001 | 0x000C | Modificador del modo piloto | Compartido |
0x0001 | 0x0080 | Controles del sistema (Potencia) | Compartido |
0x000C | 0x0001 | Controles de consumidor | Compartido |
0x000D | 0x0001 | Dispositivo de lápiz externo | Exclusivo |
0x000D | 0x0002 | Dispositivo de lápiz integrado | Exclusivo |
0x000D | 0x0004 | Pantalla táctil | Exclusivo |
0x000D | 0x0005 | Panel táctil de precisión (PTP) | Exclusivo |
0x0020 | *Múltiple | Sensors | Compartido |
0x0084 | 0x0004 | Batería HID UPS | Compartido |
0x008C | 0x0002 | Escáner de códigos de barras (hidscanner.dll) | Compartido |
En la tabla anterior, el modo de acceso para los clientes HID de entrada es exclusivo para evitar que otros clientes HID intercepten o reciban el estado de entrada global cuando no sean el destinatario de destino de esa entrada. Por motivos de seguridad, Raw Input Manager (RIM) abre todos estos dispositivos exclusivamente.
Si RIM abre un dispositivo en modo exclusivo , el usuario todavía puede abrir una interfaz de dispositivo HID sin solicitar permisos de lectura y escritura y obtener información del dispositivo HID a través de rutinas de soporte de HIDClass (HidD_GetXxx).
El modo de uso compartido permite que varias aplicaciones accedan a un dispositivo. Por ejemplo, varias aplicaciones pueden acceder a un escáner de códigos de barras para consultar las funcionalidades del dispositivo y recuperar estadísticas. Sin embargo, la recuperación de datos descodificados de un escáner de códigos de barras se realiza en modo exclusivo . Los usos se definen en las tablas de uso de USB-IF.
*Múltiplo: los usos de sensores de 0x00 : 0xFF se segmentan con fines diferentes. Por ejemplo, 0x10 indica un sensor biométrico; 0x40 indica un sensor de luz. Esas asignaciones no son contiguas. Para obtener la lista de usos de sensores, consulte Definiciones de clase de dispositivo USB-IF para HID. Para obtener información sobre los usos de sensores que se admiten en Windows, consulte Usos de sensores HID.
El controlador de transporte HID
El controlador de clase HID está diseñado para usar minidrives HID para acceder a un dispositivo de entrada de hardware. Un minidriver HID abstrae la operación específica del dispositivo de los dispositivos de entrada que admite. El minidriver HID enlaza su operación al controlador de clase HID registrando con el controlador de clase HID. El controlador de clase HID se comunica con un minidriver HID llamando a las rutinas de soporte técnico del minidriver. El minidriver HID, a su vez, envía comunicaciones por la pila del controlador a un bus subyacente o controlador de puerto.
Transportes HID admitidos en Windows
Para obtener una lista de los transportes HID admitidos, consulte información general sobre el transporte HID.
La prueba HID genérica de USB en el Kit de laboratorio de hardware (HLK) de Windows cubre los controladores HidUsb y HidClass. No hay ninguna prueba HLK para minidrives HID de terceros.