Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Windows Terminal input is as slow as rubber cement #11916

Open
wjk opened this issue Dec 9, 2021 · 23 comments
Open

Windows Terminal input is as slow as rubber cement #11916

wjk opened this issue Dec 9, 2021 · 23 comments
Labels
Area-Performance Performance-related issue Issue-Bug It either shouldn't be doing this or needs an investigation. Product-Terminal The new Windows Terminal.
Milestone

Comments

@wjk
Copy link

wjk commented Dec 9, 2021

Windows Terminal version

1.11.2921.0

Windows build number

10.0.22000.318

Other Software

My environment:

  • VMware Fusion version 12.1.1
  • macOS Monterey 12.0.1
  • 2.2 GHz 6-Core Intel Core i7 CPU (as reported by About This Mac)
  • 16 GB host memory

The virtual machine specs:

  • 4 cores (the Windows 10 minimum)
  • 8 GB RAM

Steps to reproduce

I am currently running the Visual Studio installer in this VM, placing it under heavy load (100% CPU utilization in Task Manager). If I type anything when the machine is this loaded, the input response time is unusably slow. It is so slow that if I alt-tab away from the terminal, I worry that my inputs might be sent to another program because the terminal hasn't processed them yet. Not being able to alt-tab away after typing a command is a serious productivity blocker for me.

Expected Behavior

