[mosh-devel] CVE Request -- mosh (and probably vte too): mosh server DoS (long loop) due improper parsing of terminal parameters in terminal dispatcher

Keith Winstein keithw at MIT.EDU
Tue May 22 15:29:17 EDT 2012


Hello,

I am the author of Mosh, and somebody pointed me to your CVE request: 
http://seclists.org/oss-sec/2012/q2/370

I have not been part of this process before -- do we (the upstream) have a 
role here?

I don't want to butt in inappropriately, but I also don't want it to seem 
(by our silence) like we agree with the description in the CVE request.

The writeup is not accurate. We're grateful for the bug report by Timo 
Juhani Lindfors, but to say "issue confirmed by mosh upstream" makes it 
sound like we confirm _this_ issue.

We have written about this issue in the URL linked from the request: 
https://github.com/keithw/mosh/issues/271

In general, the application sending ANSI escape sequences is a trusted 
party. It is allowed to do things like disable the user's keyboard by 
sending "\e[2h", which is interpreted by xterm and Terminal.app.

That's a DoS as well, but (like this one) it's not really a security 
vulnerability. Because ANSI escape sequences can do arbitrary things to 
the user's terminal, programs that allow untrusted user-to-user 
communication (including write(1), wall(1), and e-mail and newsgroup 
readers) need to filter these out.

Here's my suggested text for the issue description:

===
Mosh versions 1.2 and earlier allow an application to cause the 
mosh-server to consume large amounts of CPU time with a short ANSI escape 
sequence. In addition, a malicious mosh-server can cause the mosh-client 
to consume large amounts of CPU time with a short ANSI escape sequence. 
This arises because there was no limit on the value of the "repeat" 
parameter in some ANSI escape sequences, so even large and nonsensical 
values would be interpreted by Mosh's terminal emulator.
===

This gets away from the suggestion that the problem relates to "improper 
parsing" or the "count of parameters" (it's about wanting a limit on the 
_value_ of parameters so the terminal emulator doesn't do huge amounts of 
work to execute a very short sequence), or to data coming from "a remote 
attacker."

Best regards,
Keith



More information about the mosh-devel mailing list