mercury 2.1.0rc1
Pre-release
Pre-release
Summary
This version brings bug fixes and updates to our v2.0.0 release.
New features
- [NA UCX]
- Add initial support for UCX. As opposed to other plugins, the UCX plugin is able through the
ucx+all
init string to decide on which protocol to use.
- Add initial support for UCX. As opposed to other plugins, the UCX plugin is able through the
- [NA]
- Add
thread_mode
to NA init options and addNA_THREAD_MODE_SINGLE
to relax thread-safety requirements. - Add
na_cb_info_recv_expected
to returnactual_buf_size
. - Add
na_cb_type_to_string()
to convert callback enum type to printable string.
- Add
- [NA IP]
- Add
na_ip_check_interface()
routine that can be used by plugins to select IP interface to use.
- Add
- [HG util]
- Add
hg_mem_header_alloc()
/free()
calls to allocate buffers with a preceding header. - Add thread annotation module for thread safety analysis.
- Add
mercury_mem_pool
memory pool to facilitate allocation and memory registration of a pool of buffers. - Enable format argument checking on logging functions.
- Add
hg_time_from_ms()
andhg_time_to_ms()
for time conversion to ms.
- Add
- [HG bulk]
- Return transfer size
size
throughhg_cb_info
andhg_cb_info_bulk
.
- Return transfer size
Bug fixes
- [NA OFI]
- Fix handling of completion queue events and completion of retried operations that fail.
- Fix progress loop to reduce time calls.
- [HG util]
- Prevent use of
CLOCK_MONOTONIC_COARSE
on PPC platforms and default toCLOCK_MONOTONIC
. - Fix debug logs that were not freed at exit.
- Remove return value of mutex lock/unlock routines.
- Fix log subsys to prevent setting duplicates.
- Prevent use of
- [HG/HG util/NA]
- Fix thread safety warnings and potential thread locking issues.
- Fix log level set routines that were not enabling the underlying log sub-system.
- [HG bulk]
- Fix erroneous call to
NA_Mem_deregister()
when handle is deserialized. - Correctly mark op as canceled if canceled from NA.
- Fix erroneous call to
- [HG Core]
- Correctly print HG handle debug information.
- In short responses like ACKs, leave room at the front of a buffer for
the NA header, and expect the header to be present.
⚠️ Known Issues
- [NA OFI]
- [tcp/verbs;ofi_rxm] Using more than 256 peers requires
FI_UNIVERSE_SIZE
to be set. - [tcp;ofi_rxm] Remains unstable, use
sockets
as a fallback in case of issues.
- [tcp/verbs;ofi_rxm] Using more than 256 peers requires
- [NA UCX]
NA_Addr_to_string()
cannot be used on non-listening processes to convert a self-address to a string.- Serialization of addresses is currently not supported and will be supported in future UCX releases.