diff --git a/opal/mca/hwloc/base/hwloc_base_util.c b/opal/mca/hwloc/base/hwloc_base_util.c index 9ef650e1032..90821fab782 100644 --- a/opal/mca/hwloc/base/hwloc_base_util.c +++ b/opal/mca/hwloc/base/hwloc_base_util.c @@ -16,6 +16,10 @@ * Copyright (c) 2013-2017 Intel, Inc. All rights reserved. * Copyright (c) 2015-2017 Research Organization for Information Science * and Technology (RIST). All rights reserved. + * Copyright (C) 2018 Mellanox Technologies, Ltd. + * All rights reserved. + * Copyright (c) 2018 Amazon.com, Inc. or its affiliates. All Rights reserved. + * Copyright (c) 2019 IBM Corporation. All rights reserved. * $COPYRIGHT$ * * Additional copyrights may follow @@ -1891,14 +1895,14 @@ int opal_hwloc_base_cset2str(char *str, int len, for (core_index = 0; core_index < num_cores; ++core_index) { if (map[socket_index][core_index] > 0) { if (!first) { - strncat(str, ", ", len - strlen(str)); + strncat(str, ", ", len - strlen(str) - 1); } first = false; snprintf(tmp, stmp, "socket %d[core %d[hwt %s]]", socket_index, core_index, bitmap2rangestr(map[socket_index][core_index])); - strncat(str, tmp, len - strlen(str)); + strncat(str, tmp, len - strlen(str) - 1); } } } @@ -1956,7 +1960,7 @@ int opal_hwloc_base_cset2mapstr(char *str, int len, for (socket = hwloc_get_obj_by_type(topo, HWLOC_OBJ_SOCKET, 0); NULL != socket; socket = socket->next_cousin) { - strncat(str, "[", len - strlen(str)); + strncat(str, "[", len - strlen(str) - 1); /* Iterate over all existing cores in this socket */ core_index = 0; @@ -1968,7 +1972,7 @@ int opal_hwloc_base_cset2mapstr(char *str, int len, socket->cpuset, HWLOC_OBJ_CORE, ++core_index)) { if (core_index > 0) { - strncat(str, "/", len - strlen(str)); + strncat(str, "/", len - strlen(str) - 1); } /* Iterate over all existing PUs in this core */ @@ -1983,13 +1987,13 @@ int opal_hwloc_base_cset2mapstr(char *str, int len, /* Is this PU in the cpuset? */ if (hwloc_bitmap_isset(cpuset, pu->os_index)) { - strncat(str, "B", len - strlen(str)); + strncat(str, "B", len - strlen(str) - 1); } else { - strncat(str, ".", len - strlen(str)); + strncat(str, ".", len - strlen(str) - 1); } } } - strncat(str, "]", len - strlen(str)); + strncat(str, "]", len - strlen(str) - 1); } return OPAL_SUCCESS;