From mboxrd@z Thu Jan 1 00:00:00 1970 From: Asias He Subject: Re: [PATCH] kvm tools: Sanitize output characters in serial console Date: Wed, 10 Aug 2011 13:43:14 +0800 Message-ID: <4E421A72.9080203@gmail.com> References: <1312934218-32666-1-git-send-email-asias.hejun@gmail.com> <4E421784.2020703@kernel.org> Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: QUOTED-PRINTABLE Cc: Cyrill Gorcunov , Ingo Molnar , Sasha Levin , Prasad Joshi , kvm@vger.kernel.org To: Pekka Enberg Return-path: Received: from mail-pz0-f42.google.com ([209.85.210.42]:36050 "EHLO mail-pz0-f42.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751884Ab1HJFnd (ORCPT ); Wed, 10 Aug 2011 01:43:33 -0400 Received: by pzk37 with SMTP id 37so1255272pzk.1 for ; Tue, 09 Aug 2011 22:43:33 -0700 (PDT) In-Reply-To: <4E421784.2020703@kernel.org> Sender: kvm-owner@vger.kernel.org List-ID: On 08/10/2011 01:30 PM, Pekka Enberg wrote: > On 8/10/11 2:56 AM, Asias He wrote: >> This patch fixes strange characters in serial console. >> >> Before: >> >> [ 0.448000] Serial: 8250/16550 driver, 4 ports, IRQ sharing enabl= ed >> =EF=BF=BD[ 0.695000] serial8250: ttyS0 at I/O 0x3f8 (irq =3D 0) i= s a 16550A >> =EF=BF=BD[ 0.942000] serial8250: ttyS1 at I/O 0x2f8 (irq =3D 0) i= s a 16550A >> =EF=BF=BD[ 1.189000] serial8250: ttyS2 at I/O 0x3e8 (irq =3D 0) i= s a 16550A >> [ 1.194000] Non-volatile memory driver v1.3 >> >> After: >> >> [ 0.541000] Serial: 8250/16550 driver, 4 ports, IRQ sharing enabl= ed >> [ 0.788000] serial8250: ttyS0 at I/O 0x3f8 (irq =3D 0) is a 16550= A >> [ 1.041000] serial8250: ttyS1 at I/O 0x2f8 (irq =3D 0) is a 16550= A >> [ 1.294000] serial8250: ttyS2 at I/O 0x3e8 (irq =3D 0) is a 16550= A >> [ 1.309000] Non-volatile memory driver v1.3 >> >> Signed-off-by: Asias He >> --- >> tools/kvm/term.c | 7 +++++-- >> 1 files changed, 5 insertions(+), 2 deletions(-) >> >> diff --git a/tools/kvm/term.c b/tools/kvm/term.c >> index 2a3e1f0..85b41e7 100644 >> --- a/tools/kvm/term.c >> +++ b/tools/kvm/term.c >> @@ -5,6 +5,7 @@ >> #include >> #include >> #include >> +#include >> >> #include "kvm/read-write.h" >> #include "kvm/term.h" >> @@ -57,8 +58,10 @@ int term_putc(int who, char *addr, int cnt) >> if (who !=3D active_console) >> return -1; >> >> - while (cnt--) >> - fprintf(stdout, "%c", *addr++); >> + while (cnt--) { >> + if (isascii(*addr)) >=20 > Do things like backspace still work with this? Sure. Have a try ;-) http://en.wikipedia.org/wiki/ASCII >=20 >> + fprintf(stdout, "%c", *addr++); >> + } >> >> fflush(stdout); >> return cnt; >=20 >=20 --=20 Best Regards, Asias He