/* * Copyright (c) 2004-2007 The Trustees of Indiana University and Indiana * University Research and Technology * Corporation. All rights reserved. * Copyright (c) 2004-2007 The University of Tennessee and The University * of Tennessee Research Foundation. All rights * reserved. * Copyright (c) 2004-2005 High Performance Computing Center Stuttgart, * University of Stuttgart. All rights reserved. * Copyright (c) 2004-2005 The Regents of the University of California. * All rights reserved. * Copyright (c) 2011-2013 Cisco Systems, Inc. All rights reserved. * Copyright (c) 2014-2020 Intel, Inc. All rights reserved. * Copyright (c) 2015-2019 Research Organization for Information Science * and Technology (RIST). All rights reserved. * Copyright (c) 2016-2019 Mellanox Technologies, Inc. * All rights reserved. * Copyright (c) 2016 IBM Corporation. All rights reserved. * Copyright (c) 2021-2022 Nanook Consulting. All rights reserved. * $COPYRIGHT$ * * Additional copyrights may follow * * $HEADER$ */ #include "src/include/pmix_config.h" #ifdef HAVE_ARPA_INET_H # include #endif #include "bfrop_v12.h" #include "internal.h" #include "src/util/pmix_argv.h" #include "src/util/pmix_error.h" #include "src/util/pmix_output.h" pmix_status_t pmix12_bfrop_pack(pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_status_t rc; pmix_pointer_array_t *regtypes = &pmix_mca_bfrops_v12_component.types; /* check for error */ if (NULL == buffer) { return PMIX_ERR_BAD_PARAM; } /* Pack the number of values */ if (PMIX_BFROP_BUFFER_FULLY_DESC == buffer->type) { if (PMIX_SUCCESS != (rc = pmix12_bfrop_store_data_type(regtypes, buffer, PMIX_INT32))) { return rc; } } if (PMIX_SUCCESS != (rc = pmix12_bfrop_pack_int32(regtypes, buffer, &num_vals, 1, PMIX_INT32))) { return rc; } /* Pack the value(s) */ return pmix12_bfrop_pack_buffer(regtypes, buffer, src, num_vals, type); } pmix_status_t pmix12_bfrop_pack_buffer(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_status_t rc; pmix_bfrop_type_info_t *info; int v1type; pmix_output_verbose(20, pmix_globals.debug_output, "pmix12_bfrop_pack_buffer( %p, %p, %lu, %d )\n", (void *) buffer, src, (long unsigned int) num_vals, (int) type); /* some v1 types are simply declared differently */ switch (type) { case PMIX_COMMAND: v1type = PMIX_UINT32; break; case PMIX_SCOPE: case PMIX_DATA_RANGE: v1type = PMIX_UINT; break; case PMIX_PROC_RANK: case PMIX_PERSIST: v1type = PMIX_INT; break; case PMIX_INFO_ARRAY: v1type = 22; break; default: v1type = type; } /* Pack the declared data type */ if (PMIX_BFROP_BUFFER_FULLY_DESC == buffer->type) { if (PMIX_SUCCESS != (rc = pmix12_bfrop_store_data_type(regtypes, buffer, v1type))) { return rc; } } /* if it is an info array, we have to set the type back * so the pack routine will get the correct function */ if (PMIX_INFO_ARRAY == type) { v1type = PMIX_INFO_ARRAY; } /* Lookup the pack function for this type and call it */ info = (pmix_bfrop_type_info_t *) pmix_pointer_array_get_item(&pmix_mca_bfrops_v12_component.types, v1type); if (NULL == info) { return PMIX_ERR_PACK_FAILURE; } return info->odti_pack_fn(regtypes, buffer, src, num_vals, v1type); } /* PACK FUNCTIONS FOR GENERIC SYSTEM TYPES */ /* * BOOL */ pmix_status_t pmix12_bfrop_pack_bool(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { uint8_t *dst; int32_t i; bool *s = (bool *) src; pmix_output_verbose(20, pmix_globals.debug_output, "pmix12_bfrop_pack_bool * %d\n", num_vals); PMIX_HIDE_UNUSED_PARAMS(regtypes, type); /* check to see if buffer needs extending */ if (NULL == (dst = (uint8_t *) pmix_bfrop_buffer_extend(buffer, num_vals))) { return PMIX_ERR_OUT_OF_RESOURCE; } /* store the data */ for (i = 0; i < num_vals; i++) { if (s[i]) { dst[i] = 1; } else { dst[i] = 0; } } /* update buffer pointers */ buffer->pack_ptr += num_vals; buffer->bytes_used += num_vals; return PMIX_SUCCESS; } /* * INT */ pmix_status_t pmix12_bfrop_pack_int(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_status_t ret; PMIX_HIDE_UNUSED_PARAMS(type); /* System types need to always be described so we can properly unpack them */ if (PMIX_SUCCESS != (ret = pmix12_bfrop_store_data_type(regtypes, buffer, BFROP_TYPE_INT))) { return ret; } /* Turn around and pack the real type */ return pmix12_bfrop_pack_buffer(regtypes, buffer, src, num_vals, BFROP_TYPE_INT); } /* * SIZE_T */ pmix_status_t pmix12_bfrop_pack_sizet(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_status_t ret; PMIX_HIDE_UNUSED_PARAMS(type); /* System types need to always be described so we can properly unpack them. */ if (PMIX_SUCCESS != (ret = pmix12_bfrop_store_data_type(regtypes, buffer, BFROP_TYPE_SIZE_T))) { return ret; } return pmix12_bfrop_pack_buffer(regtypes, buffer, src, num_vals, BFROP_TYPE_SIZE_T); } /* * PID_T */ pmix_status_t pmix12_bfrop_pack_pid(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_status_t ret; PMIX_HIDE_UNUSED_PARAMS(type); /* System types need to always be described so we can properly unpack them. */ if (PMIX_SUCCESS != (ret = pmix12_bfrop_store_data_type(regtypes, buffer, BFROP_TYPE_PID_T))) { return ret; } /* Turn around and pack the real type */ return pmix12_bfrop_pack_buffer(regtypes, buffer, src, num_vals, BFROP_TYPE_PID_T); } /* PACK FUNCTIONS FOR NON-GENERIC SYSTEM TYPES */ /* * BYTE, CHAR, INT8 */ pmix_status_t pmix12_bfrop_pack_byte(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { char *dst; pmix_output_verbose(20, pmix_globals.debug_output, "pmix12_bfrop_pack_byte * %d\n", num_vals); PMIX_HIDE_UNUSED_PARAMS(regtypes, type); /* check to see if buffer needs extending */ if (NULL == (dst = pmix_bfrop_buffer_extend(buffer, num_vals))) { return PMIX_ERR_OUT_OF_RESOURCE; } /* store the data */ memcpy(dst, src, num_vals); /* update buffer pointers */ buffer->pack_ptr += num_vals; buffer->bytes_used += num_vals; return PMIX_SUCCESS; } /* * INT16 */ pmix_status_t pmix12_bfrop_pack_int16(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { int32_t i; uint16_t tmp, *srctmp = (uint16_t *) src; char *dst; pmix_output_verbose(20, pmix_globals.debug_output, "pmix12_bfrop_pack_int16 * %d\n", num_vals); PMIX_HIDE_UNUSED_PARAMS(regtypes, type); /* check to see if buffer needs extending */ if (NULL == (dst = pmix_bfrop_buffer_extend(buffer, num_vals * sizeof(tmp)))) { return PMIX_ERR_OUT_OF_RESOURCE; } for (i = 0; i < num_vals; ++i) { tmp = pmix_htons(srctmp[i]); memcpy(dst, &tmp, sizeof(tmp)); dst += sizeof(tmp); } buffer->pack_ptr += num_vals * sizeof(tmp); buffer->bytes_used += num_vals * sizeof(tmp); return PMIX_SUCCESS; } /* * INT32 */ pmix_status_t pmix12_bfrop_pack_int32(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { int32_t i; uint32_t tmp, *srctmp = (uint32_t *) src; char *dst; pmix_output_verbose(20, pmix_globals.debug_output, "pmix12_bfrop_pack_int32 * %d\n", num_vals); PMIX_HIDE_UNUSED_PARAMS(regtypes, type); /* check to see if buffer needs extending */ if (NULL == (dst = pmix_bfrop_buffer_extend(buffer, num_vals * sizeof(tmp)))) { return PMIX_ERR_OUT_OF_RESOURCE; } for (i = 0; i < num_vals; ++i) { tmp = htonl(srctmp[i]); memcpy(dst, &tmp, sizeof(tmp)); dst += sizeof(tmp); } buffer->pack_ptr += num_vals * sizeof(tmp); buffer->bytes_used += num_vals * sizeof(tmp); return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_datatype(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { return pmix12_bfrop_pack_int32(regtypes, buffer, src, num_vals, type); } /* * INT64 */ pmix_status_t pmix12_bfrop_pack_int64(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { int32_t i; uint64_t tmp, tmp2; char *dst; size_t bytes_packed = num_vals * sizeof(tmp); pmix_output_verbose(20, pmix_globals.debug_output, "pmix12_bfrop_pack_int64 * %d\n", num_vals); PMIX_HIDE_UNUSED_PARAMS(regtypes, type); /* check to see if buffer needs extending */ if (NULL == (dst = pmix_bfrop_buffer_extend(buffer, bytes_packed))) { return PMIX_ERR_OUT_OF_RESOURCE; } for (i = 0; i < num_vals; ++i) { memcpy(&tmp2, (char *) src + i * sizeof(uint64_t), sizeof(uint64_t)); tmp = pmix_hton64(tmp2); memcpy(dst, &tmp, sizeof(tmp)); dst += sizeof(tmp); } buffer->pack_ptr += bytes_packed; buffer->bytes_used += bytes_packed; return PMIX_SUCCESS; } /* * STRING */ pmix_status_t pmix12_bfrop_pack_string(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { int ret = PMIX_SUCCESS; int32_t i, len; char **ssrc = (char **) src; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); for (i = 0; i < num_vals; ++i) { if (NULL == ssrc[i]) { /* got zero-length string/NULL pointer - store NULL */ len = 0; if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_int32(regtypes, buffer, &len, 1, PMIX_INT32))) { return ret; } } else { len = (int32_t) strlen(ssrc[i]) + 1; if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_int32(regtypes, buffer, &len, 1, PMIX_INT32))) { return ret; } if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_byte(regtypes, buffer, ssrc[i], len, PMIX_BYTE))) { return ret; } } } return PMIX_SUCCESS; } /* FLOAT */ pmix_status_t pmix12_bfrop_pack_float(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_status_t ret = PMIX_SUCCESS; int32_t i; float *ssrc = (float *) src; char *convert; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); for (i = 0; i < num_vals; ++i) { if (0 > asprintf(&convert, "%f", ssrc[i])) { return PMIX_ERR_NOMEM; } if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_string(regtypes, buffer, &convert, 1, PMIX_STRING))) { free(convert); return ret; } free(convert); } return PMIX_SUCCESS; } /* DOUBLE */ pmix_status_t pmix12_bfrop_pack_double(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_status_t ret = PMIX_SUCCESS; int32_t i; double *ssrc = (double *) src; char *convert; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); for (i = 0; i < num_vals; ++i) { if (0 > asprintf(&convert, "%f", ssrc[i])) { return PMIX_ERR_NOMEM; } if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_string(regtypes, buffer, &convert, 1, PMIX_STRING))) { free(convert); return ret; } free(convert); } return PMIX_SUCCESS; } /* TIMEVAL */ pmix_status_t pmix12_bfrop_pack_timeval(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { int64_t tmp[2]; pmix_status_t ret = PMIX_SUCCESS; int32_t i; struct timeval *ssrc = (struct timeval *) src; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); for (i = 0; i < num_vals; ++i) { tmp[0] = (int64_t) ssrc[i].tv_sec; tmp[1] = (int64_t) ssrc[i].tv_usec; if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_int64(regtypes, buffer, tmp, 2, PMIX_INT64))) { return ret; } } return PMIX_SUCCESS; } /* TIME */ pmix_status_t pmix12_bfrop_pack_time(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_status_t ret = PMIX_SUCCESS; int32_t i; time_t *ssrc = (time_t *) src; uint64_t ui64; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); /* time_t is a system-dependent size, so cast it * to uint64_t as a generic safe size */ for (i = 0; i < num_vals; ++i) { ui64 = (uint64_t) ssrc[i]; if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_int64(regtypes, buffer, &ui64, 1, PMIX_UINT64))) { return ret; } } return PMIX_SUCCESS; } /* PACK FUNCTIONS FOR GENERIC PMIX TYPES */ static pmix_status_t pack_val(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, pmix_value_t *p) { pmix_status_t ret; pmix_info_array_t array; int rank; switch (p->type) { case PMIX_BOOL: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.flag, 1, PMIX_BOOL))) { return ret; } break; case PMIX_BYTE: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.byte, 1, PMIX_BYTE))) { return ret; } break; case PMIX_STRING: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.string, 1, PMIX_STRING))) { return ret; } break; case PMIX_SIZE: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.size, 1, PMIX_SIZE))) { return ret; } break; case PMIX_PID: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.pid, 1, PMIX_PID))) { return ret; } break; case PMIX_INT: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.integer, 1, PMIX_INT))) { return ret; } break; case PMIX_INT8: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.int8, 1, PMIX_INT8))) { return ret; } break; case PMIX_INT16: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.int16, 1, PMIX_INT16))) { return ret; } break; case PMIX_INT32: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.int32, 1, PMIX_INT32))) { return ret; } break; case PMIX_INT64: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.int64, 1, PMIX_INT64))) { return ret; } break; case PMIX_UINT: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.uint, 1, PMIX_UINT))) { return ret; } break; case PMIX_UINT8: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.uint8, 1, PMIX_UINT8))) { return ret; } break; case PMIX_UINT16: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.uint16, 1, PMIX_UINT16))) { return ret; } break; case PMIX_UINT32: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.uint32, 1, PMIX_UINT32))) { return ret; } break; case PMIX_UINT64: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.uint64, 1, PMIX_UINT64))) { return ret; } break; case PMIX_FLOAT: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.fval, 1, PMIX_FLOAT))) { return ret; } break; case PMIX_DOUBLE: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.dval, 1, PMIX_DOUBLE))) { return ret; } break; case PMIX_TIMEVAL: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.tv, 1, PMIX_TIMEVAL))) { return ret; } break; case PMIX_BYTE_OBJECT: if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &p->data.bo, 1, PMIX_BYTE_OBJECT))) { return ret; } break; case PMIX_DATA_ARRAY: /* must convert this to an in info array for v1.2 */ if (PMIX_INFO != p->data.darray->type) { return PMIX_ERR_NOT_SUPPORTED; } array.size = p->data.darray->size; array.array = (pmix_info_t *) p->data.darray->array; if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &array, 1, PMIX_INFO_ARRAY))) { return ret; } break; case PMIX_PROC_RANK: /* must convert this to an int */ rank = p->data.rank; if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_buffer(regtypes, buffer, &rank, 1, PMIX_INT))) { return ret; } break; default: pmix_output(0, "PACK-PMIX-VALUE: UNSUPPORTED TYPE %d", (int) p->type); return PMIX_ERROR; } return PMIX_SUCCESS; } /* * PMIX_VALUE */ pmix_status_t pmix12_bfrop_pack_value(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_value_t *ptr; int32_t i; pmix_status_t ret; int v1type; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); ptr = (pmix_value_t *) src; for (i = 0; i < num_vals; ++i) { /* pack the type - unfortunately, v1.2 directly packed the int instead of * using the store_data_type function. This means we lose the translation! * So get it here */ v1type = pmix12_v2_to_v1_datatype(ptr[i].type); if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_int(regtypes, buffer, &v1type, 1, PMIX_INT))) { return ret; } /* now pack the right field */ if (PMIX_SUCCESS != (ret = pack_val(regtypes, buffer, &ptr[i]))) { return ret; } } return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_info(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_info_t *info; int32_t i; pmix_status_t ret; char *foo; int v1type; info = (pmix_info_t *) src; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); for (i = 0; i < num_vals; ++i) { /* pack key */ foo = info[i].key; if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_string(regtypes, buffer, &foo, 1, PMIX_STRING))) { return ret; } /* pack the type - unfortunately, v1.2 directly packed the int instead of * using the store_data_type function. This means we lose the translation! * So get it here */ v1type = pmix12_v2_to_v1_datatype(info[i].value.type); if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_int(regtypes, buffer, &v1type, 1, PMIX_INT))) { return ret; } /* pack value */ if (PMIX_SUCCESS != (ret = pack_val(regtypes, buffer, &info[i].value))) { return ret; } } return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_pdata(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_pdata_t *pdata; int32_t i; pmix_status_t ret; char *foo; int v1type; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); pdata = (pmix_pdata_t *) src; for (i = 0; i < num_vals; ++i) { /* pack the proc */ if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_proc(regtypes, buffer, &pdata[i].proc, 1, PMIX_PROC))) { return ret; } /* pack key */ foo = pdata[i].key; if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_string(regtypes, buffer, &foo, 1, PMIX_STRING))) { return ret; } /* pack the type - unfortunately, v1.2 directly packed the int instead of * using the store_data_type function. This means we lose the translation! * So get it here */ v1type = pmix12_v2_to_v1_datatype(pdata[i].value.type); if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_int(regtypes, buffer, &v1type, 1, PMIX_INT))) { return ret; } /* pack value */ if (PMIX_SUCCESS != (ret = pack_val(regtypes, buffer, &pdata[i].value))) { return ret; } } return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_buf(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_buffer_t *ptr; int32_t i; pmix_status_t ret; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); ptr = (pmix_buffer_t *) src; for (i = 0; i < num_vals; ++i) { /* pack the number of bytes */ if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_sizet(regtypes, buffer, &ptr[i].bytes_used, 1, PMIX_SIZE))) { return ret; } /* pack the bytes */ if (0 < ptr[i].bytes_used) { if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_byte(regtypes, buffer, ptr[i].base_ptr, ptr[i].bytes_used, PMIX_BYTE))) { return ret; } } } return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_proc(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_proc_t *proc; int32_t i; pmix_status_t ret; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); proc = (pmix_proc_t *) src; for (i = 0; i < num_vals; ++i) { char *ptr = proc[i].nspace; if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_string(regtypes, buffer, &ptr, 1, PMIX_STRING))) { return ret; } if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_int(regtypes, buffer, &proc[i].rank, 1, PMIX_INT))) { return ret; } } return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_app(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_app_t *app; int32_t i, j, nvals; pmix_status_t ret; int argc; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); app = (pmix_app_t *) src; for (i = 0; i < num_vals; ++i) { if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_string(regtypes, buffer, &app[i].cmd, 1, PMIX_STRING))) { return ret; } /* argv */ argc = PMIx_Argv_count(app[i].argv); if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_int(regtypes, buffer, &argc, 1, PMIX_INT))) { return ret; } for (j = 0; j < argc; j++) { if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_string(regtypes, buffer, &app[i].argv[j], 1, PMIX_STRING))) { return ret; } } /* env */ nvals = PMIx_Argv_count(app[i].env); if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_int32(regtypes, buffer, &nvals, 1, PMIX_INT32))) { return ret; } for (j = 0; j < nvals; j++) { if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_string(regtypes, buffer, &app[i].env[j], 1, PMIX_STRING))) { return ret; } } /* maxprocs */ if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_int(regtypes, buffer, &app[i].maxprocs, 1, PMIX_INT))) { return ret; } /* info array */ if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_sizet(regtypes, buffer, &app[i].ninfo, 1, PMIX_SIZE))) { return ret; } if (0 < app[i].ninfo) { if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_info(regtypes, buffer, app[i].info, app[i].ninfo, PMIX_INFO))) { return ret; } } } return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_kval(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_kval_t *ptr; int32_t i; pmix_status_t ret; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); ptr = (pmix_kval_t *) src; for (i = 0; i < num_vals; ++i) { /* pack the key */ if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_string(regtypes, buffer, &ptr[i].key, 1, PMIX_STRING))) { return ret; } /* pack the value */ if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_value(regtypes, buffer, ptr[i].value, 1, ptr[i].value->type))) { return ret; } } return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_array(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_info_array_t *ptr; int32_t i; pmix_status_t ret; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); ptr = (pmix_info_array_t *) src; for (i = 0; i < num_vals; ++i) { /* pack the size */ if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_sizet(regtypes, buffer, &ptr[i].size, 1, PMIX_SIZE))) { return ret; } if (0 < ptr[i].size) { /* pack the values */ if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_info(regtypes, buffer, ptr[i].array, ptr[i].size, PMIX_INFO))) { return ret; } } } return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_modex(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_modex_data_t *ptr; int32_t i; pmix_status_t ret; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); ptr = (pmix_modex_data_t *) src; for (i = 0; i < num_vals; ++i) { if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_sizet(regtypes, buffer, &ptr[i].size, 1, PMIX_SIZE))) { return ret; } if (0 < ptr[i].size) { if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_byte(regtypes, buffer, ptr[i].blob, ptr[i].size, PMIX_UINT8))) { return ret; } } } return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_persist(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { PMIX_HIDE_UNUSED_PARAMS(regtypes, type); return pmix12_bfrop_pack_int(regtypes, buffer, src, num_vals, PMIX_INT); } pmix_status_t pmix12_bfrop_pack_bo(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_status_t ret; int i; pmix_byte_object_t *bo; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); bo = (pmix_byte_object_t *) src; for (i = 0; i < num_vals; i++) { if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_sizet(regtypes, buffer, &bo[i].size, 1, PMIX_SIZE))) { return ret; } if (0 < bo[i].size) { if (PMIX_SUCCESS != (ret = pmix12_bfrop_pack_byte(regtypes, buffer, bo[i].bytes, bo[i].size, PMIX_BYTE))) { return ret; } } } return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_ptr(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { /* v1.x has no concept of packing a pointer, so just return */ PMIX_HIDE_UNUSED_PARAMS(regtypes, buffer, src, num_vals, type); return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_scope(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_scope_t *scope = (pmix_scope_t *) src; unsigned int *v1scope; pmix_status_t ret; int i; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); /* v1.2 packed scope as PMIX_UINT, so we have to convert */ v1scope = (unsigned int *) malloc(num_vals * sizeof(unsigned int)); if (NULL == v1scope) { return PMIX_ERR_NOMEM; } for (i = 0; i < num_vals; i++) { v1scope[i] = (unsigned int) scope[i]; } ret = pmix12_bfrop_pack_int(regtypes, buffer, (void *) v1scope, num_vals, PMIX_UINT); free(v1scope); return ret; } pmix_status_t pmix12_bfrop_pack_status(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { PMIX_HIDE_UNUSED_PARAMS(regtypes, type); /* v1.2 declares pmix_status_t as an enum, which translates to int and * matches that of v2 */ return pmix12_bfrop_pack_int(regtypes, buffer, src, num_vals, PMIX_INT); } pmix_status_t pmix12_bfrop_pack_range(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_data_range_t *range = (pmix_data_range_t *) src; unsigned int *v1range; pmix_status_t ret; int i; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); /* v1.2 packed data range as PMIX_UINT, so we have to convert */ v1range = (unsigned int *) malloc(num_vals * sizeof(unsigned int)); if (NULL == v1range) { return PMIX_ERR_NOMEM; } for (i = 0; i < num_vals; i++) { v1range[i] = (unsigned int) range[i]; } ret = pmix12_bfrop_pack_int(regtypes, buffer, (void *) v1range, num_vals, PMIX_UINT); free(v1range); return ret; } pmix_status_t pmix12_bfrop_pack_cmd(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { pmix_cmd_t *cmd = (pmix_cmd_t *) src; int *v1cmd; pmix_status_t ret; int i; PMIX_HIDE_UNUSED_PARAMS(regtypes, type); /* v1.2 commands were enum (i.e., int), while they are uint8_t in v2 */ v1cmd = (int *) malloc(num_vals * sizeof(int)); if (NULL == v1cmd) { return PMIX_ERR_NOMEM; } for (i = 0; i < num_vals; i++) { v1cmd[i] = cmd[i]; } ret = pmix12_bfrop_pack_int(regtypes, buffer, (void *) v1cmd, num_vals, PMIX_INT); free(v1cmd); return ret; } pmix_status_t pmix12_bfrop_pack_info_directives(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { PMIX_HIDE_UNUSED_PARAMS(regtypes, buffer, src, num_vals, type); /* v1.x has no concept of an info directive, so just return */ return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_proc_state(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { PMIX_HIDE_UNUSED_PARAMS(regtypes, buffer, src, num_vals, type); /* v1.x has no concept of proc state, so just return */ return PMIX_SUCCESS; } pmix_status_t pmix12_bfrop_pack_darray(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { PMIX_HIDE_UNUSED_PARAMS(regtypes, buffer, src, num_vals, type); return PMIX_ERR_NOT_SUPPORTED; } pmix_status_t pmix12_bfrop_pack_proc_info(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { PMIX_HIDE_UNUSED_PARAMS(regtypes, buffer, src, num_vals, type); return PMIX_ERR_NOT_SUPPORTED; } pmix_status_t pmix12_bfrop_pack_query(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { PMIX_HIDE_UNUSED_PARAMS(regtypes, buffer, src, num_vals, type); return PMIX_ERR_NOT_SUPPORTED; } pmix_status_t pmix12_bfrop_pack_rank(pmix_pointer_array_t *regtypes, pmix_buffer_t *buffer, const void *src, int32_t num_vals, pmix_data_type_t type) { PMIX_HIDE_UNUSED_PARAMS(regtypes, type); /* v1 rank is just an int, not a separate data type - it is defined * to be an unint32 in v2 */ return pmix12_bfrop_pack_int(regtypes, buffer, src, num_vals, PMIX_INT); }