summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorQuincey Koziol <koziol@hdfgroup.org>2003-10-10 15:23:46 (GMT)
committerQuincey Koziol <koziol@hdfgroup.org>2003-10-10 15:23:46 (GMT)
commit232de6ee7293b8865880cd29b7ad893687015f65 (patch)
tree447239fc64be6f73f21e0c820f4e544c35661a2a
parentd04ba65f9d10799009a9da3471ec7edd9becee7c (diff)
downloadhdf5-232de6ee7293b8865880cd29b7ad893687015f65.zip
hdf5-232de6ee7293b8865880cd29b7ad893687015f65.tar.gz
hdf5-232de6ee7293b8865880cd29b7ad893687015f65.tar.bz2
[svn-r7594] Purpose:
Bug fix Description: The 'char *' type is one of the "strongly" aligned types on Crays, but a 'void *' is "weakly" aligned. So, assigning a 'void *' (pointing to a location to place a 'char *') to a 'char **' can change the pointer value during the assignment. Solution: Don't alias the 'void *' where the variable-length information ('char *' or 'hvl_t') will go. Use a temporary variable on the stack to build up the information about the VL string or sequence and then memcpy() the temporary variable directly to the location pointed to with the 'void *' Platforms tested: FreeBSD 4.9 (sleipnir) Cray SV1 (wind) specific to Cray problems, h5committest not necessary.
-rw-r--r--src/H5Tvlen.c20
1 files changed, 11 insertions, 9 deletions
diff --git a/src/H5Tvlen.c b/src/H5Tvlen.c
index ad46f78..274d122 100644
--- a/src/H5Tvlen.c
+++ b/src/H5Tvlen.c
@@ -348,7 +348,7 @@ H5T_vlen_seq_mem_write(H5F_t UNUSED *f, hid_t dxpl_id, void *vl_addr, void *buf,
{
H5MM_allocate_t alloc_func; /* Vlen allocation function */
void *alloc_info; /* Vlen allocation information */
- hvl_t *vl=(hvl_t *)vl_addr; /* Pointer to the user's hvl_t information */
+ hvl_t vl; /* Temporary hvl_t to use during operation */
size_t len;
H5P_genplist_t *plist; /* Property list */
herr_t ret_value=SUCCEED; /* Return value */
@@ -356,7 +356,7 @@ H5T_vlen_seq_mem_write(H5F_t UNUSED *f, hid_t dxpl_id, void *vl_addr, void *buf,
FUNC_ENTER_NOAPI(H5T_vlen_seq_mem_write, FAIL);
/* check parameters */
- assert(vl);
+ assert(vl_addr);
assert(buf);
if(seq_len!=0) {
@@ -373,23 +373,26 @@ H5T_vlen_seq_mem_write(H5F_t UNUSED *f, hid_t dxpl_id, void *vl_addr, void *buf,
HGOTO_ERROR(H5E_PLIST, H5E_CANTGET, FAIL, "unable to get value");
if(alloc_func!=NULL) {
- if(NULL==(vl->p=(alloc_func)(len,alloc_info)))
+ if(NULL==(vl.p=(alloc_func)(len,alloc_info)))
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, FAIL, "memory allocation failed for VL data");
} /* end if */
else { /* Default to system malloc */
- if(NULL==(vl->p=H5MM_malloc(len)))
+ if(NULL==(vl.p=H5MM_malloc(len)))
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, FAIL, "memory allocation failed for VL data");
} /* end else */
/* Copy the data into the newly allocated buffer */
- HDmemcpy(vl->p,buf,len);
+ HDmemcpy(vl.p,buf,len);
} /* end if */
else
- vl->p=NULL;
+ vl.p=NULL;
/* Set the sequence length */
- H5_ASSIGN_OVERFLOW(vl->len,seq_len,hsize_t,size_t);
+ H5_ASSIGN_OVERFLOW(vl.len,seq_len,hsize_t,size_t);
+
+ /* Set pointer in user's buffer with memcpy, to avoid alignment issues */
+ HDmemcpy(vl_addr,&vl,sizeof(hvl_t));
done:
FUNC_LEAVE_NOAPI(ret_value);
@@ -488,7 +491,6 @@ H5T_vlen_str_mem_write(H5F_t UNUSED *f, hid_t dxpl_id, void *vl_addr, void *buf,
{
H5MM_allocate_t alloc_func; /* Vlen allocation function */
void *alloc_info; /* Vlen allocation information */
- char **s=(char **)vl_addr; /* Pointer to the user's hvl_t information */
char *t; /* Pointer to temporary buffer allocated */
size_t len; /* Maximum length of the string to copy */
H5P_genplist_t *plist; /* Property list */
@@ -524,7 +526,7 @@ H5T_vlen_str_mem_write(H5F_t UNUSED *f, hid_t dxpl_id, void *vl_addr, void *buf,
t[len]='\0';
/* Set pointer in user's buffer with memcpy, to avoid alignment issues */
- HDmemcpy(s,&t,sizeof(char *));
+ HDmemcpy(vl_addr,&t,sizeof(char *));
done:
FUNC_LEAVE_NOAPI(ret_value);