• Robert Haas's avatar
    pg_rewind: Fix some problems when copying files >2GB. · a46fe6e8
    Robert Haas authored
    When incrementally updating a file larger than 2GB, the old code could
    either fail outright (if the client asked the server for bytes beyond
    the 2GB boundary) or fail to copy all the blocks that had actually
    been modified (if the server reported a file size to the client in
    excess of 2GB), resulting in data corruption.  Generally, such files
    won't occur anyway, but they might if using a non-default segment size
    or if there the directory contains stray files unrelated to
    PostgreSQL.  Fix by a more prudent choice of data types.
    
    Even with these improvements, this code still uses a mix of different
    types (off_t, size_t, uint64, int64) to represent file sizes and
    offsets, not all of which necessarily have the same width or
    signedness, so further cleanup might be in order here.  However, at
    least now they all have the potential to be 64 bits wide on 64-bit
    platforms.
    
    Kuntal Ghosh and Michael Paquier, with a tweak by me.
    
    Discussion: http://postgr.es/m/CAGz5QC+8gbkz=Brp0TgoKNqHWTzonbPtPex80U0O6Uh_bevbaA@mail.gmail.com
    a46fe6e8
libpq_fetch.c 13.5 KB