Firma de atestación Windows 10+ controladores

En este artículo se describe cómo firmar un controlador mediante la firma de atestación. Para obtener información detallada y requisitos para la firma de atestación, consulte Windows 10 controladores firmados de atestación.

Importante

A partir del 1 de marzo de 2023, los controladores firmados destinados a audiencias comerciales ya no se publican en Windows Update. Los controladores firmados de atestación para escenarios de prueba todavía se admiten al seleccionar las opciones CoDev o Test Registry Key /Surface SSRK .

Requisitos previos

Creación del archivo CAB

En esta sección, recorreremos el proceso de creación de un envío de archivos CAB. Usaremos el ejemplo del controlador de eco para ilustrar el proceso.

Un envío de archivo CAB típico debe contener lo siguiente:

  • El propio controlador, por ejemplo, Echo.sys

  • Archivo INF del controlador que usa el panel para facilitar el proceso de firma.

  • Archivo de símbolos que se usa para la depuración de información. Por ejemplo, Echo.pdb. El archivo .pdb es necesario para las herramientas automatizadas de análisis de bloqueos de Microsoft.

  • Los archivos .CAT de catálogo son necesarios y se usan solo para la comprobación de la empresa. Microsoft regenera los archivos de catálogo y reemplaza los archivos de catálogo que se enviaron.

Nota

Cada carpeta de controladores del archivo CAB debe admitir el mismo conjunto de arquitecturas. Por ejemplo, deben admitir x86, x64 o todos deben admitir x86 y x64.

No use rutas de acceso a recursos compartidos de archivos UNC al hacer referencia a las ubicaciones del controlador (\\\server\share). Debe usar una letra de unidad asignada para que el CAB sea válido.

Para crear el archivo CAB:

  1. Recopile los archivos binarios que se van a iniciar sesión en un único directorio. En este ejemplo, usaremos C:\\Echo.

  2. Abra una ventana del símbolo del sistema como administrador.

  3. Escriba MakeCab /? para ver las opciones MakeCab:

    C:\Echo> MakeCab /?
    Cabinet Maker - Lossless Data Compression Tool
    
    MAKECAB [/V[n]] [/D var=value ...] [/L dir] source [destination]
    MAKECAB [/V[n]] [/D var=value ...] /F directive_file [...]
    
    source         File to compress.
    destination    File name to give compressed file.  If omitted, the
                   last character of the source file name is replaced
                   with an underscore (_) and used as the destination.
    /F directives  A file with MakeCAB directives (may be repeated). Refer to
                   Microsoft Cabinet SDK for information on directive_file.
    /D var=value   Defines variable with specified value.
    /L dir         Location to place destination (default is current directory).
    /V[n]          Verbosity level (1..3).
    
  4. Prepare un archivo de entrada DDF del archivo cab. Para nuestro controlador Echo, podría tener un aspecto similar al siguiente.

    ;*** Echo.ddf example
    ;
    .OPTION EXPLICIT     ; Generate errors
    .Set CabinetFileCountThreshold=0
    .Set FolderFileCountThreshold=0
    .Set FolderSizeThreshold=0
    .Set MaxCabinetSize=0
    .Set MaxDiskFileCount=0
    .Set MaxDiskSize=0
    .Set CompressionType=MSZIP
    .Set Cabinet=on
    .Set Compress=on
    ;Specify file name for new cab file
    .Set CabinetNameTemplate=Echo.cab
    ; Specify the subdirectory for the files.  
    ; Your cab file should not have files at the root level,
    ; and each driver package must be in a separate subfolder.
    .Set DestinationDir=Echo
    ;Specify files to be included in cab file
    C:\Echo\Echo.Inf
    C:\Echo\Echo.Sys
    
  5. Escriba lo siguiente para crear el archivo CAB.

    C:\Echo> MakeCab /f "C:\Echo\Echo.ddf
    

    La salida de MakeCab debe mostrar el número de archivos en el archivo CAB creado. En este caso, debe haber dos archivos.

    C:\Echo> MakeCab /f Echo.ddf
    Cabinet Maker - Lossless Data Compression Tool
    
    17,682 bytes in 2 files
    Total files:              2
    Bytes before:        17,682
    Bytes after:          7,374
    After/Before:            41.70% compression
    Time:                     0.20 seconds ( 0 hr  0 min  0.20 sec)
    Throughput:              86.77 Kb/second
    
  6. Busque el archivo CAB en el Disk1 subdirectorio. Puede seleccionar el archivo CAB en Explorador de archivos para comprobar que contiene los archivos esperados.

