stringtranslate.com

ACPI

La interfaz de configuración y energía avanzada ( ACPI ) es un estándar abierto que los sistemas operativos pueden usar para descubrir y configurar componentes de hardware de computadora , para realizar administración de energía (por ejemplo, poner en suspensión los componentes de hardware no utilizados), configuración automática (por ejemplo, Plug and Play e intercambio en caliente ) . y monitoreo de estado. Fue lanzado por primera vez en diciembre de 1996. ACPI tiene como objetivo reemplazar la administración avanzada de energía (APM), la especificación multiprocesador y la especificación Plug and Play BIOS (PnP). [1] ACPI pone la administración de energía bajo el control del sistema operativo, a diferencia del sistema anterior centrado en BIOS que dependía del firmware específico de la plataforma para determinar las políticas de configuración y administración de energía. [2] La especificación es fundamental para la configuración dirigida por el sistema operativo y el sistema de administración de energía ( OSPM ). ACPI define interfaces de abstracción de hardware entre el firmware del dispositivo (por ejemplo, BIOS , UEFI ), los componentes de hardware de la computadora y los sistemas operativos . [3] [4]

Internamente, ACPI anuncia los componentes disponibles y sus funciones al kernel del sistema operativo mediante listas de instrucciones (" métodos ") proporcionadas a través del firmware del sistema ( UEFI o BIOS ), que el kernel analiza. Luego, ACPI ejecuta las operaciones deseadas escritas en lenguaje de máquina ACPI (como la inicialización de componentes de hardware) utilizando una máquina virtual mínima incorporada .

Intel , Microsoft y Toshiba desarrollaron originalmente el estándar, mientras que HP , Huawei y Phoenix también participaron más tarde. En octubre de 2013, el Grupo de Interés Especial ACPI (ACPI SIG), los desarrolladores originales del estándar ACPI, acordaron transferir todos los activos al Foro UEFI , en el que se llevará a cabo todo el desarrollo futuro. [5] La última versión del estándar 6.5 se lanzó en agosto de 2022. [6]

Arquitectura

El ACPI a nivel de firmware tiene tres componentes principales: las tablas ACPI, el BIOS ACPI y los registros ACPI. El BIOS ACPI genera tablas ACPI y las carga en la memoria principal . Gran parte de la funcionalidad ACPI del firmware se proporciona en código de bytes de ACPI Machine Language (AML), un lenguaje de bajo nivel específico de dominio , completo de Turing , almacenado en las tablas ACPI. [7] Para hacer uso de las tablas ACPI, el sistema operativo debe tener un intérprete para el código de bytes AML. La arquitectura de componentes ACPI (ACPICA) proporciona una implementación de intérprete AML de referencia. En el momento del desarrollo del BIOS, el código de bytes AML se compila a partir del código ASL (lenguaje fuente ACPI). [8] [9]

La decisión de diseño general no estuvo exenta de críticas. En noviembre de 2003, Linus Torvalds , autor del kernel de Linux , describió ACPI como "un completo desastre de diseño en todos los sentidos". [10] [11]

Arquitectura de componentes ACPI (ACPICA)

La arquitectura de componentes ACPI ( ACPICA ), escrita principalmente por ingenieros de Intel, proporciona una implementación de referencia independiente de la plataforma de código abierto del código ACPI relacionado con el sistema operativo. [12] El código ACPICA es utilizado por Linux, Haiku , ArcaOS [13] y FreeBSD , [8] que lo complementan con su código específico del sistema operativo.

Historia

La primera revisión de la especificación ACPI se publicó en diciembre de 1996 y admite espacios de direccionamiento de 16, 24 y 32 bits . No fue hasta agosto de 2000 que ACPI recibió soporte para direcciones de 64 bits , así como soporte para estaciones de trabajo y servidores multiprocesador con la revisión 2.0.

En 1999, el entonces director ejecutivo de Microsoft, Bill Gates, declaró en un correo electrónico que Linux se beneficiaría de ACPI sin que ellos tuvieran que trabajar y sugirió que fuera sólo para Windows. [14] [15] [16]

