From 451d3b86b35bddc0138de557d372d621899fd038 Mon Sep 17 00:00:00 2001 From: Yossi Itigin Date: Tue, 11 Jun 2019 12:42:27 +0000 Subject: [PATCH 1/3] RPM/SPEC: Fix changelog day-of-week --- ucx.spec.in | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ucx.spec.in b/ucx.spec.in index 0f9b843fd6a..ea782604859 100644 --- a/ucx.spec.in +++ b/ucx.spec.in @@ -82,7 +82,7 @@ rm -f %{buildroot}%{_libdir}/*.la %postun -p /sbin/ldconfig %changelog -* Sat Jun 04 2019 Yossi Itigin 1.5.2-1 +* Tue Jun 04 2019 Yossi Itigin 1.5.2-1 - Bump version to 1.5.2 - See NEWS for details * Sat Mar 23 2019 Yossi Itigin 1.5.1-1 From fb814ea8784c47ef67331e690a2d801e77999c23 Mon Sep 17 00:00:00 2001 From: Yossi Itigin Date: Tue, 11 Jun 2019 12:40:24 +0000 Subject: [PATCH 2/3] UCT/IB: Fallback to ibv_create_cq() if ibv_create_cq_ex() returns ENOSYS --- NEWS | 1 + src/uct/ib/base/ib_iface.c | 16 +++++++++++----- 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/NEWS b/NEWS index 0e7097e70af..49ef315759c 100644 --- a/NEWS +++ b/NEWS @@ -15,6 +15,7 @@ Bugfixes: - Fix segfault when libuct.so is reloaded - issue #3558 - Fix ucx_info crash when printing configuration alias - Fix static checker errors +- Fallback to ibv_create_cq() if ibv_create_cq_ex() returns ENOSYS ## 1.5.1 (April 1, 2019) Bugfixes: diff --git a/src/uct/ib/base/ib_iface.c b/src/uct/ib/base/ib_iface.c index d116166f87f..4baa1ca7c5c 100644 --- a/src/uct/ib/base/ib_iface.c +++ b/src/uct/ib/base/ib_iface.c @@ -624,9 +624,9 @@ struct ibv_cq *uct_ib_create_cq(struct ibv_context *context, int cqe, struct ibv_comp_channel *channel, int comp_vector, int ignore_overrun) { - struct ibv_cq *cq; #if HAVE_DECL_IBV_CREATE_CQ_ATTR_IGNORE_OVERRUN struct ibv_cq_init_attr_ex cq_attr = {}; + struct ibv_cq_ex *cq_ex; cq_attr.cqe = cqe; cq_attr.channel = channel; @@ -636,11 +636,17 @@ struct ibv_cq *uct_ib_create_cq(struct ibv_context *context, int cqe, cq_attr.flags = IBV_CREATE_CQ_ATTR_IGNORE_OVERRUN; } - cq = ibv_cq_ex_to_cq(ibv_create_cq_ex(context, &cq_attr)); -#else - cq = ibv_create_cq(context, cqe, NULL, channel, comp_vector); + cq_ex = ibv_create_cq_ex(context, &cq_attr); + if (cq_ex) { + return ibv_cq_ex_to_cq(cq_ex); + } else if (errno != ENOSYS) { + return NULL; + } else + /* if ibv_create_cq_ex returns ENOSYS, fallback to ibv_create_cq */ #endif - return cq; + { + return ibv_create_cq(context, cqe, NULL, channel, comp_vector); + } } static ucs_status_t uct_ib_iface_create_cq(uct_ib_iface_t *iface, int cq_length, From 7df80a09a2455e2063c7af591910fe105ddcc992 Mon Sep 17 00:00:00 2001 From: Yossi Itigin Date: Tue, 11 Jun 2019 16:04:35 +0300 Subject: [PATCH 3/3] UCT/IB: Code review fix --- src/uct/ib/base/ib_iface.c | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/src/uct/ib/base/ib_iface.c b/src/uct/ib/base/ib_iface.c index 4baa1ca7c5c..965cb280796 100644 --- a/src/uct/ib/base/ib_iface.c +++ b/src/uct/ib/base/ib_iface.c @@ -641,12 +641,11 @@ struct ibv_cq *uct_ib_create_cq(struct ibv_context *context, int cqe, return ibv_cq_ex_to_cq(cq_ex); } else if (errno != ENOSYS) { return NULL; - } else - /* if ibv_create_cq_ex returns ENOSYS, fallback to ibv_create_cq */ -#endif - { - return ibv_create_cq(context, cqe, NULL, channel, comp_vector); } + + /* if ibv_create_cq_ex returned ENOSYS, fallback to ibv_create_cq */ +#endif + return ibv_create_cq(context, cqe, NULL, channel, comp_vector); } static ucs_status_t uct_ib_iface_create_cq(uct_ib_iface_t *iface, int cq_length,