DWM.EXE High CPU (One Core) On Target System after Remote Desktop Disconnect on Windows 10 x64 1903 (Fully Patched)

Anonymous
2019-06-18T18:14:01+00:00

*** PROBLEM RESOLVED BY KB4522355 RELEASED OCTOBER 24TH 2019. ***

Two systems,

  • Intel NUC with Iris Plus Graphics 655 running latest drivers 26.20.100.6890
  • the other with Intel HD Graphics 2500 running latest drivers 5.33.48.5069

On completion of a remote desktop session, the target system shows high CPU utilisation (one core running at 100%) for DWM.EXE - the newer machine (Intel Iris Plus 655) will eventually crash several hours later - I suspect a memory leak such as the previous one affecting QuickSync.

If I change the drivers to "Microsoft Basic Display Adapter" then things return to normal re: DWM.EXE. It's not a long term fix as one of the machines is my Media Centre PC and I lose audio output on it, the other is a headless Plex server and I lose "Quick Sync" hardware transcoding.

Anyone else seeing this ?  If so after a bit of digging I've identified a short term workaround.

I believe there is a problem with the Microsoft RDP code in 1903 (an area which seems to have had a major internal overhaul), and I document a successful workaround. 

For clarity,

  • the behavior started with 1903
  • one system is an Intel NUC NUC8I7BEH PC with 16Gb Corsair Vengeance Memory and an Intel 760p 256Gb SSD; the other is a Chillblast Fusion Vacuum PC based on a P8H77-M motherboard. However other machines with nVidia GPU's are also affected, so this is NOT an Intel problem.
  • my testing consists of using a third machine running Windows 10 x64 1903 (fully patched) to run the Remote Desktop client software. The "targets" I refer to are the two machines I mention acting as RDP Host machines. Both demonstrate the high CPU DWM.EXE after taking them over and then disconnecting (the NUC has an 8 core CPU so shows 12.5% CPU) and the other machine based on an Intel P8H77-M motherboard.

It seems Microsoft has done significant engineering to Remote Desktop in Windows 10 1903 and I now believe a significant bug exists in the Microsoft code.

In the first article a Microsoft employee mentions

<--------------------->

There’s a known issue with some of the old display drivers.**<I believe the issue I am facing is related to this area>

Display drivers report some of their capabilities upon load. In previous Windows versions this reported data wasn’t used or verified. Because of that, some of the old versions of the legacy display driver may report invalid data and it would be ignored. Starting with Windows 10 1903 RDP uses this data to initialize the session.

The best option is to install an updated display driver from the hardware manufacturer. If the new version is not available, you can workaround this by disabling the problematic driver in the device manager.

Our team has identified the issue and we are currently verifying the fix that will dynamically switch to the software renderer if the problematic driver is detected.

I will this thread when the fix will be included to the Windows Insider release.

<---------------------->

Further testing in my environment has shown that machines without Intel integrated graphics are also showing the problem.

In the second article it mentions a change to the RDP driver area

<--------------------->

XDDM-based remote display driver: Starting with this release the Remote Desktop Services uses a Windows Display Driver Model (WDDM) based Indirect Display Driver (IDD) for a single session remote desktop. The support for Windows 2000 Display Driver Model (XDDM) based remote display drivers will be removed in a future release. Independent Software Vendors that use XDDM-based remote display driver should plan a migration to the WDDM driver model. For more information on implementing remote indirect display driver ISVs can reach out to rdsdev@microsoft.com.

<--------------------->

As a workaround on all of my affected machines I have used Group Policy Editor to set

Local Computer Policy

 Computer Configuration

  Administrative Templates

   Windows Components

    Remote Desktop Service

     Remote Desktop Session Host

      Remote Session Environment

       Use WDDM graphics display driver for Remote Desktop Connections

to DISABLED

This forces RDP to use the old (and now deprecated XDDM drivers)

After rebooting, behaviour returns to normal and after disconnecting from an RDP session the RDP host (target machine) no longer shows DWM.EXE consuming CPU.

This isn't a long term fix (to rely on a deprecated feature). I also don't understand why only a limited number of users are affected, but for now, I'm up and running again, and hoping for a Microsoft fix.

Windows for home | Windows 10 | Internet and connectivity

Locked Question. This question was migrated from the Microsoft Support Community. You can vote on whether it's helpful, but you can't add comments or replies or follow the question.

0 comments No comments
{count} votes

43 answers

Sort by: Most helpful
  1. Anonymous
    2019-07-08T11:17:06+00:00

    I have this problem too. Hope Microsoft can fix it soon.

    40 people found this answer helpful.
    0 comments No comments
  2. Anonymous
    2019-07-09T17:57:28+00:00

    Same issue here

    If the host is left alone with dwm.exe taking up one full core it will eventually crash and log out the session

    Intel 4770K with Asus Sabertooth Z87 motherboard using integrated intel gpu for the host (display driver 20.19.15.5063)

    Intel 3770K with Asus Sabertooth Z77 motherboaed using nvidia gpu for the client

    Faulting application name: dwm.exe, version: 10.0.18362.1, time stamp: 0x6468b8f9

    Faulting module name: dwmcore.dll, version: 10.0.18362.1, time stamp: 0xb9c883ae

    Exception code: 0xc00001ad

    Fault offset: 0x000000000015bada

    Faulting process id: 0x1cf4

    Faulting application start time: 0x01d5118f548421db

    Faulting application path: C:\WINDOWS\system32\dwm.exe

    Faulting module path: C:\WINDOWS\system32\dwmcore.dll

    Report Id: 8db71ccd-573e-41f5-8ca8-a2954c58ee5a

    Faulting package full name: 

    Faulting package-relative application ID:

    12 people found this answer helpful.
    0 comments No comments
  3. Anonymous
    2019-07-14T01:49:57+00:00

    I may be having a similar issue on a Lenovo laptop. I have 1903 on other hardware and works fine. I use this Lenovo laptop that has both Intel and nVidia GPUs running the latest drivers available for both. As far as I can tell, the system is fully up to date. However, if I RDP to this laptop, at some point the RDP session terminates and my user logged out. Looking at the event log, I see DWM.EXE has crashed two to three times with connected devices crashing events as well.

    I have not monitored DWM.EXE's memory and CPU footprint. I just know I've updated to 1903 on this laptop at least 7 times and each time, I've had to revert back to 1809 as this issue is destructive to productivity. It's also the only system I have that isn't running 1903 at this time.

    4 people found this answer helpful.
    0 comments No comments
  4. Anonymous
    2019-07-14T02:47:32+00:00

    The instructions in the initial post fixed my issues. Let's hope the legacy RDP stays as long as modern RDP has issues

    It does require Windows 10 Pro. A home version lacks the required policy editor

    7 people found this answer helpful.
    0 comments No comments
  5. Anonymous
    2019-07-14T17:41:47+00:00

    million thanks, the suggestion of using policy editor to force XDDM solved my issue. My machine in question is a Macmini late 2014 which has Intel GPU. Before this fix, a disconnected RDP session takes up 30% of the CPU, now it is back to normal as previous version of Windows 7/10/server.

    9 people found this answer helpful.
    0 comments No comments