From b7a74bbc41b38fc7f43d66ba868e22a97f08f660 Mon Sep 17 00:00:00 2001 From: Wolfram Schneider Date: Tue, 25 Jan 2022 15:58:29 +0000 Subject: [PATCH] stop on error and display the statstics anyway PR: 32686 --- usr.bin/locate/locate/fastfind.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/usr.bin/locate/locate/fastfind.c b/usr.bin/locate/locate/fastfind.c index b230f93439fd..67d22bfca7b7 100644 --- a/usr.bin/locate/locate/fastfind.c +++ b/usr.bin/locate/locate/fastfind.c @@ -66,6 +66,12 @@ statistic (fp, path_fcodes) } else count += c - OFFSET; + if (count < 0 || count > MAXPATHLEN) { + /* stop on error and display the statstics anyway */ + warnx("corrupted database: %s", path_fcodes); + break; + } + for (p = path + count; (c = getc(fp)) > SWITCH; size++) if (c < PARITY) { if (c == UMLAUT) {