uint32      crc_offset;
    pg_crc32c   calc_crc,
                file_crc;
+   int         r;
 
    TwoPhaseFilePath(path, xid);
 
        if (give_warnings)
            ereport(WARNING,
                    (errcode_for_file_access(),
-                    errmsg("could not open two-phase state file \"%s\": %m",
-                           path)));
+                    errmsg("could not open file \"%s\": %m", path)));
        return NULL;
    }
 
            errno = save_errno;
            ereport(WARNING,
                    (errcode_for_file_access(),
-                    errmsg("could not stat two-phase state file \"%s\": %m",
-                           path)));
+                    errmsg("could not stat file \"%s\": %m", path)));
        }
        return NULL;
    }
    buf = (char *) palloc(stat.st_size);
 
    pgstat_report_wait_start(WAIT_EVENT_TWOPHASE_FILE_READ);
-   if (read(fd, buf, stat.st_size) != stat.st_size)
+   r = read(fd, buf, stat.st_size);
+   if (r != stat.st_size)
    {
        int         save_errno = errno;
 
        CloseTransientFile(fd);
        if (give_warnings)
        {
-           errno = save_errno;
-           ereport(WARNING,
-                   (errcode_for_file_access(),
-                    errmsg("could not read two-phase state file \"%s\": %m",
-                           path)));
+           if (r < 0)
+           {
+               errno = save_errno;
+               ereport(WARNING,
+                       (errcode_for_file_access(),
+                        errmsg("could not read file \"%s\": %m", path)));
+           }
+           else
+               ereport(WARNING,
+                       (errmsg("could not read file \"%s\": read %d of %zu",
+                               path, r, stat.st_size)));
        }
        pfree(buf);
        return NULL;
        if (errno != ENOENT || giveWarning)
            ereport(WARNING,
                    (errcode_for_file_access(),
-                    errmsg("could not remove two-phase state file \"%s\": %m",
-                           path)));
+                    errmsg("could not remove file \"%s\": %m", path)));
 }
 
 /*
    if (fd < 0)
        ereport(ERROR,
                (errcode_for_file_access(),
-                errmsg("could not recreate two-phase state file \"%s\": %m",
-                       path)));
+                errmsg("could not recreate file \"%s\": %m", path)));
 
    /* Write content and CRC */
    pgstat_report_wait_start(WAIT_EVENT_TWOPHASE_FILE_WRITE);
        errno = save_errno ? save_errno : ENOSPC;
        ereport(ERROR,
                (errcode_for_file_access(),
-                errmsg("could not write two-phase state file: %m")));
+                errmsg("could not write file \"%s\": %m", path)));
    }
    if (write(fd, &statefile_crc, sizeof(pg_crc32c)) != sizeof(pg_crc32c))
    {
        errno = save_errno ? save_errno : ENOSPC;
        ereport(ERROR,
                (errcode_for_file_access(),
-                errmsg("could not write two-phase state file: %m")));
+                errmsg("could not write file \"%s\": %m", path)));
    }
    pgstat_report_wait_end();
 
        errno = save_errno;
        ereport(ERROR,
                (errcode_for_file_access(),
-                errmsg("could not fsync two-phase state file: %m")));
+                errmsg("could not fsync file \"%s\": %m", path)));
    }
    pgstat_report_wait_end();
 
    if (CloseTransientFile(fd) != 0)
        ereport(ERROR,
                (errcode_for_file_access(),
-                errmsg("could not close two-phase state file: %m")));
+                errmsg("could not close file \"%s\": %m", path)));
 }
 
 /*
 
 
        if (nread > 0)
        {
+           int         r;
+
            if (nread > sizeof(buffer))
                nread = sizeof(buffer);
            errno = 0;
            pgstat_report_wait_start(WAIT_EVENT_WAL_COPY_READ);
-           if (read(srcfd, buffer, nread) != nread)
+           r = read(srcfd, buffer, nread);
+           if (r != nread)
            {
-               if (errno != 0)
+               if (r < 0)
                    ereport(ERROR,
                            (errcode_for_file_access(),
                             errmsg("could not read file \"%s\": %m",
                                    path)));
                else
                    ereport(ERROR,
-                           (errmsg("not enough data in file \"%s\"",
-                                   path)));
+                           (errmsg("could not read file \"%s\": read %d of %zu",
+                                   path, r, (Size) nread)));
            }
            pgstat_report_wait_end();
        }
    if (fd < 0)
        ereport(PANIC,
                (errcode_for_file_access(),
-                errmsg("could not open control file \"%s\": %m",
+                errmsg("could not open file \"%s\": %m",
                        XLOG_CONTROL_FILE)));
 
    pgstat_report_wait_start(WAIT_EVENT_CONTROL_FILE_READ);
        if (r < 0)
            ereport(PANIC,
                    (errcode_for_file_access(),
-                    errmsg("could not read from control file: %m")));
+                    errmsg("could not read file \"%s\": %m",
+                           XLOG_CONTROL_FILE)));
        else
            ereport(PANIC,
-                   (errmsg("could not read from control file: read %d bytes, expected %d", r, (int) sizeof(ControlFileData))));
+                   (errmsg("could not read file \"%s\": read %d of %zu",
+                           XLOG_CONTROL_FILE, r, sizeof(ControlFileData))));
    }
    pgstat_report_wait_end();
 
    int         emode = private->emode;
    uint32      targetPageOff;
    XLogSegNo   targetSegNo PG_USED_FOR_ASSERTS_ONLY;
+   int         r;
 
    XLByteToSeg(targetPagePtr, targetSegNo, wal_segment_size);
    targetPageOff = XLogSegmentOffset(targetPagePtr, wal_segment_size);
    }
 
    pgstat_report_wait_start(WAIT_EVENT_WAL_READ);
-   if (read(readFile, readBuf, XLOG_BLCKSZ) != XLOG_BLCKSZ)
+   r = read(readFile, readBuf, XLOG_BLCKSZ);
+   if (r != XLOG_BLCKSZ)
    {
        char        fname[MAXFNAMELEN];
        int         save_errno = errno;
 
        pgstat_report_wait_end();
        XLogFileName(fname, curFileTLI, readSegNo, wal_segment_size);
-       errno = save_errno;
-       ereport(emode_for_corrupt_record(emode, targetPagePtr + reqLen),
-               (errcode_for_file_access(),
-                errmsg("could not read from log segment %s, offset %u: %m",
-                       fname, readOff)));
+       if (r < 0)
+       {
+           errno = save_errno;
+           ereport(emode_for_corrupt_record(emode, targetPagePtr + reqLen),
+                   (errcode_for_file_access(),
+                    errmsg("could not read from log segment %s, offset %u: %m",
+                           fname, readOff)));
+       }
+       else
+           ereport(emode_for_corrupt_record(emode, targetPagePtr + reqLen),
+                   (errmsg("could not read from log segment %s, offset %u: read %d of %zu",
+                           fname, readOff, r, (Size) XLOG_BLCKSZ)));
        goto next_record_is_invalid;
    }
    pgstat_report_wait_end();
 
    /* verify magic, that is written even if nothing was active */
    readBytes = read(fd, &magic, sizeof(magic));
    if (readBytes != sizeof(magic))
