Received: by 10.223.176.5 with SMTP id f5csp3496275wra; Mon, 29 Jan 2018 14:09:23 -0800 (PST) X-Google-Smtp-Source: AH8x226DJcPyKb64RZ8pqs+9EJ6H8Ci/6upiY5ctb8AvhnK/2R61G2CIUaAaSXlQDqvCpjqU+K3i X-Received: by 10.98.157.26 with SMTP id i26mr28033151pfd.12.1517263763000; Mon, 29 Jan 2018 14:09:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517263762; cv=none; d=google.com; s=arc-20160816; b=vfICE5XL+6hYyltrOaaQoogaNakwidpA/TEw2nYbAJi7pxXkkWPDYFJQ7WblWa1ojw kDyGSVyj+sERSCMZ7vWc7fXW31IuVHXpjJo9SxTSLuHm6CeZ1uUHwgOsqQWJ5/CEOt62 GxJv7+MO2FSEPOH4tkdz+xN1bmliYKu3MnYYaPxeL3qoZpf9pADBJn6jZQa9Btwf54B0 PgDsQ2y1kcjmoDiqf7A78ipN/v8HEclTQrIhfpB/GZQJspaVez8baVbU4Ab76axy2uVx Xg/UNHnw9tAo0Jkk6iH94F2DgYAGLpWAKhB9csFfU1Up74/oOm3xWtofsekjfAS9Pk6p 4IoQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :arc-authentication-results; bh=MvP7ygkh3TlIKyuzJ0ctpFSNJw+IWh7cnfJzfA6UyaU=; b=XMPYs5p7W3JwXbUM0/DHWaueoVeyjWGQoY2NU24ggGs4+4vP9l++IiV+xhgOeb7fAF CmnTeuPALPw1F/4yZTrWWWgs1b/dSs9CsQgY07Dxc0abUnNO7YZD8Xg91+bSGBnJ8+YN H4zuccNLXWx67S+30jCaXXYJc+g2m4V8wbt4zFcaX5nyeInqEmz32BsqyzR3R4GH8Uo2 M+CRXiy1xUkEo6sT8P7ECPvsXJMcJodyUM9/vYsk9k/Oid8gt+OePXdb1kiAzUnZdGD3 EviRiNestIMDYMJ4JcXoNX3Xa+Y9U/izI5A8oyf7Wdeu91RzixGYL+/CEUKPEMTFcBQF G8ZQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=gentoo.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j11-v6si10252608pll.485.2018.01.29.14.09.08; Mon, 29 Jan 2018 14:09:22 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=gentoo.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752660AbeA2WI3 (ORCPT + 99 others); Mon, 29 Jan 2018 17:08:29 -0500 Received: from smtp.gentoo.org ([140.211.166.183]:36338 "EHLO smtp.gentoo.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751903AbeA2WI2 (ORCPT ); Mon, 29 Jan 2018 17:08:28 -0500 Received: from vapier.lan (localhost [127.0.0.1]) by smtp.gentoo.org (Postfix) with ESMTP id 1A8E9335C3C; Mon, 29 Jan 2018 22:08:27 +0000 (UTC) From: Mike Frysinger To: linux-kernel@vger.kernel.org, Greg Kroah-Hartman , Jiri Slaby Cc: Egmont Koblinger Subject: [PATCH] vt: change SGR 21 to follow the standards Date: Mon, 29 Jan 2018 17:08:21 -0500 Message-Id: <20180129220821.24100-1-vapier@gentoo.org> X-Mailer: git-send-email 2.16.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Mike Frysinger ECMA-48 [1] (aka ISO 6429) has defined SGR 21 as "doubly underlined" since at least March 1984. The Linux kernel has treated it as SGR 22 "normal intensity" since it was added in Linux-0.96b in June 1992. Before that, it was simply ignored. Other terminal emulators have either ignored it, or treat it as double underline now. xterm for example added support in its 304 release (May 2014) [2] where it was previously ignoring it. Changing this behavior shouldn't be an issue: - It isn't a named capability in ncurses's terminfo database, so no script is using libtinfo/libcurses to look this up, or using tput to query & output the right sequence. - Any script assuming SGR 21 will reset intensity in all terminals already do not work correctly on non-Linux VTs (including running under screen/tmux/etc...). - If someone has written a script that only runs in the Linux VT, and they're using SGR 21 (instead of SGR 22), the output should still be readable. imo it's important to change this as the Linux VT's non-conformance is sometimes used as an argument for other terminal emulators to not implement SGR 21 at all, or do so incorrectly. [1]: https://www.ecma-international.org/publications/standards/Ecma-048.htm [2]: https://github.com/ThomasDickey/xterm-snapshots/commit/2fd29cb98d214cb536bcafbee00bc73b3f1eeb9d Signed-off-by: Mike Frysinger --- drivers/tty/vt/vt.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c index 88b902c525d7..16c0fcd6904a 100644 --- a/drivers/tty/vt/vt.c +++ b/drivers/tty/vt/vt.c @@ -1354,6 +1354,11 @@ static void csi_m(struct vc_data *vc) case 3: vc->vc_italic = 1; break; + case 21: + /* + * No console drivers support double underline, so + * convert it to a single underline. + */ case 4: vc->vc_underline = 1; break; @@ -1389,7 +1394,6 @@ static void csi_m(struct vc_data *vc) vc->vc_disp_ctrl = 1; vc->vc_toggle_meta = 1; break; - case 21: case 22: vc->vc_intensity = 1; break; -- 2.16.1