Merge pull request #3760 from rhc54/topic/cov
Silence coverity warnings, correctly transfer the endpoint blob bytes
Этот коммит содержится в:
Коммит
3d1112e79b
@ -134,12 +134,6 @@ void free_ofi_prov_resources( int ofi_prov_id)
|
||||
opal_output_verbose(10,orte_rml_base_framework.framework_output,
|
||||
" %s - close ep",ORTE_NAME_PRINT(ORTE_PROC_MY_NAME));
|
||||
CLOSE_FID(orte_rml_ofi.ofi_prov[ofi_prov_id].ep);
|
||||
if (ret)
|
||||
{
|
||||
opal_output_verbose(10,orte_rml_base_framework.framework_output,
|
||||
" %s - fi_close(ep) failed with error- %d",
|
||||
ORTE_NAME_PRINT(ORTE_PROC_MY_NAME),ret);
|
||||
}
|
||||
}
|
||||
if (orte_rml_ofi.ofi_prov[ofi_prov_id].mr_multi_recv) {
|
||||
opal_output_verbose(10,orte_rml_base_framework.framework_output,
|
||||
@ -745,28 +739,33 @@ static int rml_ofi_component_init(void)
|
||||
/* pack the provider's name */
|
||||
if (OPAL_SUCCESS != (ret = opal_dss.pack(&entry, &(orte_rml_ofi.ofi_prov[cur_ofi_prov].fabric_info->fabric_attr->prov_name), 1, OPAL_STRING))) {
|
||||
OBJ_DESTRUCT(&entry);
|
||||
free_ofi_prov_resources(cur_ofi_prov);
|
||||
continue;
|
||||
}
|
||||
/* pack the provider's local index */
|
||||
if (OPAL_SUCCESS != (ret = opal_dss.pack(&entry, &cur_ofi_prov, 1, OPAL_UINT8))) {
|
||||
OBJ_DESTRUCT(&entry);
|
||||
free_ofi_prov_resources(cur_ofi_prov);
|
||||
continue;
|
||||
}
|
||||
/* pack the size of the provider's connection blob */
|
||||
if (OPAL_SUCCESS != (ret = opal_dss.pack(&entry, &orte_rml_ofi.ofi_prov[cur_ofi_prov].epnamelen, 1, OPAL_SIZE))) {
|
||||
OBJ_DESTRUCT(&entry);
|
||||
free_ofi_prov_resources(cur_ofi_prov);
|
||||
continue;
|
||||
}
|
||||
/* pack the blob itself */
|
||||
if (OPAL_SUCCESS != (ret = opal_dss.pack(&entry, &orte_rml_ofi.ofi_prov[cur_ofi_prov].ep_name,
|
||||
if (OPAL_SUCCESS != (ret = opal_dss.pack(&entry, orte_rml_ofi.ofi_prov[cur_ofi_prov].ep_name,
|
||||
orte_rml_ofi.ofi_prov[cur_ofi_prov].epnamelen, OPAL_BYTE))) {
|
||||
OBJ_DESTRUCT(&entry);
|
||||
free_ofi_prov_resources(cur_ofi_prov);
|
||||
continue;
|
||||
}
|
||||
/* add this entry to the overall modex object */
|
||||
eptr = &entry;
|
||||
if (OPAL_SUCCESS != (ret = opal_dss.pack(&modex, &eptr, 1, OPAL_BUFFER))) {
|
||||
OBJ_DESTRUCT(&entry);
|
||||
free_ofi_prov_resources(cur_ofi_prov);
|
||||
continue;
|
||||
}
|
||||
OBJ_DESTRUCT(&entry);
|
||||
@ -789,15 +788,6 @@ static int rml_ofi_component_init(void)
|
||||
ntohs(ep_sockaddr->sin_port), inet_ntoa(ep_sockaddr->sin_addr));
|
||||
break;
|
||||
}
|
||||
/* end of printing opal_modex_string and port, IP */
|
||||
if (ORTE_SUCCESS != ret) {
|
||||
opal_output_verbose(1, orte_rml_base_framework.framework_output,
|
||||
"%s:%d: OPAL_MODEX_SEND failed: %s\n",
|
||||
__FILE__, __LINE__, fi_strerror(-ret));
|
||||
free_ofi_prov_resources(cur_ofi_prov);
|
||||
/*abort this current transport, but check if next transport can be opened*/
|
||||
continue;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the ANY_SRC address.
|
||||
@ -944,7 +934,8 @@ int get_ofi_prov_id( opal_list_t *attributes)
|
||||
* (or) ORTE_RML_OFI_PROV_NAME key with values "socket" or "OPA"
|
||||
* if both above attributes are missing return failure
|
||||
*/
|
||||
if (orte_get_attribute(attributes, ORTE_RML_TRANSPORT_ATTRIB, (void**)&transport, OPAL_STRING) ) {
|
||||
if (orte_get_attribute(attributes, ORTE_RML_TRANSPORT_ATTRIB, (void**)&transport, OPAL_STRING) &&
|
||||
NULL != transport) {
|
||||
if( 0 == strcmp( transport, "ethernet") ) {
|
||||
provider = ethernet;
|
||||
} else if ( 0 == strcmp( transport, "fabric") ) {
|
||||
@ -953,10 +944,8 @@ int get_ofi_prov_id( opal_list_t *attributes)
|
||||
}
|
||||
/* if from the transport we don't know which provider we want, then check for the ORTE_RML_OFI_PROV_NAME_ATTRIB */
|
||||
if ( NULL == provider) {
|
||||
orte_get_attribute(attributes, ORTE_RML_PROVIDER_ATTRIB, (void**)&provider, OPAL_STRING);
|
||||
}
|
||||
if (NULL != provider)
|
||||
{
|
||||
if (orte_get_attribute(attributes, ORTE_RML_PROVIDER_ATTRIB, (void**)&provider, OPAL_STRING) &&
|
||||
NULL != provider) {
|
||||
// loop the orte_rml_ofi.ofi_provs[] and find the provider name that matches
|
||||
for ( prov_num = 0; prov_num < orte_rml_ofi.ofi_prov_open_num && ofi_prov_id == RML_OFI_PROV_ID_INVALID ; prov_num++ ) {
|
||||
cur_fi = orte_rml_ofi.ofi_prov[prov_num].fabric_info;
|
||||
@ -967,7 +956,7 @@ int get_ofi_prov_id( opal_list_t *attributes)
|
||||
ofi_prov_id = prov_num;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
opal_output_verbose(20,orte_rml_base_framework.framework_output,
|
||||
|
@ -243,6 +243,9 @@ int orte_rml_ofi_recv_handler(struct fi_cq_data_entry *wc, uint8_t ofi_prov_id)
|
||||
"%s Adding data for packet %d, pktlength = %lu, cumulative datalen so far = %d",
|
||||
ORTE_NAME_PRINT(ORTE_PROC_MY_NAME), ofi_recv_pkt->cur_pkt_num, ofi_recv_pkt->pkt_size, datalen );
|
||||
if (0 == datalen) {
|
||||
if (NULL != totdata) {
|
||||
free(totdata);
|
||||
}
|
||||
totdata = (char *)malloc(ofi_recv_pkt->pkt_size);
|
||||
if( totdata == NULL) {
|
||||
opal_output_verbose(1, orte_rml_base_framework.framework_output,
|
||||
@ -462,7 +465,7 @@ static void send_msg(int fd, short args, void *cbdata)
|
||||
bytes = (uint8_t*)malloc(entrysize);
|
||||
/* unpack the connection blob */
|
||||
cnt = entrysize;
|
||||
if (OPAL_SUCCESS != (ret = opal_dss.unpack(entry, &bytes, &cnt, OPAL_BYTE))) {
|
||||
if (OPAL_SUCCESS != (ret = opal_dss.unpack(entry, bytes, &cnt, OPAL_BYTE))) {
|
||||
ORTE_ERROR_LOG(ret);
|
||||
OBJ_RELEASE(entry);
|
||||
break;
|
||||
@ -470,7 +473,15 @@ static void send_msg(int fd, short args, void *cbdata)
|
||||
/* done with the buffer */
|
||||
OBJ_RELEASE(entry);
|
||||
/* decide if this is the provider we want to use - if so, then we are done.
|
||||
* If not, then we can simply free they bytes and continue looking */
|
||||
* If not, then we can simply free the bytes and continue looking. For now,
|
||||
* take the first one */
|
||||
pr = OBJ_NEW(orte_rml_ofi_peer_t);
|
||||
pr->ofi_ep = bytes;
|
||||
pr->ofi_ep_len = entrysize;
|
||||
opal_hash_table_set_value_uint64(&orte_rml_ofi.peers, ui64, (void*)pr);
|
||||
dest_ep_name = pr->ofi_ep;
|
||||
dest_ep_namelen = pr->ofi_ep_len;
|
||||
break;
|
||||
}
|
||||
OBJ_DESTRUCT(&modex); // releases the data returned by the modex_recv
|
||||
} else {
|
||||
|
Загрузка…
Ссылка в новой задаче
Block a user