-       ereport(PANIC,
-               (errmsg("could not read file \"%s\": %m",
-                       path)));
+   {
+       if (readBytes < 0)
+           ereport(PANIC,
+                   (errmsg("could not read file \"%s\": %m",
+                           path)));
+       else
+           ereport(PANIC,
+                   (errmsg("could not read file \"%s\": read %d of %zu",
+                           path, readBytes, sizeof(magic))));
+   }
    COMP_CRC32C(crc, &magic, sizeof(magic));
 
    if (magic != REPLICATION_STATE_MAGIC)
 
        int         save_errno = errno;
 
        CloseTransientFile(fd);
-       errno = save_errno;
-       ereport(ERROR,
-               (errcode_for_file_access(),
-                errmsg("could not read file \"%s\", read %d of %d: %m",
-                       path, readBytes, (int) SnapBuildOnDiskConstantSize)));
+
+       if (readBytes < 0)
+       {
+           errno = save_errno;
+           ereport(ERROR,
+                   (errcode_for_file_access(),
+                    errmsg("could not read file \"%s\": %m", path)));
+       }
+       else
+           ereport(ERROR,
+                   (errmsg("could not read file \"%s\": read %d of %zu",
+                           path, readBytes, SnapBuildOnDiskConstantSize)));
    }
 
    if (ondisk.magic != SNAPBUILD_MAGIC)
        int         save_errno = errno;
 
        CloseTransientFile(fd);
