Set-WheaMemoryPolicy
Sets the Windows Hardware Error Architecture (WHEA) memory policy on a local or remote computer.
Syntax
Set-WheaMemoryPolicy
[-ComputerName <String>]
[-DisableOffline <Boolean>]
[-DisablePFA <Boolean>]
[-PersistMemoryOffline <Boolean>]
[-PFAPageCount <UInt32>]
[-PFAErrorThreshold <UInt32>]
[-PFATimeout <UInt32>]
[<CommonParameters>]
Description
The Set-WheaMemoryPolicy cmdlet sets the elements of the WHEA (Windows Hardware Error Architecture) memory policy on the specified computer. WHEA receives memory errors, corrected and uncorrected, from the platform and implements a Predictive Failure Analysis (PFA) algorithm based on corrected errors. WHEA attempts to remove from the available system memory the pages that have uncorrected errors, or are predicted to fail based on corrected errors. The removal decisions can be persisted across reboots. You can change the WHEA decision criteria against memory errors by tuning the WHEA memory policy. These policy elements can be set independently of each other. The new policy element values take effect immediately.
The following list specifies the WHEA memory policy elements:
DisableOffline: Disable decisions to take memory offline based on corrected or uncorrected errors.
DisablePFA: Disable predictive failure analysis (PFA) of memory pages based on the number of corrected errors reported in the page.
PersistMemoryOffline: Persist the decisions to take memory offline across reboots. This element applies to both corrected and uncorrected errors.
PFAPageCount: The maximum number of memory pages that WHEA monitors using PFA.
PFAErrorThreshold: The number of errors that need to occur within the timeout period for the page to be candidate for removal.
PFATimeout: The number of seconds before PFA takes a page out of the monitoring list.
Examples
Example 1: Enable WHEA predictive failure analysis
PS C:\>Set-WheaMemoryPolicy -DisablePFA $FALSE
Enable PFA on the local computer.
Example 2: Change the memory time out policy on a remote computer
PS C:\>Set-WHEAMemoryPolicy -ComputerName TestPC -PFATimeout 600
Change the WHEA memory policy on the remote computer TestPC to use a timeout of 600 seconds.
Example 3: Get and set WHEA memory policy in a script
PS C:\>$x=Get-WheaMemoryPolicy
PS C:\>$x.DisableOffline=$TRUE$
PS C:\>$x | Set-WheaMemoryPolicy
Get the memory policy in the object x, change the value of x.DisableOffline to TRUE, and then use x to set the memory policy.
Parameters
-ComputerName
Name of the computer on which to set the policy. If you do not specify this value, the cmdlet sets policy on the local computer. You can use cn as an alias for ComputerName.
Type: | String |
Aliases: | CN |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-DisableOffline
Setting the DisableOffline policy element to TRUE prevents WHEA from removing memory pages in response to either corrected or uncorrected memory errors.
Type: | Boolean |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-DisablePFA
Setting the DisablePFA policy element to TRUE stops WHEA from monitoring the memory pages that have corrected errors, and disables the predicative failure analysis algorithm.
Type: | Boolean |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-PersistMemoryOffline
Setting the PersistMemoryOffline policy element to TRUE enables WHEA to persist memory offline decisions across computer reboots.
Type: | Boolean |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-PFAErrorThreshold
The PFAErrorThreshold is the number of corrected errors that need to occur before a memory page in the PFA monitoring list is considered bad and will be taken offline.
Type: | UInt32 |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-PFAPageCount
The maximum size of the PFA monitoring list for pages that experience corrected memory errors.
Type: | UInt32 |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-PFATimeout
The number of seconds that WHEA monitors a memory page using PFA. WHEA starts monitoring a memory page when the page has its first corrected error.
WHEA stops monitoring a memory page when one of the following events occurs:
The monitoring interval exceeds the PfaTimeout value.
or
The number of detected errors exceeds the PfaErrorThreshold value.
Type: | UInt32 |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
Feedback
https://aka.ms/ContentUserFeedback.
Coming soon: Throughout 2024 we will be phasing out GitHub Issues as the feedback mechanism for content and replacing it with a new feedback system. For more information see:Submit and view feedback for