aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/drivers/tty/vt
diff options
context:
space:
mode:
authorNicolas Pitre <npitre@baylibre.com>2025-04-10 15:38:13 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2025-04-11 16:55:55 +0200
commitb35f7a773cbcbfea3bc87a33c7d0f39e34ed83ec (patch)
tree92d170aec40297fda69c203d4c9f58f39ebba86c /drivers/tty/vt
parentvt: pad double-width code points with a zero-white-space (diff)
downloadwireguard-linux-b35f7a773cbcbfea3bc87a33c7d0f39e34ed83ec.tar.xz
wireguard-linux-b35f7a773cbcbfea3bc87a33c7d0f39e34ed83ec.zip
vt: remove zero-white-space handling from conv_uni_to_pc()
This is now taken care of by ucs_is_zero_width(). And in the case where we do want a padding from some zero-width code point then we should also give the legacy displays a space character to work with. Signed-off-by: Nicolas Pitre <npitre@baylibre.com> Link: https://lore.kernel.org/r/6o2ss437-6nps-s943-1n38-54np5587r08s@syhkavp.arg Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/tty/vt')
-rw-r--r--drivers/tty/vt/consolemap.c2
-rw-r--r--drivers/tty/vt/vt.c4
2 files changed, 3 insertions, 3 deletions
diff --git a/drivers/tty/vt/consolemap.c b/drivers/tty/vt/consolemap.c
index 82d70083fead..bb4bb272ebec 100644
--- a/drivers/tty/vt/consolemap.c
+++ b/drivers/tty/vt/consolemap.c
@@ -870,8 +870,6 @@ int conv_uni_to_pc(struct vc_data *conp, long ucs)
return -4; /* Not found */
else if (ucs < 0x20)
return -1; /* Not a printable character */
- else if (ucs == 0xfeff || (ucs >= 0x200b && ucs <= 0x200f))
- return -2; /* Zero-width space */
/*
* UNI_DIRECT_BASE indicates the start of the region in the User Zone
* which always has a 1:1 mapping to the currently loaded font. The
diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c
index dc84f9c6b7c6..0d1d663c7809 100644
--- a/drivers/tty/vt/vt.c
+++ b/drivers/tty/vt/vt.c
@@ -2964,13 +2964,15 @@ static int vc_con_write_normal(struct vc_data *vc, int tc, int c,
goto out;
}
}
+ /* padding for the legacy display like done below */
+ tc = ' ';
}
}
/* Now try to find out how to display it */
tc = conv_uni_to_pc(vc, tc);
if (tc & ~charmask) {
- if (tc == -1 || tc == -2)
+ if (tc == -1)
return -1; /* nothing to display */
/* Glyph not found */