-       errno = save_errno;
-       ereport(ERROR,
-               (errcode_for_file_access(),
-                errmsg("could not read file \"%s\", read %d of %d: %m",
-                       path, readBytes, (int) sizeof(SnapBuild))));
+
+       if (readBytes < 0)
+       {
+           errno = save_errno;
+           ereport(ERROR,
+                   (errcode_for_file_access(),
+                    errmsg("could not read file \"%s\": %m", path)));
+       }
+       else
+           ereport(ERROR,
+                   (errmsg("could not read file \"%s\": read %d of %zu",
+                           path, readBytes, sizeof(SnapBuild))));
    }
    COMP_CRC32C(checksum, &ondisk.builder, sizeof(SnapBuild));
 
        int         save_errno = errno;
 
        CloseTransientFile(fd);
-       errno = save_errno;
-       ereport(ERROR,
-               (errcode_for_file_access(),
-                errmsg("could not read file \"%s\", read %d of %d: %m",
-                       path, readBytes, (int) sz)));
+
+       if (readBytes < 0)
+       {
+           errno = save_errno;
+           ereport(ERROR,
+                   (errcode_for_file_access(),
+                    errmsg("could not read file \"%s\": %m", path)));
+       }
+       else
+           ereport(ERROR,
+                   (errmsg("could not read file \"%s\": read %d of %zu",
+                           path, readBytes, sz)));
    }
    COMP_CRC32C(checksum, ondisk.builder.was_running.was_xip, sz);
 
        int         save_errno = errno;
 
        CloseTransientFile(fd);
-       errno = save_errno;
-       ereport(ERROR,
-               (errcode_for_file_access(),
-                errmsg("could not read file \"%s\", read %d of %d: %m",
-                       path, readBytes, (int) sz)));
+
+       if (readBytes < 0)
+       {
+           errno = save_errno;
+           ereport(ERROR,
+                   (errcode_for_file_access(),
+                    errmsg("could not read file \"%s\": %m", path)));
+       }
+       else
+           ereport(ERROR,
+                   (errmsg("could not read file \"%s\": read %d of %zu",
+                           path, readBytes, sz)));
    }
    COMP_CRC32C(checksum, ondisk.builder.committed.xip, sz);
 
 
 
        CloseTransientFile(fd);
        errno = saved_errno;
-       ereport(PANIC,
-               (errcode_for_file_access(),
-                errmsg("could not read file \"%s\", read %d of %u: %m",
-                       path, readBytes,
-                       (uint32) ReplicationSlotOnDiskConstantSize)));
+       if (readBytes < 0)
+           ereport(PANIC,
+                   (errcode_for_file_access(),
+                    errmsg("could not read file \"%s\": %m", path)));
+       else
+           ereport(PANIC,
+                   (errmsg("could not read file \"%s\": read %d of %zu",
+                           path, readBytes,
+                           ReplicationSlotOnDiskConstantSize)));
    }
 
    /* verify magic */
 
        CloseTransientFile(fd);
        errno = saved_errno;
-       ereport(PANIC,
-               (errcode_for_file_access(),
-                errmsg("could not read file \"%s\", read %d of %u: %m",
-                       path, readBytes, cp.length)));
+       if (readBytes < 0)
+           ereport(PANIC,
+                   (errcode_for_file_access(),
+                    errmsg("could not read file \"%s\": %m", path)));
+       else
+           ereport(PANIC,
+                   (errmsg("could not read file \"%s\": read %d of %zu",
+                           path, readBytes, (Size) cp.length)));
    }
 
    CloseTransientFile(fd);
 
        pgstat_report_wait_start(WAIT_EVENT_WALSENDER_TIMELINE_HISTORY_READ);
        nread = read(fd, rbuf, sizeof(rbuf));
        pgstat_report_wait_end();
-       if (nread <= 0)
+       if (nread < 0)
            ereport(ERROR,
                    (errcode_for_file_access(),
                     errmsg("could not read file \"%s\": %m",
                            path)));
+       else if (nread == 0)
+           ereport(ERROR,
+                   (errmsg("could not read file \"%s\": read %d of %zu",
+                           path, nread, bytesleft)));
+
        pq_sendbytes(&buf, rbuf, nread);
        bytesleft -= nread;
    }
        pgstat_report_wait_start(WAIT_EVENT_WAL_READ);
        readbytes = read(sendFile, p, segbytes);
        pgstat_report_wait_end();
