mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-01-12 01:20:14 +00:00
vt: minor cleanup to vc_translate_unicode()
Make it clearer when a sequence is bad. Signed-off-by: Nicolas Pitre <npitre@baylibre.com> Reviewed-by: Jiri Slaby <jirislaby@kernel.org> Link: https://lore.kernel.org/r/20250417184849.475581-2-nico@fluxnic.net Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
3702f72748
commit
d066989a3d
@ -2817,7 +2817,7 @@ static int vc_translate_unicode(struct vc_data *vc, int c, bool *rescan)
|
||||
if ((c & 0xc0) == 0x80) {
|
||||
/* Unexpected continuation byte? */
|
||||
if (!vc->vc_utf_count)
|
||||
return 0xfffd;
|
||||
goto bad_sequence;
|
||||
|
||||
vc->vc_utf_char = (vc->vc_utf_char << 6) | (c & 0x3f);
|
||||
vc->vc_npar++;
|
||||
@ -2829,17 +2829,17 @@ static int vc_translate_unicode(struct vc_data *vc, int c, bool *rescan)
|
||||
/* Reject overlong sequences */
|
||||
if (c <= utf8_length_changes[vc->vc_npar - 1] ||
|
||||
c > utf8_length_changes[vc->vc_npar])
|
||||
return 0xfffd;
|
||||
goto bad_sequence;
|
||||
|
||||
return vc_sanitize_unicode(c);
|
||||
}
|
||||
|
||||
/* Single ASCII byte or first byte of a sequence received */
|
||||
if (vc->vc_utf_count) {
|
||||
/* Continuation byte expected */
|
||||
/* A continuation byte was expected */
|
||||
*rescan = true;
|
||||
vc->vc_utf_count = 0;
|
||||
return 0xfffd;
|
||||
goto bad_sequence;
|
||||
}
|
||||
|
||||
/* Nothing to do if an ASCII byte was received */
|
||||
@ -2858,11 +2858,14 @@ static int vc_translate_unicode(struct vc_data *vc, int c, bool *rescan)
|
||||
vc->vc_utf_count = 3;
|
||||
vc->vc_utf_char = (c & 0x07);
|
||||
} else {
|
||||
return 0xfffd;
|
||||
goto bad_sequence;
|
||||
}
|
||||
|
||||
need_more_bytes:
|
||||
return -1;
|
||||
|
||||
bad_sequence:
|
||||
return 0xfffd;
|
||||
}
|
||||
|
||||
static int vc_translate(struct vc_data *vc, int *c, bool *rescan)
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user