Skip to content

Commit

Permalink
Fix selection when using vlen types
Browse files Browse the repository at this point in the history
  • Loading branch information
mattjala committed Feb 29, 2024
1 parent 3720b46 commit c9a4183
Show file tree
Hide file tree
Showing 3 changed files with 179 additions and 104 deletions.
58 changes: 56 additions & 2 deletions src/rest_vol.c
Original file line number Diff line number Diff line change
Expand Up @@ -3635,6 +3635,8 @@ RV_curl_multi_perform(CURL *curl_multi_handle, dataset_transfer_info *transfer_i
fail_count++;
}
else if (response_code == 200) {
H5T_class_t dtype_class = H5T_NO_CLASS;

num_finished++;
succeed_count++;

Expand All @@ -3661,8 +3663,60 @@ RV_curl_multi_perform(CURL *curl_multi_handle, dataset_transfer_info *transfer_i
transfer_info[handle_index].curl_easy_handle = NULL;

if (transfer_info[handle_index].transfer_type == WRITE) {
RV_free(transfer_info[handle_index].u.write_info.alloc_write_buffer);
transfer_info[handle_index].u.write_info.alloc_write_buffer = NULL;
if (transfer_info[handle_index].tconv_buf) {
if ((dtype_class = H5Tget_class(transfer_info[handle_index].mem_type_id)) ==
H5T_NO_CLASS)
FUNC_DONE_ERROR(H5E_DATASET, H5E_CANTGET, FAIL, "can't get mem dtype class");

/* Clean up memory allocated by type conversion of vlen types */
if (dtype_class == H5T_VLEN) {
/* Buffer was gathered before type conversion, so we can manually free vlen
* memory by iteration */
hssize_t num_elems = 0;
if ((num_elems = H5Sget_select_npoints(
transfer_info[handle_index].mem_space_id)) <= 0)
FUNC_DONE_ERROR(H5E_DATASET, H5E_CANTGET, FAIL,
"can't get number of elements in dataspace");

hvl_t *vlen_buf = (hvl_t *)transfer_info[handle_index].tconv_buf;
for (size_t i = 0; i < (size_t)num_elems; i++) {
if (vlen_buf[i].p) {
RV_free(vlen_buf[i].p);
vlen_buf[i].p = NULL;
}
}
}
}

if (transfer_info[handle_index].u.write_info.gather_buf) {
RV_free(transfer_info[handle_index].u.write_info.gather_buf);
transfer_info[handle_index].u.write_info.gather_buf = NULL;
}

if (transfer_info[handle_index].u.write_info.serialize_buf) {
RV_free(transfer_info[handle_index].u.write_info.serialize_buf);
transfer_info[handle_index].u.write_info.serialize_buf = NULL;
}

if (transfer_info[handle_index].u.write_info.base64_encoded_values) {
RV_free(transfer_info[handle_index].u.write_info.base64_encoded_values);
transfer_info[handle_index].u.write_info.base64_encoded_values = NULL;
}

if (transfer_info[handle_index].u.write_info.selection_buf) {
RV_free(transfer_info[handle_index].u.write_info.selection_buf);
transfer_info[handle_index].u.write_info.selection_buf = NULL;
}
}

if (transfer_info[handle_index].tconv_buf) {
RV_free(transfer_info[handle_index].tconv_buf);
transfer_info[handle_index].tconv_buf = NULL;
}

if (transfer_info[handle_index].bkg_buf) {
RV_free(transfer_info[handle_index].bkg_buf);
transfer_info[handle_index].bkg_buf = NULL;
}

RV_free(transfer_info[handle_index].request_url);
Expand Down
8 changes: 6 additions & 2 deletions src/rest_vol.h
Original file line number Diff line number Diff line change
Expand Up @@ -569,8 +569,11 @@ struct RV_object_t {

/* Structures to hold information for cURL requests to read/write to datasets */
typedef struct dataset_write_info {
/* This points to the dynamically allocated buffer for write, if any */
char *alloc_write_buffer;
/* Dynamically allocated buffers for each step of the write pipeline */
void *gather_buf;
void *base64_encoded_values;
void *serialize_buf;
void *selection_buf;
upload_info uinfo;
} dataset_write_info;

Expand Down Expand Up @@ -600,6 +603,7 @@ typedef struct dataset_transfer_info {
char *selection_body;

/* Fields for type conversion */
void *tconv_buf;
void *bkg_buf;

transfer_type_t transfer_type;
Expand Down
Loading

0 comments on commit c9a4183

Please sign in to comment.