mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-03-31 17:10:47 +08:00
Updated H5C__flush_single_entry() in H5C.c to correct
duplicate metadata write bug observed in 1.10.1. Tested parallel/production on jelly parallel/debug & parallel/production on charis (in develop branch)
This commit is contained in:
parent
af3474f05e
commit
85699e41c2
26
src/H5C.c
26
src/H5C.c
@ -6273,17 +6273,27 @@ H5C__flush_single_entry(H5F_t *f, hid_t dxpl_id, H5C_cache_entry_t *entry_ptr,
|
||||
HGOTO_ERROR(H5E_CACHE, H5E_CANTINSERT, FAIL, "unable to insert skip list item")
|
||||
} /* end if */
|
||||
else
|
||||
{
|
||||
#endif /* H5_HAVE_PARALLEL */
|
||||
|
||||
if(entry_ptr->prefetched) {
|
||||
HDassert(entry_ptr->type->id == H5AC_PREFETCHED_ENTRY_ID);
|
||||
mem_type = cache_ptr->class_table_ptr[entry_ptr->prefetch_type_id]->mem_type;
|
||||
} /* end if */
|
||||
else
|
||||
mem_type = entry_ptr->type->mem_type;
|
||||
if(entry_ptr->prefetched) {
|
||||
HDassert(entry_ptr->type->id == H5AC_PREFETCHED_ENTRY_ID);
|
||||
mem_type = cache_ptr->
|
||||
class_table_ptr[entry_ptr->prefetch_type_id]->
|
||||
mem_type;
|
||||
} /* end if */
|
||||
else
|
||||
mem_type = entry_ptr->type->mem_type;
|
||||
|
||||
if(H5F_block_write(f, mem_type, entry_ptr->addr, entry_ptr->size, dxpl_id, entry_ptr->image_ptr) < 0)
|
||||
HGOTO_ERROR(H5E_CACHE, H5E_CANTFLUSH, FAIL, "Can't write image to file")
|
||||
if(H5F_block_write(f, mem_type, entry_ptr->addr,
|
||||
entry_ptr->size, dxpl_id,
|
||||
entry_ptr->image_ptr) < 0)
|
||||
|
||||
HGOTO_ERROR(H5E_CACHE, H5E_CANTFLUSH, FAIL, \
|
||||
"Can't write image to file")
|
||||
#ifdef H5_HAVE_PARALLEL
|
||||
}
|
||||
#endif /* H5_HAVE_PARALLEL */
|
||||
} /* end if */
|
||||
|
||||
/* if the entry has a notify callback, notify it that we have
|
||||
|
Loading…
x
Reference in New Issue
Block a user