En septiembre de 2004, se lanzó la revisión 3.0, que incorpora a la especificación ACPI soporte para interfaces SATA , bus PCI Express , soporte multiprocesador para más de 256 procesadores, sensores de luz ambiental y dispositivos de presencia del usuario, además de extender el modelo térmico más allá del anterior. soporte centrado en el procesador.

Lanzada en junio de 2009, la revisión 4.0 de la especificación ACPI agregó varias características nuevas al diseño; los más notables son la compatibilidad con USB 3.0 , la compatibilidad con el procesador lógico inactivo y la compatibilidad con x2APIC .

La revisión 5.0 de la especificación ACPI se lanzó en diciembre de 2011, [17] y agregó soporte para la arquitectura ARM . La revisión 5.1 se publicó en julio de 2014. [18]

La última revisión de la especificación es la 6.5, que se publicó en agosto de 2022. [6]

Sistemas operativos

La pantalla "Ahora es seguro apagar la computadora" en Windows 9x. La mayoría de los periféricos de la computadora están fuera de línea y la única forma de salir de esta pantalla es apagar o reiniciar la computadora.
La pantalla "Ahora es seguro apagar la computadora" en Windows NT 4.0. A diferencia de Windows 9x y versiones posteriores de NT, la mayoría de los periféricos esenciales de la computadora funcionan normalmente, por lo que el usuario puede optar por reiniciar en lugar de apagar su computadora.

Windows 98 de Microsoft fue el primer sistema operativo en implementar ACPI, [19] [20] pero su implementación tuvo algunos errores o estuvo incompleta, [21] [22] aunque algunos de los problemas asociados con él fueron causados ​​por el hardware ACPI de primera generación. . [23] Otros sistemas operativos, incluidas versiones posteriores de Windows , macOS , eComStation , ArcaOS , [24] FreeBSD (desde FreeBSD 5.0 ​​[25] ), NetBSD (desde NetBSD 1.6 [26] ), OpenBSD (desde OpenBSD 3.8 [27] ), HP-UX , OpenVMS , Linux , GNU Hurd y las versiones para PC de Solaris tienen al menos algo de soporte para ACPI. [28] Algunos sistemas operativos más nuevos, como Windows Vista , requieren que la computadora tenga un BIOS compatible con ACPI y, desde Windows 8 , se implementó el estado S0ix/Modern Standby . [29]

Los sistemas operativos Windows utilizan acpi.sys [30] para acceder a eventos ACPI.

La serie 2.4 del kernel de Linux tenía solo un soporte mínimo para ACPI, con un mejor soporte implementado (y habilitado de forma predeterminada) desde la versión del kernel 2.6.0 en adelante. [31] Las implementaciones antiguas de ACPI BIOS tienden a tener bastantes errores y, en consecuencia, no son compatibles con sistemas operativos posteriores. Por ejemplo, Windows 2000 , Windows XP y Windows Server 2003 sólo usan ACPI si la fecha del BIOS es posterior al 1 de enero de 1999. [32] De manera similar, el kernel 2.6 de Linux no puede usar ACPI si la fecha del BIOS es anterior al 1 de enero de 2001. [31]

Los sistemas operativos basados ​​en Linux pueden proporcionar manejo de eventos ACPI a través de acpid. [33]

Responsabilidades de OSPM

Una vez que un sistema operativo compatible con OSPM activa ACPI, toma el control exclusivo de todos los aspectos de la administración de energía y la configuración del dispositivo. La implementación de OSPM debe exponer un entorno compatible con ACPI a los controladores de dispositivos, lo que expone ciertos estados del sistema, del dispositivo y del procesador.

Estados de poder

Estados globales

La especificación ACPI define los siguientes cuatro estados globales "Gx" y seis estados de suspensión "Sx" para un sistema informático compatible con ACPI: [34] [35]

La especificación también define un estado heredado : el estado de un sistema operativo que no admite ACPI. En este estado, el hardware y la energía no se administran a través de ACPI, lo que de hecho desactiva ACPI.

Estados del dispositivo

Los estados del dispositivo D0D3 dependen del dispositivo:

Estados del procesador

Los estados de energía de la CPU C0C3 se definen de la siguiente manera:

Estado de rendimiento

