1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2024-12-18 12:28:09 +00:00

fix(legacy): Fix split_message() to correctly handle strings that are not null-terminated.

This commit is contained in:
Andrew Kozlik 2021-11-10 08:28:38 +01:00 committed by Andrew Kozlik
parent d8de95767d
commit 0737deedc4

View File

@ -189,18 +189,17 @@ const char **split_message(const uint8_t *msg, uint32_t len, uint32_t rowlen) {
if (rowlen > 32) {
rowlen = 32;
}
memzero(str, sizeof(str));
strlcpy(str[0], (char *)msg, rowlen + 1);
if (len > rowlen) {
strlcpy(str[1], (char *)msg + rowlen, rowlen + 1);
for (int i = 0; i < 4; ++i) {
size_t show_len = strnlen((char *)msg, MIN(rowlen, len));
memcpy(str[i], (char *)msg, show_len);
str[i][show_len] = '\0';
msg += show_len;
len -= show_len;
}
if (len > rowlen * 2) {
strlcpy(str[2], (char *)msg + rowlen * 2, rowlen + 1);
}
if (len > rowlen * 3) {
strlcpy(str[3], (char *)msg + rowlen * 3, rowlen + 1);
}
if (len > rowlen * 4) {
if (len > 0) {
str[3][rowlen - 1] = '.';
str[3][rowlen - 2] = '.';
str[3][rowlen - 3] = '.';