Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

136 lines
3.0 KiB

  1. /*++
  2. Copyright (c) 1991 Microsoft Corporation
  3. Module Name:
  4. mtrr.h
  5. Abstract:
  6. This module contains the i386 specific mtrr register
  7. hardware definitions.
  8. Author:
  9. Ken Reneris (kenr) 11-Oct-95
  10. Environment:
  11. Kernel mode only.
  12. Revision History:
  13. --*/
  14. //
  15. // MTRR MSR architecture definitions
  16. //
  17. #define MTRR_MSR_CAPABILITIES 0x0fe
  18. #define MTRR_MSR_DEFAULT 0x2ff
  19. #define MTRR_MSR_VARIABLE_BASE 0x200
  20. #define MTRR_MSR_VARIABLE_MASK (MTRR_MSR_VARIABLE_BASE+1)
  21. #define MTRR_PAGE_SIZE 4096
  22. #define MTRR_PAGE_MASK (~(MTRR_PAGE_SIZE-1))
  23. //
  24. // Memory range types
  25. //
  26. #define MTRR_TYPE_UC 0
  27. #define MTRR_TYPE_USWC 1
  28. #define MTRR_TYPE_WT 4
  29. #define MTRR_TYPE_WP 5
  30. #define MTRR_TYPE_WB 6
  31. #define MTRR_TYPE_MAX 7
  32. //
  33. // MTRR specific registers - capability register, default
  34. // register, and variable mask and base register
  35. //
  36. #include "pshpack1.h"
  37. typedef struct _MTRR_CAPABILITIES {
  38. union {
  39. struct {
  40. ULONG VarCnt:8;
  41. ULONG FixSupported:1;
  42. ULONG Reserved_0:1;
  43. ULONG UswcSupported:1;
  44. ULONG Reserved_1:21;
  45. ULONG Reserved_2;
  46. } hw;
  47. ULONGLONG QuadPart;
  48. } u;
  49. } MTRR_CAPABILITIES, *PMTRR_CAPABILITIES;
  50. typedef struct _MTRR_DEFAULT {
  51. union {
  52. struct {
  53. ULONG Type:8;
  54. ULONG Reserved_0:2;
  55. ULONG FixedEnabled:1;
  56. ULONG MtrrEnabled:1;
  57. ULONG Reserved_1:20;
  58. ULONG Reserved_2;
  59. } hw;
  60. ULONGLONG QuadPart;
  61. } u;
  62. } MTRR_DEFAULT, *PMTRR_DEFAULT;
  63. typedef struct _MTRR_VARIABLE_BASE {
  64. union {
  65. struct {
  66. ULONG Type:8;
  67. ULONG Reserved_0:4;
  68. ULONG PhysBase_1:20;
  69. ULONG PhysBase_2:4;
  70. ULONG Reserved_1:28;
  71. } hw;
  72. ULONGLONG QuadPart;
  73. } u;
  74. } MTRR_VARIABLE_BASE, *PMTRR_VARIABLE_BASE;
  75. #define MTRR_MASK_BASE 0x0000000ffffff000
  76. typedef struct _MTRR_VARIABLE_MASK {
  77. union {
  78. struct {
  79. ULONG Reserved_0:11;
  80. ULONG Valid:1;
  81. ULONG PhysMask_1:20;
  82. ULONG PhysMask_2:4;
  83. ULONG Reserved_1:28;
  84. } hw;
  85. ULONGLONG QuadPart;
  86. } u;
  87. } MTRR_VARIABLE_MASK, *PMTRR_VARIABLE_MASK;
  88. #define MTRR_MASK_MASK 0x0000000ffffff000
  89. //
  90. // Masks/constants to check for non-contiguous masks,
  91. // mask out reserved bits of variable MTRR's,
  92. // and construct MTRR variable register masks
  93. //
  94. #define MASK_OVERFLOW_MASK (~0x1000000000)
  95. #define MTRR_RESVBIT_MASK 0xfffffffff
  96. #define MTRR_MAX_RANGE_SHIFT 36
  97. #include "poppack.h"
  98. typedef struct _PROCESSOR_LOCKSTEP {
  99. ULONG Processor;
  100. volatile ULONG TargetCount;
  101. volatile ULONG *TargetPhase;
  102. } PROCESSOR_LOCKSTEP, *PPROCESSOR_LOCKSTEP;
  103. VOID
  104. KiLockStepExecution(
  105. IN PPROCESSOR_LOCKSTEP Context
  106. );