ACPI 시스템 설명 테이블
SOC 기반 플랫폼에서는 ACPI(고급 구성 및 전원 인터페이스) 하드웨어 사양을 구현할 필요가 없지만 대부분의 ACPI 소프트웨어 사양이 필요합니다. ACPI는 확장 가능한 일반 테이블 전달 메커니즘과 플랫폼을 운영 체제에 설명하는 특정 테이블을 정의합니다.
ID 및 체크섬 필드를 포함한 테이블 구조 및 헤더는 ACPI 5.0 사양에 정의되어 있습니다. Windows는 이 문서에 설명된 특정 테이블 외에도 이 테이블 전달 메커니즘을 활용합니다.
이러한 테이블의 개념은 제네릭 소프트웨어가 다양한 방식으로 다양한 플랫폼에 통합될 수 있는 표준 IP(지적 재산권) 블록을 지원할 수 있도록 하는 것입니다. 테이블 전략을 사용하면 특정 플랫폼의 플랫폼 변수 특성이 테이블에 제공되며 일반 소프트웨어에서 플랫폼에 통합된 특정 IP 블록 집합에 맞게 조정하는 데 사용됩니다. 따라서 이 소프트웨어를 한 번 작성하고, 철저히 테스트한 다음, 시간이 지남에 따라 최적화할 수 있습니다.
RSDP(루트 시스템 설명 포인터)
Windows는 하드웨어 플랫폼을 부팅하기 위해 UEFI 펌웨어에 의존합니다. 따라서 Windows는 EFI 시스템 테이블을 사용하여 ACPI 5.0 사양의 "UEFI 사용 시스템에서 RSDP 찾기" 섹션 5.2.5.2에 설명된 대로 RSDP를 찾습니다. 플랫폼 펌웨어는 RSDP에서 RSDT 또는 XSDT의 주소를 채웁니다. (두 테이블 주소가 모두 제공되는 경우 Windows는 XSDT를 선호합니다.)
RSDT(루트 시스템 설명 테이블)
RSDT(또는 XSDT)에는 플랫폼에서 제공하는 다른 시스템 설명 테이블에 대한 포인터가 포함됩니다. 특히 이 테이블에는 다음 테이블에 대한 포인터가 포함되어 있습니다.
고정 ACPI 하드웨어 테이블(FADT)
MADT(다중 인터럽트 컨트롤러 테이블)
필요에 따라 CSRT(핵심 시스템 리소스 테이블)입니다.
디버그 포트 테이블 2(DBG2)
BGRT(부팅 그래픽 리소스 테이블)
FPDT(펌웨어 성능 데이터 테이블)
기본 시스템 설명 테이블(DSDT)
필요에 따라 추가 시스템 설명 테이블(SSDT)
고정 ACPI 설명 테이블(FADT)
FADT(고정 ACPI 하드웨어 테이블)에는 플랫폼에서 사용할 수 있는 다양한 고정 하드웨어 기능에 대한 중요한 정보가 포함되어 있습니다. 하드웨어 감소 ACPI 플랫폼을 지원하기 위해 ACPI 5.0은 다음과 같이 FADT 테이블 정의를 확장합니다.
FADT(오프셋 112) 내의 Flags 필드에는 두 개의 새 플래그가 있습니다.
HARDWARE_REDUCED_ACPI 비트 오프셋 20. 이 플랫폼에서 ACPI 하드웨어를 사용할 수 없음을 나타냅니다. ACPI 고정 하드웨어 프로그래밍 모델이 구현되지 않은 경우 이 플래그를 설정해야 합니다.
LOW_POWER_S0_IDLE_CAPABLE 비트 오프셋 21입니다. 플랫폼이 ACPI S0 시스템 전원 상태 내에서 Sx 절전 상태보다 에너지 효율이 높은 저전력 유휴 상태를 지원한다는 것을 나타냅니다. 이 플래그가 설정된 경우 Windows는 절전 모드 및 다시 시작을 시도하지 않고 플랫폼 유휴 상태 및 연결된 대기 상태를 대신 사용합니다.
FADT Preferred_PM_Profile 필드(바이트 오프셋 45)에는 새 역할 항목 "Tablet"이 있습니다. 이 역할은 디스플레이 및 입력에 대한 전원 관리 정책에 영향을 미치며 화상 키보드의 디스플레이에 영향을 줍니다.
"IA-PC 부팅 아키텍처 플래그" 필드(오프셋 109)에는 PC의 CMOS RTC가 구현되지 않았거나 레거시 주소에 존재하지 않음을 나타내는 새로운 "CMOS RTC 없음" 플래그(비트 오프셋 5)가 있습니다. 이 플래그가 설정된 경우 플랫폼은 ACPI 시간 및 경보 제어 방법 디바이스를 구현해야 합니다. 자세한 내용은 ACPI 정의디바이스 문서의 제어 방법 시간 및 경보 디바이스 섹션을 참조하세요.
하드웨어 감소 ACPI 플랫폼에서 기존 PC 절전 모드/다시 시작을 지원하기 위해 새 필드가 추가되었습니다. 이러한 필드는 Windows에서 무시되지만 규정 준수를 위해 테이블에 있어야 합니다.
HARDWARE_REDUCED_ACPI 플래그가 설정된 경우 ACPI 하드웨어 사양과 관련된 모든 필드는 운영 체제에서 무시됩니다.
다른 모든 FADT 설정은 이전 버전인 ACPI 4.0의 의미를 유지합니다. 자세한 내용은 ACPI 5.0 사양의 섹션 5.2.9, "FADT(고정 ACPI 설명 테이블)" 섹션을 참조하세요.
여러 APIC 설명 테이블(MADT)
ACPI의 PC 구현에서 MADT(다중 APIC 설명 테이블) 및 PC별 인터럽트 컨트롤러 설명자는 시스템 인터럽트 모델을 설명하는 데 사용됩니다. Arm 기반 SoC 플랫폼의 경우 ACPI 5.0은 Arm Holdings의 GIC(일반 인터럽트 컨트롤러) 및 GIC 배포자에 대한 설명자를 추가합니다. Windows에는 GIC 및 GIC 배포자에 대한 받은 편지함 지원이 포함되어 있습니다. 이러한 설명자에 대한 자세한 내용은 ACPI 5.0 사양의 섹션 5.2.12.14, "GIC 구조", 5.2.12.15, "GIC 배포자 구조"를 참조하세요.
인터럽트 컨트롤러 설명자 구조는 MADT의 Flags 필드 바로 다음에 나열됩니다. Arm 플랫폼의 경우 각 GIC에 대해 하나의 설명자가 나열되고 각 GIC 배포자에 대해 설명자가 하나씩 나열됩니다. 부팅 프로세서에 해당하는 GIC는 인터럽트 컨트롤러 설명자 목록의 첫 번째 항목이어야 합니다.
일반 타이머 설명 테이블(GTDT)
인터럽트 컨트롤러와 마찬가지로 ACPI에는 표준 타이머 설명 테이블이 있습니다. GIT 타이머를 활용하는 Arm 시스템의 경우 ACPI의 GTDT를 사용하여 Windows에서 GIT에 대한 기본 제공 지원을 활용할 수 있습니다.
CSRT(핵심 시스템 리소스 테이블)
CSR(핵심 시스템 리소스)은 운영 체제가 액세스를 직렬화해야 하는 인터럽트 컨트롤러, 타이머 및 DMA 컨트롤러와 같은 공유 하드웨어 함수입니다. 타이머 및 인터럽트 컨트롤러(x86 및 Arm 아키텍처 둘 다)와 같은 기능에 대한 업계 표준이 있는 경우 Windows는 ACPI(예: MADT 및 GTDT)에 설명된 표준 테이블을 기반으로 이러한 기능을 지원합니다. 그러나 업계가 DMA 컨트롤러 인터페이스 표준에 수렴할 때까지 운영 체제에서 일부 비표준 디바이스를 지원해야 합니다.
Windows는 이 문제를 해결하기 위해 HAL 확장의 개념을 지원합니다. HAL 확장은 Windows HAL을 Windows에 필요한 특정 CSR 클래스의 특정 하드웨어 인터페이스에 맞게 조정하는 SoC 관련 모듈로, DLL로 구현됩니다. 이러한 비표준 CSR 모듈을 식별하고 로드하기 위해 Microsoft는 새 ACPI 테이블을 정의했습니다. ACPI 사양에 "CSRT"라는 예약 서명이 있는 이 테이블은 플랫폼에서 비표준 CSR을 사용하는 경우 RSDT에 포함되어야 합니다.
CSRT는 각 리소스 그룹이 특정 형식의 하드웨어를 식별하는 CSR의 리소스 그룹을 설명합니다. Windows는 리소스 그룹에 제공된 식별자를 사용하여 이 그룹에 필요한 HAL 확장을 찾아 로드합니다. CSRT 내의 리소스 그룹에는 CSR 유형 및 HAL 확장의 요구 사항에 따라 개별 리소스 설명자가 포함될 수도 있습니다. 이러한 리소스 설명자의 형식 및 사용은 HAL 확장 작성기에 의해 정의되며, 확장이 훨씬 더 이식 가능하고 CSRT에 포함된 리소스 설명자를 변경하여 다양한 SoC 플랫폼을 지원할 수 있습니다.
HAL 확장의 유지 관리를 지원하고 이러한 확장에서 사용하는 시스템 리소스를 관리하려면 CSRT에 설명된 각 리소스 그룹도 플랫폼의 ACPI 네임스페이스 내에서 디바이스로 표시되어야 합니다. 자세한 내용은 다음 "DSDT(차별화된 시스템 설명 테이블)" 섹션을 참조하세요. 리소스 그룹 헤더에 사용되는 디바이스 식별자는 디바이스의 네임스페이스 노드에서 사용되는 식별자와 일치해야 합니다. 자세한 내용은 디바이스 관리 네임스페이스 개체 문서의 ACPI에서 디바이스 식별 섹션을 참조하세요. 이러한 리소스 그룹 네임스페이스 디바이스가 존재하면 WINDOWS 업데이트 서비스에서 HAL 확장을 서비스할 수 있습니다.
자세한 내용은 CSRT(핵심 시스템 리소스 테이블) 사양을 참조하세요.
디버그 포트 테이블 2(DBG2)
Microsoft는 모든 시스템에 디버그 포트가 필요합니다. 플랫폼에 기본 제공되는 디버그 포트를 설명하기 위해 Microsoft는 ACPI용 DBG2(디버그 포트 테이블 2)를 정의합니다. 이 표에서는 디버깅을 위해 하나 이상의 독립 포트를 지정합니다. DBG2 테이블이 있으면 플랫폼에 하나 이상의 디버그 포트가 포함되어 있음을 나타냅니다. 이 표에는 디버그 포트의 ID 및 구성에 대한 정보가 포함되어 있습니다. 테이블은 다른 ACPI 테이블이 있는 시스템 메모리에 있으며 ACPI RSDT 테이블에서 참조해야 합니다.
Windows는 DBG2 테이블의 포트 유형 값을 사용하여 시스템에 필요한 커널 디버거(KD) 전송(예: USB 또는 직렬)을 식별하고 로드합니다. 그런 다음 KD 전송은 DBG2 테이블의 포트 하위 형식 값을 사용하여 포트에서 사용하는 하드웨어 인터페이스를 식별합니다. DBG2 테이블의 다른 정보는 지정된 하위 형식에 대한 하드웨어 인터페이스 모듈에서 사용되는 포트 레지스터의 시스템 주소를 지정합니다. 마지막으로 DBG2 테이블에는 디버그 포트에 해당하는 ACPI 네임스페이스의 디바이스 노드에 대한 참조가 포함되어야 합니다. 이 참조를 사용하면 Windows에서 디버깅 사용과 디바이스의 일반적인 사용(있는 경우) 간의 충돌을 관리하고 디버거를 전원 전환과 통합할 수 있습니다.
자세한 내용은 Microsoft DBG2(디버그 포트 테이블 2) 사양을 참조하세요.
DSDT(차별화된 시스템 설명 테이블)
ACPI에서 플랫폼의 주변 장치 및 시스템 하드웨어 기능은 부팅 시 로드되는 DSDT(차별화된 시스템 설명 테이블) 또는 부팅 시 로드되거나 런타임에 동적으로 로드되는 SSDT(보조 시스템 설명 테이블)에 설명되어 있습니다. SoC의 경우 플랫폼 구성은 일반적으로 정적이므로 SSDT를 사용하여 플랫폼 설명의 모듈성을 향상시킬 수도 있지만 DSDT로 충분할 수 있습니다.
ACPI는 OS에 구애받지 않은 방식으로 시스템 디바이스 및 기능 및 플랫폼별 컨트롤을 설명하는 해석된 언어(ACPI 원본 언어 또는 ASL) 및 실행 환경(ACPI 가상 머신)을 정의합니다. ASL은 ACPI 네임스페이스에서 명명된 개체를 정의하는 데 사용되며, Microsoft ASL 컴파일러는 DSDT의 운영 체제로 전송하기 위한 AML(ACPI 컴퓨터 언어) 바이트 코드를 생성하는 데 사용됩니다. 받은 편지함 Windows ACPI 드라이버 Acpi.sys ACPI 가상 머신을 구현하고 AML 바이트 코드를 해석합니다. AML 개체는 단순히 설명 정보를 반환할 수 있습니다. 또는 AML 개체는 계산을 수행하거나 I/O 작업을 수행하는 메서드일 수 있습니다. 제어 메서드는 운영 체제의 디바이스 드라이버를 사용하여 플랫폼 하드웨어에서 I/O 작업을 수행하는 실행 가능한 AML 개체입니다. ASL은 OpRegions를 사용하여 운영 체제에서 액세스할 수 있는 다양한 주소 공간을 추상화합니다. 제어 메서드는 OpRegions에 선언된 명명된 필드 간 일련의 전송으로 I/O 작업을 수행합니다.
OpRegions에 대한 자세한 내용은 ACPI 5.0 사양의 섹션 5.5.2.4, "작업 지역에 대한 액세스"를 참조하세요. ASL 및 컨트롤 메서드에 대한 자세한 내용은 ACPI 5.0 사양의 섹션 5.5, "ACPI 네임스페이스"를 참조하세요.
Windows는 ASL 코드 개발 및 디버깅을 지원합니다. ASL 컴파일러에는 구현자가 디버깅 대상에서 네임스페이스를 로드할 수 있도록 하는 디스어셈블러가 포함되어 있습니다. 그런 다음 ASL 컴파일러를 사용하여 시스템 펌웨어를 플래시하지 않고도 신속한 프로토타입화 및 테스트를 위해 네임스페이스를 대상에 다시 적용할 수 있습니다. 또한 Windows 커널 디버거는 Acpi.sys 드라이버의 확인된(CHK) 버전과 함께 AML 실행 추적 및 분석을 지원합니다. 자세한 내용은 AMLI 디버거를 참조하세요.
WSMT(Windows SMM 보안 완화 테이블)
WSMT(Windows SMM 보안 완화 테이블) 사양에는 Windows VBS(가상화 기반 보안) 기능을 지원하는 Windows 운영 체제에서 사용하기 위해 만든 ACPI(고급 구성 및 전원 인터페이스) 테이블의 세부 정보가 포함되어 있습니다.
이 정보는 다음 운영 체제에 적용됩니다.
Windows Server 2016
Windows 10 버전 1607
자세한 내용은 WSMT(Windows SMM 보안 완화 테이블) 사양(DOCX 다운로드)을 참조하세요.
iSCSI 부팅 펌웨어 테이블(iBFT)
iSCSI 부팅 펌웨어(iBF) 테이블(iBFT)은 iSCSI 부팅 프로세스에 유용한 다양한 매개 변수를 포함하는 정보 블록입니다. iBFT는 iBF 매개 변수 값이 운영 체제에 전달되는 메커니즘입니다. iBF는 iBFT를 빌드하고 채웁니다. iBFT는 Windows 운영 체제에서 부팅 프로세스의 일관된 흐름을 사용하도록 설정할 수 있습니다.
자세한 내용은 iSCSI 부팅 펌웨어 테이블(iBFT) 사양(DOCX 다운로드)을 참조하세요.