From: Peter Eisentraut Date: Tue, 3 Sep 2019 06:26:55 +0000 (+0200) Subject: pg_checksums: Handle read and write returns correctly X-Git-Tag: REL_12_BETA4~27 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=3e20b7fa408f1b5a1bf17120b55b5473e82a7e63;p=postgresql pg_checksums: Handle read and write returns correctly The read() return was not checking for errors, the write() return was not checking for short writes. Reviewed-by: Michael Paquier Discussion: https://www.postgresql.org/message-id/flat/5de61b6b-8be9-7771-0048-860328efe027%402ndquadrant.com --- diff --git a/src/bin/pg_checksums/pg_checksums.c b/src/bin/pg_checksums/pg_checksums.c index 8c00ec9a3b..971ae73f54 100644 --- a/src/bin/pg_checksums/pg_checksums.c +++ b/src/bin/pg_checksums/pg_checksums.c @@ -198,8 +198,12 @@ scan_file(const char *fn, BlockNumber segmentno) break; if (r != BLCKSZ) { - pg_log_error("could not read block %u in file \"%s\": read %d of %d", - blockno, fn, r, BLCKSZ); + if (r < 0) + pg_log_error("could not read block %u in file \"%s\": %m", + blockno, fn); + else + pg_log_error("could not read block %u in file \"%s\": read %d of %d", + blockno, fn, r, BLCKSZ); exit(1); } blocks++; @@ -222,6 +226,8 @@ scan_file(const char *fn, BlockNumber segmentno) } else if (mode == PG_MODE_ENABLE) { + int w; + /* Set checksum in page header */ header->pd_checksum = csum; @@ -233,10 +239,15 @@ scan_file(const char *fn, BlockNumber segmentno) } /* Write block with checksum */ - if (write(f, buf.data, BLCKSZ) != BLCKSZ) + w = write(f, buf.data, BLCKSZ); + if (w != BLCKSZ) { - pg_log_error("could not write block %u in file \"%s\": %m", - blockno, fn); + if (w < 0) + pg_log_error("could not write block %u in file \"%s\": %m", + blockno, fn); + else + pg_log_error("could not write block %u in file \"%s\": wrote %d of %d", + blockno, fn, w, BLCKSZ); exit(1); } }