1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2025-01-07 17:17:44 +03:00

import: check overflow

Fixes CID#1548022 and CID#1548075.

(cherry picked from commit f7012a93a7f04fa29c7933a4963aa17fcf120e97)
(cherry picked from commit 11c15905cd4759b89a1da63d05772c1f7c3744a4)
This commit is contained in:
Yu Watanabe 2024-08-01 12:03:54 +09:00 committed by Luca Boccassi
parent 3888d11d2d
commit a920cc9b3a
2 changed files with 10 additions and 0 deletions

View File

@ -408,6 +408,11 @@ static int raw_import_process(RawImport *i) {
goto finish;
}
if ((size_t) l > sizeof(i->buffer) - i->buffer_size) {
r = log_error_errno(SYNTHETIC_ERRNO(EBADMSG), "Read input file exceeded maximum size.");
goto finish;
}
i->buffer_size += l;
if (i->compress.type == IMPORT_COMPRESS_UNKNOWN) {

View File

@ -275,6 +275,11 @@ static int tar_import_process(TarImport *i) {
goto finish;
}
if ((size_t) l > sizeof(i->buffer) - i->buffer_size) {
r = log_error_errno(SYNTHETIC_ERRNO(EBADMSG), "Read input file exceeded maximum size.");
goto finish;
}
i->buffer_size += l;
if (i->compress.type == IMPORT_COMPRESS_UNKNOWN) {