The input latency being as fast as any other program on the VM at this heavy a load. (Try filling out a bug report form in Microsoft Edge under these circumstances, like I'm doing. The input latency there is as fast and as responsive as I expect.)

Actual Behavior

Enough time for me to enter a complete command line before the first character appears onscreen. The arrow keys, Backspace, and Ctrl+C are also processed this slowly. (I am a fast typist, but my hand-eye coordination isn't what it used to be; I make many typos while writing text.)

@ghost ghost added Needs-Triage It's a new issue that the core contributor team needs to triage at the next triage meeting Needs-Tag-Fix Doesn't match tag requirements labels Dec 9, 2021
@zadjii-msft
Copy link
Member

Hmmm. This might be a core input site bug. That's at least my only theory.

  • Is typing in the vintage console conhost.exe reasonably responsive?
  • What about typing in something like the Xaml Controls Gallery, or maybe even the Mail app?

Just trying to narrow down the problem space here. I'm not sure of any other good Xaml Islands applications that have text boxes that we could use for a comparison 😕

@zadjii-msft zadjii-msft added the Needs-Author-Feedback The original author of the issue/PR needs to come back and respond to something label Dec 9, 2021
@DHowett
Copy link
Member

DHowett commented Dec 9, 2021

This might be fallout from some of the responsiveness work we've done in Windows 11. Terminal is considered a foreground application, but the console application it is hosting isn't. This may cause some trouble.

If you try to make a text selection when it's bogged down, does that respond at a normal speed? That may help us determine which part of the pipeline is falling down.

@jpage-godaddy
Copy link

jpage-godaddy commented Dec 9, 2021

I don't know if this is the exact same thing, but I'm experiencing strangeness when it comes to keyboard input. My computer can get into a state where I get slowness of keyboard input and sometimes repeated characters. Details:

  • The problem only happens with my wireless keyboard.
  • The problem isn't there on a fresh reboot; it seems to start happening after some time.
  • Turning my wireless keyboard on/off does not help.
  • Restarting the terminal app seems to briefly help but the problem returns quickly.
  • My wireless keyboard doesn't cause this issue in other apps; it's only this terminal app.
  • My non-wireless laptop keyboard doesn't have this issue.
  • It happens for wsl and powershell, though it's much worse in wsl.
  • It does not happen in conhost.exe.
  • Text selection is not experiencing the lag.

I'm baffled; sorry to hijack if this is not the same issue as yours @wjk...

@wjk
Copy link
Author

wjk commented Dec 9, 2021

This might be fallout from the Windows 11 "Foreground Boost" work to make foreground apps more responsive. Terminal is considered a foreground application, but--critically--the console application it is hosting is NOT.

Yep, that’s exactly what’s happening. I can select text and manipulate the app just fine while the input is lagging badly. Is there any way we can make Terminal able to exempt its child process tree from Foreground Boost?

@ghost ghost added Needs-Attention The core contributors need to come back around and look at this ASAP. and removed Needs-Author-Feedback The original author of the issue/PR needs to come back and respond to something labels Dec 9, 2021
@zadjii-msft zadjii-msft added the Product-Terminal The new Windows Terminal. label Dec 9, 2021
@zadjii-msft
Copy link
Member

@DHowett I'm having a hard time finding anything on Foreground Boost. You think this is something we'll need to follow up with an internal deliverable to get Terminal/conpty sessions accounted for correctly? Or is there and API we can use?

@riverar

This comment has been minimized.

@wjk

This comment has been minimized.

@riverar

This comment has been minimized.

@zadjii-msft
Copy link
Member

There might be a regression in the OS we've discovered here. I've filed MSFT:37406950 tracking this internally on the kernel team to investigate what's going on here. We'll keep you posted with anything we hear back! (which may be a while with the holidays)

@DJankauskas
Copy link

DJankauskas commented Jul 6, 2022

Is there any movement on this issue? On Windows 11 22H2 I experienced extreme input lag in both Windows Terminal and Visual Studio Code, at least on battery power. Downgrading back to 22H1, along with the viveconfig tip above, seemed to solve the problem, but viveconfig did not help in 22H2. The lag made Terminal downright unusable, and I think it needs to be prioritized before developers are upgraded to 22H2. Personally I found the experience frustrating enough that I was thinking of switching to Linux or MacOS if I couldn't solve the problem.

@paulboco
Copy link

paulboco commented Aug 6, 2022

I was having the same issue. The issue stopped when I removed the .aws and .azure symlinks from my home directory. Don't know if this is related.
Edit: I spoke too soon. After an hour the sluggish behavior returned.

@microsoft microsoft deleted a comment from kjpgit Sep 2, 2022
@chrisfcarroll
Copy link

chrisfcarroll commented Oct 19, 2022

My environment:

  • Windows 10 21H2
  • Dell Precision 3551 16GB Core i7
    and 'slow as rubber cement' seems a fair description. conhost.exe and other apps are fine.

@stephenmartindale
Copy link

+1 on Windows 10 10.0.19044; wt says it's 1.15.2874.0 after I finally worked out how to call up the about dialogue.

I first noticed this with keyboard shortcuts like ctrl+c which are extremely slow – unusably slow, in fact. In some shells – git bash like – it's "slow as in minutes", not just "slow as in laggy".

And, yes, I, too, have noticed that the integrated terminal in vs code exhibits similar behaviour. conhost terminals do not.

@carlos-zamora carlos-zamora removed Needs-Triage It's a new issue that the core contributor team needs to triage at the next triage meeting Needs-Attention The core contributors need to come back around and look at this ASAP. Needs-Tag-Fix Doesn't match tag requirements labels Apr 5, 2023
@microsoft-github-policy-service microsoft-github-policy-service bot added the Needs-Tag-Fix Doesn't match tag requirements label Apr 5, 2023
@carlos-zamora carlos-zamora added Area-Performance Performance-related issue Issue-Bug It either shouldn't be doing this or needs an investigation. and removed Needs-Tag-Fix Doesn't match tag requirements labels Apr 5, 2023
@carlos-zamora carlos-zamora added this to the Backlog milestone Apr 5, 2023
@arymkus
Copy link

arymkus commented Oct 25, 2023

Same issue, awkwardly slow input while typing
Windows 11 21H2 OS build 22000.2538
terminal 1.18.2822.0

GitHub's mintty git bash and vscode's git bash work just fine.

@rickgladwin
Copy link

Same issue, very laggy (several seconds) when typing on the command line.
The same issue wasn't happening when using Powershell.
To reproduce:

  • open Windows Terminal
  • command wsl (Windows Subsystem for Linux)
  • open an ssh session to a remote server with localhost port forwarding (ssh -L <local port>:<remote host>:<remote port> <user>@<remote host)
  • type commands in the remote shell OR use vim in the remote shell (vim lag is even worse)

@zadjii-msft
Copy link
Member

@rickgladwin Can you go chime in over at #16861? I think there's possibly a more recent regression in this space that might be relevant.

@pryorda
Copy link

pryorda commented Apr 21, 2024

@zadjii-msft These versions did not fix the issue for me.

@SpBills
Copy link

SpBills commented Oct 28, 2024

Can confirm this is still a problem. Using Alacritty right now because wt is unbelievably slow.

@zadjii-msft
Copy link
Member

@SpBills Can you share your Terminal & OS Version?


Honestly this thread might just need to be closed in favor of newer information. I'm worried it's gotten too piled on with a variety of similar symptoms of different root causes.

  • The renderer has been dramatically rewritten (twice) since 1.11. So perf there shouldn't be an issue anymore?
  • Is the settings UI also laggy in this scenario? Or just the commandline? That would help ID if this is a foreground boost thing or not
  • does it only repro when the CPU is under load? or does it repro always?
  • being on 1.23 (the most recent terminal builds) will probably get the most consistent results

@chrisfcarroll
Copy link

chrisfcarroll commented Oct 29, 2024

@zadjii-msft — it could be that the widespread cause is that the Windows Store versions of Terminal are (or were last time I installed) years out of date. That would affect many of us on locked-down corporate desktops.

If so, is there some better place than here to get that addressed?

@DHowett
Copy link
Member

DHowett commented Oct 29, 2024

@chrisfcarroll FWIW, the store version of Terminal updates 1-2 weeks after we make a release on GitHub. The current Store version is 1.21.2911.0, which is the latest stable (it came out two weeks ago.)

corporate

That could explain it. Some enterprises do restrict the frequency of updates or the versions available on update.

It is for exactly this reason that we encourage everybody filing bugs or resurrecting years-old bugs to include their version information. That’s why it’s one of the items in the bug template.

As for getting that addressed: I'd recommend talking to your local IT administrator. ☹

@wilson0x4d
Copy link

wilson0x4d commented Jan 5, 2025

Windows Terminal Version 1.21.3231.0

Recently I noticed that as I typed into a Terminal session there would be intermittent draw artifacts and the delay between what I typed and what I saw appeared significant -- this was annoying. This is why I am here.

As for the draw artifacts, when using pwsh I noticed that autocomplete would fail to draw, every other character might fail to draw (as I typed), and then suddenly everything would draw -- this was distracting as the draw latency could be as much as a full second, or, coincides with my completing typing a statement.

I also noticed that when running a command such as ls the display would lag and then +poof!+ the directory* listing would appear -- this was livable, but obvious.

I then started running some of my development tools and noticed my test runner would incorrectly render test results onto one line, and then when the test runner exited +poof!+ the test results would be correctly rendered on individual lines as expected.

I played with the Direct2D vs Direct3D rendering options and both had the same problem, it was less-pronounced with the D3D render setting but still present. After enabling "Use Software Rendering (WARP)" the problem appears to be resolved +knocks on wood+. I was moments away from ditching Windows Terminal and going back to using tmux in a classic "Windows Console" and WSL for everything, which has its obvious drawbacks.. and to be blunt I will likely do if this problem emerges again.

Hopefully this info helps someone else out there work around the issue if they're experiencing unacceptable latency and render artifacts.

As for fixing this problem in the Product itself, the Product appears to have a design flaw. I am using Windows 11 24H2 26100.2605, all updates applied on a Core i9, w/64GiB ram and a "mid" RTX 4070 Ti GPU -- obviously this is overkill galore for a Terminal program to not be working correctly... I usually do all my development work in Qubes OS which despite the HV overhead and Xen channels wedged in between everything I've never experienced latency anywhere close to what Windows Terminal is exhibiting. VSCode terminal windows works fabulous, Windows Console works fabulous, this is squarely a problem with how Windows Terminal renders.

<3 good luck

@lhecker
Copy link
Member

lhecker commented Jan 6, 2025

What you experienced was most likely either:

  • (Most likely) You had a Direct3D application running that behaves like video game. Windows 24H2 has has a severe composition bug that causes applications like Windows Terminal (or Discord, etc.) to freeze just like how you described it. You can follow this issue: Terminal Unresponsive when Playing Games #18040.
  • A Nvidia driver bug. Those happens from time to time... With such a modern GPU I think it's best to make sure you always use the latest driver straight from Nvidia: https://www.nvidia.com/en-us/geforce/drivers/
    This is because the driver package also contains firmware updates. If it still occurs then, I'd reboot once such a bug still happens (that should reset its state).
  • (Least likely) You had G-Sync engaged for some reason without noticing it and you're using an old Nvidia driver. Nvidia has a bug where it mistakes any application like Windows Terminal (= windowed "iflip" swap chain) as a video game that wants G-Sync and so everything stutters. But you would've probably noticed that because your cursor would've stuttered as well.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Area-Performance Performance-related issue Issue-Bug It either shouldn't be doing this or needs an investigation. Product-Terminal The new Windows Terminal.
Projects
None yet
Development

No branches or pull requests