mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-02-17 16:10:24 +08:00
[svn-r27206] fix for HDFFV-9418.
- Moving truncate to H5F_flush() where it was done a long time ago. - Add a second H5AC_flush() call after the truncate is done to make sure we write the correct EOA. tested with h5committest
This commit is contained in:
parent
adbb64c6cd
commit
f34bdad87c
17
src/H5Fint.c
17
src/H5Fint.c
@ -857,14 +857,6 @@ H5F_dest(H5F_t *f, hid_t dxpl_id, hbool_t flush)
|
||||
/* Push error, but keep going*/
|
||||
HDONE_ERROR(H5E_FILE, H5E_CANTDEC, FAIL, "can't close property list")
|
||||
|
||||
/* Only truncate the file on an orderly close, with write-access */
|
||||
if(f->closing && (H5F_ACC_RDWR & H5F_INTENT(f))) {
|
||||
/* Truncate the file to the current allocated size */
|
||||
if(H5FD_truncate(f->shared->lf, dxpl_id, (unsigned)TRUE) < 0)
|
||||
/* Push error, but keep going*/
|
||||
HDONE_ERROR(H5E_FILE, H5E_WRITEERROR, FAIL, "low level truncate failed")
|
||||
} /* end if */
|
||||
|
||||
/* Close the file */
|
||||
if(H5FD_close(f->shared->lf) < 0)
|
||||
/* Push error, but keep going*/
|
||||
@ -1182,6 +1174,15 @@ H5F_flush(H5F_t *f, hid_t dxpl_id, hbool_t closing)
|
||||
/* Push error, but keep going*/
|
||||
HDONE_ERROR(H5E_CACHE, H5E_CANTFLUSH, FAIL, "unable to flush metadata cache")
|
||||
|
||||
/* Truncate the file to the current allocated size */
|
||||
if(H5FD_truncate(f->shared->lf, dxpl_id, (unsigned)TRUE) < 0)
|
||||
HDONE_ERROR(H5E_FILE, H5E_WRITEERROR, FAIL, "low level truncate failed")
|
||||
|
||||
/* Flush the entire metadata cache again since the EOA could have changed in the truncate call. */
|
||||
if(H5AC_flush(f, dxpl_id) < 0)
|
||||
/* Push error, but keep going*/
|
||||
HDONE_ERROR(H5E_CACHE, H5E_CANTFLUSH, FAIL, "unable to flush metadata cache")
|
||||
|
||||
/* Set up I/O info for operation */
|
||||
fio_info.f = f;
|
||||
if(NULL == (fio_info.dxpl = (H5P_genplist_t *)H5I_object(dxpl_id)))
|
||||
|
Loading…
Reference in New Issue
Block a user