-       if (readbytes <= 0)
+       if (readbytes < 0)
        {
            ereport(ERROR,
                    (errcode_for_file_access(),
-                    errmsg("could not read from log segment %s, offset %u, length %lu: %m",
+                    errmsg("could not read from log segment %s, offset %u, length %zu: %m",
+                           XLogFileNameP(curFileTimeLine, sendSegNo),
+                           sendOff, (Size) segbytes)));
+       }
+       else if (readbytes == 0)
+       {
+           ereport(ERROR,
+                   (errmsg("could not read from log segment %s, offset %u: read %d of %zu",
                            XLogFileNameP(curFileTimeLine, sendSegNo),
-                           sendOff, (unsigned long) segbytes)));
+                           sendOff, readbytes, (Size) segbytes)));
        }
 
        /* Update state for read */
 
    char        mapfilename[MAXPGPATH];
    pg_crc32c   crc;
    int         fd;
+   int         r;
 
    if (shared)
    {
    if (fd < 0)
        ereport(FATAL,
                (errcode_for_file_access(),
-                errmsg("could not open relation mapping file \"%s\": %m",
+                errmsg("could not open file \"%s\": %m",
                        mapfilename)));
 
    /*
     * are able to access any relation that's affected by the change.
     */
    pgstat_report_wait_start(WAIT_EVENT_RELATION_MAP_READ);
-   if (read(fd, map, sizeof(RelMapFile)) != sizeof(RelMapFile))
-       ereport(FATAL,
-               (errcode_for_file_access(),
-                errmsg("could not read relation mapping file \"%s\": %m",
-                       mapfilename)));
+   r = read(fd, map, sizeof(RelMapFile));
+   if (r != sizeof(RelMapFile))
+   {
+       if (r < 0)
+           ereport(FATAL,
+                   (errcode_for_file_access(),
+                    errmsg("could not read file \"%s\": %m", mapfilename)));
+       else
+           ereport(FATAL,
+                   (errmsg("could not read file \"%s\": read %d of %zu",
+                           mapfilename, r, sizeof(RelMapFile))));
+   }
    pgstat_report_wait_end();
 
    CloseTransientFile(fd);
    if (fd < 0)
        ereport(ERROR,
                (errcode_for_file_access(),
-                errmsg("could not open relation mapping file \"%s\": %m",
+                errmsg("could not open file \"%s\": %m",
                        mapfilename)));
 
    if (write_wal)
            errno = ENOSPC;
        ereport(ERROR,
                (errcode_for_file_access(),
-                errmsg("could not write to relation mapping file \"%s\": %m",
+                errmsg("could not write file \"%s\": %m",
                        mapfilename)));
    }
    pgstat_report_wait_end();
    if (pg_fsync(fd) != 0)
        ereport(ERROR,
                (errcode_for_file_access(),
-                errmsg("could not fsync relation mapping file \"%s\": %m",
+                errmsg("could not fsync file \"%s\": %m",
                        mapfilename)));
    pgstat_report_wait_end();
 
    if (CloseTransientFile(fd))
        ereport(ERROR,
                (errcode_for_file_access(),
-                errmsg("could not close relation mapping file \"%s\": %m",
+                errmsg("could not close file \"%s\": %m",
                        mapfilename)));
 
    /*
 
            char        buf[4];
            int         bytes_out;
            char        fullpath[MAXPGPATH * 2];
+           int         r;
 
            snprintf(fullpath, sizeof(fullpath), "%s/%s", basedir, dirent->d_name);
 
                        progname, fullpath, strerror(errno));
                disconnect_and_exit(1);
            }
-           if (read(fd, (char *) buf, sizeof(buf)) != sizeof(buf))
+           r = read(fd, (char *) buf, sizeof(buf));
+           if (r != sizeof(buf))
            {
-               fprintf(stderr, _("%s: could not read compressed file \"%s\": %s\n"),
-                       progname, fullpath, strerror(errno));
+               if (r < 0)
+                   fprintf(stderr, _("%s: could not read compressed file \"%s\": %s\n"),
+                           progname, fullpath, strerror(errno));
+               else
+                   fprintf(stderr, _("%s: could not read compressed file \"%s\": read %d of %zu\n"),
+                           progname, fullpath, r, sizeof(buf));
                disconnect_and_exit(1);
            }
 
 
    struct stat statbuf;
    char        fullpath[MAXPGPATH];
    int         len;
+   int         r;
 
    snprintf(fullpath, sizeof(fullpath), "%s/%s", datadir, path);
 
 
    buffer = pg_malloc(len + 1);
 
-   if (read(fd, buffer, len) != len)
-       pg_fatal("could not read file \"%s\": %s\n",
-                fullpath, strerror(errno));
+   r = read(fd, buffer, len);
+   if (r != len)
+   {
+       if (r < 0)
+           pg_fatal("could not read file \"%s\": %s\n",
+                    fullpath, strerror(errno));
+       else
+           pg_fatal("could not read file \"%s\": read %d of %zu\n",
+                    fullpath, r, (Size) len);
+   }
    close(fd);
 
    /* Zero-terminate the buffer. */
 
    uint32      targetPageOff;
    XLogRecPtr  targetSegEnd;
    XLogSegNo   targetSegNo;
+   int         r;
 
    XLByteToSeg(targetPagePtr, targetSegNo, WalSegSz);
    XLogSegNoOffsetToRecPtr(targetSegNo + 1, 0, WalSegSz, targetSegEnd);
        return -1;
    }
 
-   if (read(xlogreadfd, readBuf, XLOG_BLCKSZ) != XLOG_BLCKSZ)
+
+   r = read(xlogreadfd, readBuf, XLOG_BLCKSZ);
+   if (r != XLOG_BLCKSZ)
    {
-       printf(_("could not read from file \"%s\": %s\n"), xlogfpath,
-              strerror(errno));
+       if (r < 0)
+           printf(_("could not read file \"%s\": %s\n"), xlogfpath,
+                  strerror(errno));
+       else
+           printf(_("could not read file \"%s\": read %d of %zu\n"),
+                  xlogfpath, r, (Size) XLOG_BLCKSZ);
+
        return -1;
    }
 
 
    if (fd >= 0)
    {
        char        buf[XLOG_BLCKSZ];
+       int         r;
 
-       if (read(fd, buf, XLOG_BLCKSZ) == XLOG_BLCKSZ)
+       r = read(fd, buf, XLOG_BLCKSZ);
+       if (r == XLOG_BLCKSZ)
        {
            XLogLongPageHeader longhdr = (XLogLongPageHeader) buf;
 
                fatal_error("could not read file \"%s\": %s",
                            fname, strerror(errno));
            else
-               fatal_error("not enough data in file \"%s\"", fname);
+               fatal_error("could not read file \"%s\": read %d of %zu",
+                           fname, r, (Size) XLOG_BLCKSZ);
        }
        close(fd);
        return true;
        {
            int         err = errno;
            char        fname[MAXPGPATH];
+           int         save_errno = errno;
 
            XLogFileName(fname, timeline_id, sendSegNo, WalSegSz);
-
-           fatal_error("could not read from log file %s, offset %u, length %d: %s",
-                       fname, sendOff, segbytes, strerror(err));
+           errno = save_errno;
+
+           if (readbytes < 0)
+               fatal_error("could not read from log file %s, offset %u, length %d: %s",
+                           fname, sendOff, segbytes, strerror(err));
+           else if (readbytes == 0)
+               fatal_error("could not read from log file %s, offset %u: read %d of %zu",
+                           fname, sendOff, readbytes, (Size) segbytes);
        }
 
        /* Update state for read */
 
        else
 #ifndef FRONTEND
            ereport(ERROR,
-                   (errmsg("could not read file \"%s\": read %d of %d",
-                           ControlFilePath, r, (int) sizeof(ControlFileData))));
+                   (errmsg("could not read file \"%s\": read %d of %zu",
+                           ControlFilePath, r, sizeof(ControlFileData))));
 #else
        {
-           fprintf(stderr, _("%s: could not read file \"%s\": read %d of %d\n"),
-                   progname, ControlFilePath, r, (int) sizeof(ControlFileData));
+           fprintf(stderr, _("%s: could not read file \"%s\": read %d of %zu\n"),
+                   progname, ControlFilePath, r, sizeof(ControlFileData));
            exit(EXIT_FAILURE);
        }
 #endif