Firmar el archivo CAB con el certificado EV

  1. Use el proceso recomendado por el proveedor de certificados EV para firmar el archivo CAB con el certificado EV. Por ejemplo, para firmar el archivo CAB con una marca de tiempo o un certificado SHA256, escriba el siguiente comando:

    C:\Echo> SignTool sign /ac "C:\MyEVCert.cer" /s MY /n "Company Name" /fd sha256 /tr http://sha256timestamp.ws.symantec.com/sha256/timestamp /td sha256 /v "C:\Echo\Disk1\Echo.cab"
    

    Importante

    Recuerde usar los procedimientos recomendados del sector para administrar la seguridad del proceso de firma de código ev.

Enviar el archivo Cab firmado de EV mediante el Centro de partners

  1. Vaya al panel de hardware del Centro de partners e inicie sesión con sus credenciales.

  2. Seleccione Enviar nuevo hardware.

    Captura de pantalla de la lista de hardware enviado.

  3. En la sección Paquetes y propiedades de firma , escriba un nombre de producto para el envío del controlador. Este nombre se puede usar para buscar y organizar los envíos de controladores.

    Nota

    Si comparte su controlador con otra empresa, verá este nombre.

  4. Deje las dos opciones de firma de prueba desactivadas.

  5. En Firmas solicitadas, seleccione las firmas que desea incluir en el paquete de controladores.

    Captura de pantalla que muestra las opciones para enviar el controlador de eco para la firma.

  6. Desplázte por la página y selecciona Enviar.

  7. Una vez completado el proceso de firma, descargue el controlador firmado desde el panel de hardware.

Validación de que el controlador se ha firmado correctamente

Complete los pasos siguientes para asegurarse de que el controlador se firmó correctamente.

  1. Después de descargar el archivo de envío, extraiga el archivo de controlador.

  2. Abra una ventana del símbolo del sistema como administrador.

  3. Escriba el siguiente comando para comprobar que el controlador se firmó según lo previsto.

    C:\Echo> SignTool verify Echo.Sys
    
  4. Para enumerar información adicional y hacer que signtool compruebe todas las firmas de un archivo con varias firmas, escriba el siguiente comando:

     C:\Echo> SignTool verify /pa /ph /v /d Echo.Sys
    
  5. Para confirmar que las EKU del controlador completen los pasos siguientes.

    1. Abra el Explorador de Windows y busque el archivo binario. Seleccione y mantenga presionado (o haga clic con el botón derecho) en el archivo y seleccione Propiedades.

    2. En la pestaña Firmas digitales , seleccione el elemento enumerado en la lista Firma.

    3. Seleccione Detalles y, a continuación, seleccione Ver certificado.

    4. En la pestaña Detalles , seleccione Uso mejorado de claves.

Cuando el panel renuncia al controlador, se usa el siguiente proceso.

  • Anexa una firma insertada de Microsoft SHA2.
  • Si el cliente inserta los archivos binarios del controlador con sus propios certificados, esas firmas no se sobrescribirán.
  • Crea y firma un nuevo archivo de catálogo con un certificado SHA2 de Microsoft. Este catálogo reemplaza cualquier catálogo existente proporcionado por el cliente.

Probar el controlador en Windows 10

Siga las instrucciones siguientes para instalar el controlador de ejemplo.

  1. Abra una ventana del símbolo del sistema como administrador. Vaya a la carpeta del paquete de controladores y escriba el siguiente comando.

    C:\Echo> devcon install echo.inf root\ECHO
    
  2. Confirme que el proceso de instalación del controlador no muestra "Windows no puede comprobar el publicador de este software de controlador". Cuadro de diálogo Seguridad de Windows.

Creación de un envío con varios controladores

Para enviar varios controladores al mismo tiempo:

  1. Cree un subdirectorio para cada controlador como se muestra a continuación.

    Diagrama que muestra una estructura de directorios de firma de controladores de ejemplo.

  2. Prepare un archivo de entrada DDF del archivo CAB que haga referencia a los subdirectorios. Es posible que tenga un aspecto similar a este:

    ;*** Submission.ddf multiple driver example
    ;
    .OPTION EXPLICIT     ; Generate errors
    .Set CabinetFileCountThreshold=0
    .Set FolderFileCountThreshold=0
    .Set FolderSizeThreshold=0
    .Set MaxCabinetSize=0
    .Set MaxDiskFileCount=0
    .Set MaxDiskSize=0
    .Set CompressionType=MSZIP
    .Set Cabinet=on
    .Set Compress=on
    ;Specify file name for new cab file
    .Set CabinetNameTemplate=Echo.cab
    ;Specify files to be included in cab file
    ; First Driver
    .Set DestinationDir=DriverPackage1
    C:\DriverFiles\DriverPackage1\Driver1.sys
    C:\DriverFiles\DriverPackage1\Driver1.inf
    ; Second driver
    .Set DestinationDir=DriverPackage2
    C:\DriverFiles\DriverPackage2\Driver2.sys
    C:\DriverFiles\DriverPackage2\Driver2.inf