Mientras un dispositivo o procesador está en funcionamiento (D0 y C0, respectivamente), puede encontrarse en uno de varios estados de energía-rendimiento . Estos estados dependen de la implementación. P0 es siempre el estado de mayor rendimiento, siendo P1 a Pn sucesivamente estados de menor rendimiento, hasta un límite específico de la implementación de n no mayor que 16. [43]

Los estados P se conocen como SpeedStep en los procesadores Intel , como PowerNow! o Cool'n'Quiet en procesadores AMD , y como PowerSaver en procesadores VIA .

Interfaces

Hardware

Los sistemas compatibles con ACPI interactúan con el hardware a través de una "interfaz de hardware de función fija (FFH)" o un modelo de programación de hardware independiente de la plataforma que se basa en el lenguaje de máquina ACPI (AML) específico de la plataforma proporcionado por el fabricante del equipo original (OEM).

Las interfaces de hardware fijo de funciones son características específicas de la plataforma, proporcionadas por los fabricantes de plataformas con fines de rendimiento y recuperación de fallas. Las PC estándar basadas en Intel tienen una interfaz de función fija definida por Intel, [45] que proporciona un conjunto de funcionalidades principales que reducen la necesidad de un sistema compatible con ACPI de pilas completas de controladores para proporcionar funcionalidad básica durante el tiempo de arranque o en el caso de un sistema importante. falla.

La interfaz de error de plataforma ACPI (APEI) es una especificación para informar errores de hardware, por ejemplo, chipset o RAM al sistema operativo.

firmware

ACPI define muchas tablas que proporcionan la interfaz entre un sistema operativo compatible con ACPI y el firmware del sistema ( BIOS o UEFI ). Esto incluye RSDP, RSDT, XSDT, FADT, FACS, DSDT, SSDT, MADT y MCFG, por ejemplo. [46] [47]

Las tablas permiten la descripción del hardware del sistema de manera independiente de la plataforma y se presentan como estructuras de datos con formato fijo o en AML. La tabla AML principal es la DSDT (tabla de descripción de sistemas diferenciados). El AML se puede descompilar mediante herramientas como iASL de Intel (código abierto, parte de ACPICA) con fines como parchear las tablas para ampliar la compatibilidad del sistema operativo. [48] ​​[49]

El puntero de descripción del sistema raíz (RSDP) se ubica según la plataforma y describe el resto de las tablas.

Microsoft utiliza una tabla ACPI personalizada llamada tabla binaria de plataforma Windows (WPBT) para permitir a los proveedores agregar software al sistema operativo Windows automáticamente. Se ha descubierto que algunos proveedores, como Lenovo , utilizan esta función para instalar software dañino como Superfish . [50] Samsung envió PC con Windows Update deshabilitado. [50] Las versiones de Windows anteriores a Windows 7 no admiten esta función, pero se pueden utilizar técnicas alternativas. Este comportamiento se ha comparado con los rootkits . [51] [52]

Mesas

FANTÁSTICO
Tabla de evaluación del estado de la plataforma
DESLIZAR
Tabla de descripción de licencias de software

Riesgos de seguridad

El fundador de Ubuntu, Mark Shuttleworth, dice que ACPI es un riesgo para la seguridad. [53] Dice que "defender ACPI en su dispositivo de próxima generación es defender la instalación de un caballo de Troya de proporciones monumentales en su sala de estar y en su centro de datos" y "el firmware de su dispositivo es el mejor amigo de la NSA" . ". Continúa diciendo: "Su mayor error es asumir que la NSA es la única institución que abusa de esta posición de confianza; de hecho, es razonable suponer que todo el firmware es un pozo negro de inseguridad, cortesía de la incompetencia del más alto grado por parte de fabricantes y competencia del más alto nivel por parte de una amplia gama de tales agencias." Sugiere firmware declarativo de código abierto (ACPI o no ACPI) como solución . [10]

Ver también

Otras lecturas

