mirror of
https://github.com/CloverHackyColor/CloverBootloader.git
synced 2024-12-03 13:13:30 +01:00
620401dca6
Signed-off-by: Sergey Isakov <isakov-sl@bk.ru>
49 lines
1.5 KiB
NASM
49 lines
1.5 KiB
NASM
;------------------------------------------------------------------------------
|
|
; @file
|
|
; Copyright (C) 2020, vit9696. All rights reserved.
|
|
;
|
|
; All rights reserved.
|
|
;
|
|
; This program and the accompanying materials
|
|
; are licensed and made available under the terms and conditions of the BSD License
|
|
; which accompanies this distribution. The full text of the license may be found at
|
|
; http://opensource.org/licenses/bsd-license.php
|
|
;
|
|
; THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
; WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
;------------------------------------------------------------------------------
|
|
|
|
BITS 64
|
|
DEFAULT REL
|
|
|
|
MSR_IA32_BIOS_SIGN_ID equ 00000008Bh
|
|
CPUID_VERSION_INFO equ 1
|
|
|
|
SECTION .text
|
|
|
|
;------------------------------------------------------------------------------
|
|
; UINT32
|
|
; EFIAPI
|
|
; AsmReadIntelMicrocodeRevision (
|
|
; VOID
|
|
; );
|
|
;------------------------------------------------------------------------------
|
|
align 8
|
|
global ASM_PFX(AsmReadIntelMicrocodeRevision)
|
|
ASM_PFX(AsmReadIntelMicrocodeRevision):
|
|
; Several Intel CPUs, notably Westmere, require a certain assembly
|
|
; sequence to retrieve microcode revision.
|
|
; Reference: https://github.com/acidanthera/bugtracker/issues/621.
|
|
push rbx
|
|
mov ecx, MSR_IA32_BIOS_SIGN_ID
|
|
xor eax, eax
|
|
xor edx, edx
|
|
wrmsr
|
|
mov eax, CPUID_VERSION_INFO
|
|
cpuid
|
|
mov ecx, MSR_IA32_BIOS_SIGN_ID
|
|
rdmsr
|
|
mov eax, edx
|
|
pop rbx
|
|
ret
|