How to set up a Device for Real-Time Performance
This guide will walk you through how to set up your device for Real-Time Performance.
The only way to use this feature is with an application and device custom-built for a specific purpose. The mapping of processor core assignments in the application threads must match the physical device cores and their configuration for real-time versus standard workloads.
Disable idle states with
Reference the Security guidelines for system services to disable the following services:
a. SysMain (Superfetch)
b. DPS (Diagnostic Policy Service)
c. Audiosrv (Windows Audio)
Disable Windows Update using this guidance.
This will open up your device to vulnerabilities as security patches will not go through. That said, it is necessary as the Windows Update agent does not respect CPU core isolation. We recommend having a plan to ensure device security and install updates during times when the device can be taken down for maintenance
A good example of managing updates during downtime can be found in the UWF documentation: Service UWF-protected devices If you are using UWF and Soft Real-time then this process should take care of the OS update need for both features at the same time.
Set the WindowsIoT CSP for real-time performance.
Configure RSS to migrate ISRs/DPCs to CPU0
This is hardware dependent and can only be done if the NIC supports RSS
- Optional: Disable threaded DPCs for debugging
- Optional: Deploying a custom DPC pinning driver for certain hardware interrupts by following this guidance.
Performing this Configuration from the Command Line
Note that this will configure the device while it remains powered on. To ensure that the device maintains soft-RT performance, you should configure the machine to run these commands as a script every time the machine powers on using this guidance.
- Run these three commands in a cmd prompt. This disables CPU idle states, where a CPU with no instructions to run will go into a power-saving state. This is undesirable in real-time scenarios as idle CPUs have a delay in starting to execute new instructions:
powercfg.exe /setacvalueindex SCHEME_CURRENT SUB_PROCESSOR IdleDisable 1 powercfg.exe /setactive SCHEME_CURRENT
- Run these three commands in a cmd prompt to disable DPS:
sc query dps sc stop dps sc config dps start=disabled
- Run these three commands in a cmd prompt to disable Audiosrv:
sc query Audiosrv sc stop Audiosrv sc config Audiosrv start=disabled
- Run these three commands in a cmd prompt to disable SysMain:
sc query SysMain sc stop SysMain sc config SysMain start=disabled
- Run these 3 commands in a cmd prompt to disable Windows Update:
sc query wuauserv sc stop wuauserv sc config wuauserv start=disabled
- Run this command to disable threaded DPCs
reg add "HKLM\System\CurrentControlSet\Control\Session Manager\kernel" /v ThreadDpcEnable /t REG_DWORD /f /d 0
Ensuring the Device Stays Set up for Real-Time
Before deploying a real-time device to a production environment, there is additional setup needed to ensure the device can receive updates and maintain real-time performance:
Set up a script that can reenable Windows Update, install updates, and turn off Windows Update once again
Set up checks to ensure that on-device services remain disabled
What is the WindowsIoT CSP?
The WindowsIoT CSP is used to configure Windows IoT devices. Currently the only functionality available in this CSP is to configure a device for Soft Real-Time performance. Note that this is not the only work that needs to be done in order to use soft real-time with a device. You must also perform the other 6 steps above. Using this CSP to set soft real-time cores without also performing this additional configuration work will result in system malfunction and will require reimaging to recover.
The hierarchy of this CSP is as follows:
WindowsIoT SoftRealTimeProperties SetRTCores
A value greater than 0 and less than the total number of cores on the device must be provided to the SetRTCores parameter. Feel free to set this CSP using whatever tool your organization uses to configure their devices or use the steps below to use the MDM Bridge.
Use MDM Bridge WMI Provider to Configure the WindowsIoT CSP
This CSP will configure the system for real-time performance. You will need to provide the number of CPU cores to allocate to real-time tasks, with the rest being allocated for running system or standard user tasks. A numerical value must be provided in the SetRTCores node. This is the number of CPU Cores dedicated to real-time workloads. Valid numeric values must be at least 1 and less than the number of physical cores in the CPU.
Environments that use Windows Management Instrumentation (WMI) can use the MDM Bridge WMI Provider to accomplish this. Here's an example to set the RealTime configuration with 3 real-time cores:
Download the psexec tool.
Run an administrative command prompt.
In the command prompt, launch powershell under system account
psexec.exe -s -i powershell.exe
Execute the following script:
$nameSpaceName="root\cimv2\mdm\dmmap" $className="MDM_WindowsIoT_SoftRealTimeProperties01" $obj = Get-CimInstance -Namespace $namespaceName -ClassName $className Add-Type -AssemblyName System.Web Set-CimInstance -CimInstance $obj $obj.SetRTCores = 3 Set-CimInstance -CimInstance $obj
You can use the same script for whatever number of real-time cores you need to have, just replacing the 3 in the second-to-last line with the appropriate number. This will reserve cores starting with core 0 and going upwards. So reserving 3 cores on a 4 core CPU will reserve cores 0, 1, and 2 and leave core 3 for system and non-real-time tasks.