summaryrefslogtreecommitdiffstats
path: root/MdePkg/Library/BaseLib/Ia32/WriteMsr64.c
blob: ba0cf3f74c308229c2809ed29b55f52509344e97 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
/** @file
  AsmWriteMsr64 function

  Copyright (c) 2006 - 2021, Intel Corporation. All rights reserved.<BR>
  SPDX-License-Identifier: BSD-2-Clause-Patent

**/


#include <Library/RegisterFilterLib.h>

/**
  Writes a 64-bit value to a Machine Specific Register(MSR), and returns the
  value.

  Writes the 64-bit value specified by Value to the MSR specified by Index. The
  64-bit value written to the MSR is returned. No parameter checking is
  performed on Index or Value, and some of these may cause CPU exceptions. The
  caller must either guarantee that Index and Value are valid, or the caller
  must establish proper exception handlers. This function is only available on
  IA-32 and x64.

  @param  Index The 32-bit MSR index to write.
  @param  Value The 64-bit value to write to the MSR.

  @return Value

**/
UINT64
EFIAPI
AsmWriteMsr64 (
  IN UINT32  Index,
  IN UINT64  Value
  )
{
  BOOLEAN                           Flag;

  Flag = FilterBeforeMsrWrite (Index, &Value);
  if (Flag) {
    _asm {
      mov     edx, dword ptr [Value + 4]
      mov     eax, dword ptr [Value + 0]
      mov     ecx, Index
      wrmsr
    }
  }
  FilterAfterMsrWrite (Index, &Value);

  return Value;
}