Referencias

  1. ^ "Descripción general de ACPI" (PDF) . www.acpi.info . Archivado desde el original ( presentación de diapositivas en PDF) el 25 de mayo de 2019.
  2. ^ "Especificación del BIOS APM". Corporación Intel , Corporación Microsoft . Febrero de 1996. Archivado desde el original (RTF) el 6 de febrero de 2012 . Consultado el 2 de julio de 2010 .
  3. ^ "¿Qué es ACPI (interfaz de alimentación y configuración avanzada)? - Definición de WhatIs.com". BuscarWindowsServer . Consultado el 18 de septiembre de 2020 .
  4. ^ "Árbol de dispositivos ACPI: representación del espacio de nombres ACPI: documentación del kernel de Linux". www.kernel.org . Consultado el 18 de septiembre de 2020 .
  5. ^ "La página web Configuración avanzada e interfaz de alimentación tiene una nota destacada que enlaza con la página Especificaciones ACPI preexistentes en el sitio web UEFI". acpi.org . 23 de julio de 2014. Archivado desde el original el 22 de junio de 2011 . Consultado el 25 de enero de 2016 .
  6. ^ ab "Especificación de interfaz de alimentación y configuración avanzada, versión 6.5" (PDF) . UEFI.org/especificaciones . Agosto de 2022 . Consultado el 4 de octubre de 2022 .
  7. ^ Bernhard Kauer (agosto de 2009). "ATARE: Tablas ACPI y expresiones regulares" (PDF) . Consultado el 18 de febrero de 2019 .
  8. ^ ab Implementación de ACPI en FreeBSD - Usenix
  9. ^ ACPI en Linux, 2005
  10. ^ ab Revista Linux número 162, mayo de 2014, página 9
  11. ^ Searls, Doc (25 de noviembre de 2003). "Linus y los locos, parte II". Diario de Linux . Consultado el 13 de enero de 2010 .
  12. ^ ACPICA: Arquitectura de componentes ACPI
  13. ^ "Léame para el paquete de controladores ACPI". arcanoae.com . Consultado el 6 de septiembre de 2020 .
  14. ^ "Microsoft no utiliza ACPI para Windows". Der Standard (en alemán austriaco) . Consultado el 6 de noviembre de 2022 .
  15. ^ "Microsoft: ACPI solo funciona con funciones de Windows". Golem.de . Consultado el 6 de noviembre de 2022 .
  16. ^ Gates, Bill (24 de enero de 1999). "Extensiones ACPI" (PDF) . Archivado desde el original (PDF) el 2 de febrero de 2007.
  17. ^ Hewlett-Packard ; Corporación Intel ; microsoft ; Tecnologías Phoenix ; Toshiba (6 de diciembre de 2011). "Especificación de interfaz de alimentación y configuración avanzada (Revisión 5.0)" (PDF) . acpi.info . Archivado desde el original (PDF) el 14 de septiembre de 2012 . Consultado el 17 de noviembre de 2013 .
  18. ^ "Especificación de interfaz de alimentación y configuración avanzada (Revisión 5.1)" (PDF) . uefi.org . 23 de julio de 2014 . Consultado el 24 de mayo de 2015 .
  19. ^ "Limitaciones al utilizar Microsoft Windows 98 en portátiles Compaq Armada" (PDF) . physik.hu-berlin.de. Octubre de 1998. pág. 3 . Consultado el 27 de enero de 2014 .[ enlace muerto permanente ]
  20. ^ "Windows 98 en sistemas ThinkPad: ThinkPad General". Soporte.lenovo.com. Archivado desde el original el 3 de febrero de 2014 . Consultado el 27 de enero de 2014 .
  21. ^ Robert Cowart; Brian Knittel (2000). Usando Microsoft Windows 2000 Profesional . Que Editorial. pag. 30.ISBN _ 978-0-7897-2125-9.
  22. ^ Windows 98 no admite el modo de refrigeración pasiva ACPI
  23. ^ "Artículo de portada: errores y correcciones de Win98 - diciembre de 1998". winmag.com . Archivado desde el original el 13 de octubre de 1999.
  24. ^ "Registro de cambios de ArcaOS" . Consultado el 24 de agosto de 2020 .
  25. ^ "Anuncio de lanzamiento de FreeBSD 5.0". www.freebsd.org . Consultado el 3 de diciembre de 2020 .
  26. ^ "acpi(4) - Páginas del manual de NetBSD". man.netbsd.org . Consultado el 3 de diciembre de 2020 .
  27. ^ "acpi(4) - páginas del manual de OpenBSD". man.openbsd.org . Consultado el 3 de diciembre de 2020 .
  28. ^ Therien, Guy (6 de enero de 2000). "Revisión técnica de la especificación ACPI 2.0, Foro de desarrolladores Intel" (PPT) . Corporación Intel. Archivado desde el original el 21 de julio de 2011 . Consultado el 21 de agosto de 2011 .
  29. ^ Marshall, Allen. "ACPI en Windows Vista" (PPT) . Corporación Microsoft . Consultado el 2 de julio de 2010 .
  30. ^ "Acpi.sys: el controlador ACPI de Windows". Corporación Microsoft . 15 de junio de 2017 . Consultado el 20 de septiembre de 2019 .
  31. ^ ab El estado de ACPI en el kernel de Linux
  32. ^ BIOS ACPI. msdn.microsoft.com .
  33. ^ Linux en pocas palabras. Ellen Siever, Ellen Siever (5ª ed.). Pekín: O'Reilly. 2005. pág. 36.ISBN _ 978-0-596-52949-9. OCLC  773210086.{{cite book}}: Mantenimiento CS1: otros ( enlace )
  34. ^ ACPI Spec Rev 5.0 - de fecha 6 de diciembre de 2011
  35. ^ Anand Lal Shimpi (5 de octubre de 2012). "Analización de la arquitectura Haswell de Intel". AnandTech . Consultado el 20 de octubre de 2013 .
  36. ^ contenido del controlador de Windows. "Espera moderna". docs.microsoft.com . Consultado el 20 de marzo de 2020 .
  37. ^ "Estados S0ix". software.intel.com . 9 de marzo de 2020.
  38. ^ Wang, Wendy (17 de octubre de 2018). "Cómo lograr estados S0ix en Linux*". 01.org .
  39. ^ "Estados D0". www.android.com (en español). 11 de diciembre de 2023.
  40. ^ "Athlon II X2: Hardware C1E y regreso del error CnQ". AnandTech . Consultado el 26 de octubre de 2020 .
  41. ^ Wasson, Scott (21 de febrero de 2005). "Procesadores Intel de la serie Pentium 4600". El informe técnico . pag. 2.
  42. ^ "Paquete de procesador y estados C principales". AnandTech . 9 de junio de 2013 . Consultado el 20 de octubre de 2013 .
  43. ^ "Especificación de interfaz de alimentación y configuración avanzada, revisión 3.0, sección 2.6 Definiciones del estado de rendimiento del procesador y del dispositivo" (PDF) . ACPI.info . 2 de septiembre de 2004. p. 23. Archivado desde el original (PDF) el 28 de noviembre de 2015 . Consultado el 19 de agosto de 2015 .
  44. ^ Agregación de enlaces
  45. ^ Intel Corporation (septiembre de 2006). "ACPI específico del proveedor de procesadores Intel" (PDF) . Archivado desde el original (PDF) el 25 de diciembre de 2012 . Consultado el 5 de octubre de 2014 .
  46. ^ Brown, Len (20 de julio de 2005). "ACPI en Linux". Simposio de Ottawa sobre Linux : 3. CiteSeerX 10.1.1.173.2206 . 
  47. ^ "Tablas ACPI: documentación del kernel de Linux". www.kernel.org . Consultado el 8 de noviembre de 2020 .
  48. ^ "DSDT". ArchiWiki .
  49. ^ "Primeros pasos con ACPI". GitBook .
  50. ^ ab Hoffman, Chris (19 de agosto de 2015). "Zombie Crapware: cómo funciona la tabla binaria de la plataforma Windows". Cómo hacerlo geek .
  51. ^ "Proveedores 'rootkit': 'Tabla binaria de la plataforma Windows' (WPBT)". La tecnología de Born y el mundo de Windows . 6 de diciembre de 2017.
  52. ^ Mayank Sharma (27 de septiembre de 2021). "Millones de PC con Windows 10 expuestas a una desagradable vulnerabilidad de seguridad". TecnologíaRadar . Consultado el 10 de noviembre de 2022 .
  53. ^ Blog de Mark Shuttleworth (17 de marzo de 2014), "ACPI, firmware y su seguridad"

enlaces externos