From: Leon Romanovsky <leonro-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
To: Tatyana Nikolova
<tatyana.e.nikolova-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
Cc: jgunthorpe-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org,
dledford-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org,
linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
e1000-rdma-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org
Subject: Re: [PATCH V2 08/10] i40iw: Control debug error prints using env variable
Date: Sat, 10 Dec 2016 16:34:21 +0200 [thread overview]
Message-ID: <20161210143421.GC2521@mtr-leonro.local> (raw)
In-Reply-To: <1481306104-19352-9-git-send-email-tatyana.e.nikolova-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
[-- Attachment #1: Type: text/plain, Size: 12313 bytes --]
On Fri, Dec 09, 2016 at 11:55:02AM -0600, Tatyana Nikolova wrote:
> From: Shiraz Saleem <shiraz.saleem-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
>
> Debug prints for error paths are off by default. User
> has the option to turn them on by setting environment
> variable I40IW_DEBUG in command line.
>
> Signed-off-by: Shiraz Saleem <shiraz.saleem-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
> Signed-off-by: Tatyana Nikolova <tatyana.e.nikolova-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
Hi Tatyana,
This patch duplicates already existing code in most of providers and
libraries in rdma-core, while two of our main goals for creating this
consolidated library were simplification for users and reduce code duplication.
It will be very beneficial if you:
1. Use and promote general pr_debug(..), srp_tools has nice piece of code, to be general code.
2. Create one and general place for all rdma-core's environment variables.
This infrastructure will allow us in the future create better manual of
all variables supported and ensure easy change if neeeded.
Thanks
> ---
> providers/i40iw/i40iw_umain.c | 11 ++++++---
> providers/i40iw/i40iw_umain.h | 7 ++++++
> providers/i40iw/i40iw_uverbs.c | 52 +++++++++++++++++++++++-------------------
> 3 files changed, 44 insertions(+), 26 deletions(-)
>
> diff --git a/providers/i40iw/i40iw_umain.c b/providers/i40iw/i40iw_umain.c
> index 1756e65..a204859 100644
> --- a/providers/i40iw/i40iw_umain.c
> +++ b/providers/i40iw/i40iw_umain.c
> @@ -46,7 +46,7 @@
> #include "i40iw_umain.h"
> #include "i40iw-abi.h"
>
> -unsigned int i40iw_debug_level;
> +unsigned int i40iw_dbg;
>
> #include <sys/types.h>
> #include <sys/stat.h>
> @@ -184,7 +184,7 @@ static struct ibv_context *i40iw_ualloc_context(struct ibv_device *ibdev, int cm
> return &iwvctx->ibv_ctx;
>
> err_free:
> - fprintf(stderr, PFX "%s: failed to allocate context for device.\n", __func__);
> + i40iw_debug("failed to allocate context for device.\n");
> free(iwvctx);
>
> return NULL;
> @@ -216,6 +216,7 @@ static struct ibv_device_ops i40iw_udev_ops = {
> struct ibv_device *i40iw_driver_init(const char *uverbs_sys_path, int abi_version)
> {
> char value[16];
> + char *env_val;
> struct i40iw_udevice *dev;
> unsigned int vendor, device;
> int i;
> @@ -236,9 +237,13 @@ struct ibv_device *i40iw_driver_init(const char *uverbs_sys_path, int abi_versio
>
> return NULL;
> found:
> + env_val = getenv("I40IW_DEBUG");
> + if (env_val)
> + i40iw_dbg = atoi(env_val);
> +
> dev = malloc(sizeof(*dev));
> if (!dev) {
> - fprintf(stderr, PFX "%s: failed to allocate memory for device object\n", __func__);
> + i40iw_debug("failed to allocate memory for device object\n");
> return NULL;
> }
>
> diff --git a/providers/i40iw/i40iw_umain.h b/providers/i40iw/i40iw_umain.h
> index 13d3da8..889c006 100644
> --- a/providers/i40iw/i40iw_umain.h
> +++ b/providers/i40iw/i40iw_umain.h
> @@ -72,6 +72,13 @@
> #define I40E_DB_SHADOW_AREA_SIZE 64
> #define I40E_DB_CQ_OFFSET 0x40
>
> +extern unsigned int i40iw_dbg;
> +#define i40iw_debug(fmt, args...) \
> +do { \
> + if (i40iw_dbg) \
> + fprintf(stderr, PFX "%s: " fmt, __FUNCTION__, ##args); \
> +} while (0)
> +
> enum i40iw_uhca_type {
> INTEL_i40iw
> };
> diff --git a/providers/i40iw/i40iw_uverbs.c b/providers/i40iw/i40iw_uverbs.c
> index f6d9196..464900b 100644
> --- a/providers/i40iw/i40iw_uverbs.c
> +++ b/providers/i40iw/i40iw_uverbs.c
> @@ -65,7 +65,7 @@ int i40iw_uquery_device(struct ibv_context *context, struct ibv_device_attr *att
>
> ret = ibv_cmd_query_device(context, attr, &i40iw_fw_ver, &cmd, sizeof(cmd));
> if (ret) {
> - fprintf(stderr, PFX "%s: query device failed and returned status code: %d\n", __func__, ret);
> + i40iw_debug("query device failed and returned status code: %d\n", ret);
> return ret;
> }
>
> @@ -165,7 +165,7 @@ struct ibv_mr *i40iw_ureg_mr(struct ibv_pd *pd, void *addr, size_t length, int a
> if (ibv_cmd_reg_mr(pd, addr, length, (uintptr_t)addr,
> access, mr, &cmd.ibv_cmd, sizeof(cmd),
> &resp, sizeof(resp))) {
> - fprintf(stderr, PFX "%s: Failed to register memory\n", __func__);
> + i40iw_debug("Failed to register memory\n");
> free(mr);
> return NULL;
> }
> @@ -264,7 +264,7 @@ struct ibv_cq *i40iw_ucreate_cq(struct ibv_context *context, int cqe,
> &iwucq->mr, ®_mr_cmd.ibv_cmd, sizeof(reg_mr_cmd), ®_mr_resp,
> sizeof(reg_mr_resp));
> if (ret) {
> - fprintf(stderr, PFX "%s: failed to pin memory for CQ\n", __func__);
> + i40iw_debug("failed to pin memory for CQ\n");
> goto err;
> }
>
> @@ -274,7 +274,7 @@ struct ibv_cq *i40iw_ucreate_cq(struct ibv_context *context, int cqe,
> &resp.ibv_resp, sizeof(resp));
> if (ret) {
> ibv_cmd_dereg_mr(&iwucq->mr);
> - fprintf(stderr, PFX "%s: failed to create CQ\n", __func__);
> + i40iw_debug("failed to create CQ\n");
> goto err;
> }
>
> @@ -286,7 +286,7 @@ struct ibv_cq *i40iw_ucreate_cq(struct ibv_context *context, int cqe,
> if (!ret)
> return &iwucq->ibv_cq;
> else
> - fprintf(stderr, PFX "%s: failed to initialze CQ, status %d\n", __func__, ret);
> + i40iw_debug("failed to initialze CQ, status %d\n", ret);
> err:
> if (info.cq_base)
> free(info.cq_base);
> @@ -307,11 +307,11 @@ int i40iw_udestroy_cq(struct ibv_cq *cq)
>
> ret = pthread_spin_destroy(&iwucq->lock);
> if (ret)
> - return ret;
> + goto err;
>
> ret = ibv_cmd_destroy_cq(cq);
> if (ret)
> - return ret;
> + goto err;
>
> ibv_cmd_dereg_mr(&iwucq->mr);
>
> @@ -319,6 +319,9 @@ int i40iw_udestroy_cq(struct ibv_cq *cq)
> free(iwucq);
>
> return 0;
> +err:
> + i40iw_debug("failed to destroy CQ, status %d\n", ret);
> + return ret;
> }
>
> /**
> @@ -344,7 +347,7 @@ int i40iw_upoll_cq(struct ibv_cq *cq, int num_entries, struct ibv_wc *entry)
> if (ret == I40IW_ERR_QUEUE_EMPTY) {
> break;
> } else if (ret) {
> - fprintf(stderr, PFX "%s: Error polling CQ, status %d\n", __func__, ret);
> + i40iw_debug("Error polling CQ, status %d\n", ret);
> if (!cqe_count)
> /* Indicate error */
> cqe_count = -1;
> @@ -519,7 +522,7 @@ static int i40iw_vmapped_qp(struct i40iw_uqp *iwuqp, struct ibv_pd *pd,
> info->sq = memalign(I40IW_HW_PAGE_SIZE, totalqpsize);
>
> if (!info->sq) {
> - fprintf(stderr, PFX "%s: failed to allocate memory for SQ\n", __func__);
> + i40iw_debug("failed to allocate memory for SQ\n");
> return 0;
> }
>
> @@ -535,7 +538,7 @@ static int i40iw_vmapped_qp(struct i40iw_uqp *iwuqp, struct ibv_pd *pd,
> IBV_ACCESS_LOCAL_WRITE, &iwuqp->mr, ®_mr_cmd.ibv_cmd,
> sizeof(reg_mr_cmd), ®_mr_resp, sizeof(reg_mr_resp));
> if (ret) {
> - fprintf(stderr, PFX "%s: failed to pin memory for SQ\n", __func__);
> + i40iw_debug("failed to pin memory for SQ\n");
> free(info->sq);
> return 0;
> }
> @@ -545,7 +548,7 @@ static int i40iw_vmapped_qp(struct i40iw_uqp *iwuqp, struct ibv_pd *pd,
> ret = ibv_cmd_create_qp(pd, &iwuqp->ibv_qp, attr, &cmd.ibv_cmd, sizeof(cmd),
> &resp->ibv_resp, sizeof(struct i40iw_ucreate_qp_resp));
> if (ret) {
> - fprintf(stderr, PFX "%s: failed to create QP, status %d\n", __func__, ret);
> + i40iw_debug("failed to create QP, status %d\n", ret);
> ibv_cmd_dereg_mr(&iwuqp->mr);
> free(info->sq);
> return 0;
> @@ -565,7 +568,7 @@ static int i40iw_vmapped_qp(struct i40iw_uqp *iwuqp, struct ibv_pd *pd,
> map = mmap(NULL, I40IW_HW_PAGE_SIZE, PROT_WRITE | PROT_READ, MAP_SHARED,
> pd->context->cmd_fd, offset);
> if (map == MAP_FAILED) {
> - fprintf(stderr, PFX "%s: failed to map push page, errno %d\n", __func__, errno);
> + i40iw_debug("failed to map push page, errno %d\n", errno);
> info->push_wqe = NULL;
> info->push_db = NULL;
> } else {
> @@ -575,7 +578,7 @@ static int i40iw_vmapped_qp(struct i40iw_uqp *iwuqp, struct ibv_pd *pd,
> map = mmap(NULL, I40IW_HW_PAGE_SIZE, PROT_WRITE | PROT_READ, MAP_SHARED,
> pd->context->cmd_fd, offset);
> if (map == MAP_FAILED) {
> - fprintf(stderr, PFX "%s: failed to map push doorbell, errno %d\n", __func__, errno);
> + i40iw_debug("failed to map push doorbell, errno %d\n", errno);
> munmap(info->push_wqe, I40IW_HW_PAGE_SIZE);
> info->push_wqe = NULL;
> info->push_db = NULL;
> @@ -639,7 +642,7 @@ struct ibv_qp *i40iw_ucreate_qp(struct ibv_pd *pd, struct ibv_qp_init_attr *attr
> int sq_attr, rq_attr;
>
> if (attr->qp_type != IBV_QPT_RC) {
> - fprintf(stderr, PFX "%s: failed to create QP, unsupported QP type: 0x%x\n", __func__, attr->qp_type);
> + i40iw_debug("failed to create QP, unsupported QP type: 0x%x\n", attr->qp_type);
> return NULL;
> }
>
> @@ -658,8 +661,8 @@ struct ibv_qp *i40iw_ucreate_qp(struct ibv_pd *pd, struct ibv_qp_init_attr *attr
> /* Sanity check QP size before proceeding */
> sqdepth = i40iw_qp_get_qdepth(sq_attr, attr->cap.max_send_sge, attr->cap.max_inline_data);
> if (!sqdepth) {
> - fprintf(stderr, PFX "%s: invalid SQ attributes, max_send_wr=%d max_send_sge=%d\n",
> - __func__, attr->cap.max_send_wr, attr->cap.max_send_sge);
> + i40iw_debug("invalid SQ attributes, max_send_wr=%d max_send_sge=%d\n",
> + attr->cap.max_send_wr, attr->cap.max_send_sge);
> return NULL;
> }
>
> @@ -691,13 +694,13 @@ struct ibv_qp *i40iw_ucreate_qp(struct ibv_pd *pd, struct ibv_qp_init_attr *attr
> info.sq_wrtrk_array = calloc(sqdepth, sizeof(*info.sq_wrtrk_array));
>
> if (!info.sq_wrtrk_array) {
> - fprintf(stderr, PFX "%s: failed to allocate memory for SQ work array\n", __func__);
> + i40iw_debug("failed to allocate memory for SQ work array\n");
> goto err_destroy_lock;
> }
>
> info.rq_wrid_array = calloc(rqdepth, sizeof(*info.rq_wrid_array));
> if (!info.rq_wrid_array) {
> - fprintf(stderr, PFX "%s: failed to allocate memory for RQ work array\n", __func__);
> + i40iw_debug("failed to allocate memory for RQ work array\n");
> goto err_free_sq_wrtrk;
> }
>
> @@ -706,7 +709,7 @@ struct ibv_qp *i40iw_ucreate_qp(struct ibv_pd *pd, struct ibv_qp_init_attr *attr
> status = i40iw_vmapped_qp(iwuqp, pd, attr, &resp, sqdepth, rqdepth, &info);
>
> if (!status) {
> - fprintf(stderr, PFX "%s: failed to map QP\n", __func__);
> + i40iw_debug("failed to map QP\n");
> goto err_free_rq_wrid;
> }
> info.qp_id = resp.qp_id;
> @@ -772,11 +775,11 @@ int i40iw_udestroy_qp(struct ibv_qp *qp)
>
> ret = pthread_spin_destroy(&iwuqp->lock);
> if (ret)
> - return ret;
> + goto err;
>
> ret = i40iw_destroy_vmapped_qp(iwuqp, iwuqp->qp.sq_base);
> if (ret)
> - return ret;
> + goto err;
>
> if (iwuqp->qp.sq_wrtrk_array)
> free(iwuqp->qp.sq_wrtrk_array);
> @@ -792,6 +795,9 @@ int i40iw_udestroy_qp(struct ibv_qp *qp)
> free(iwuqp);
>
> return 0;
> +err:
> + i40iw_debug("failed to destroy QP, status %d\n", ret);
> + return ret;
> }
>
> /**
> @@ -916,7 +922,7 @@ int i40iw_upost_send(struct ibv_qp *ib_qp, struct ibv_send_wr *ib_wr, struct ibv
> default:
> /* error */
> err = -EINVAL;
> - fprintf(stderr, PFX "%s: post work request failed, invalid opcode: 0x%x\n", __func__, ib_wr->opcode);
> + i40iw_debug("post work request failed, invalid opcode: 0x%x\n", ib_wr->opcode);
> break;
> }
>
> @@ -960,7 +966,7 @@ int i40iw_upost_recv(struct ibv_qp *ib_qp, struct ibv_recv_wr *ib_wr, struct ibv
> post_recv.sg_list = sg_list;
> ret = iwuqp->qp.ops.iw_post_receive(&iwuqp->qp, &post_recv);
> if (ret) {
> - fprintf(stderr, PFX "%s: failed to post receives, status %d\n", __func__, ret);
> + i40iw_debug("failed to post receives, status %d\n", ret);
> if (ret == I40IW_ERR_QP_TOOMANY_WRS_POSTED)
> err = -ENOMEM;
> else
> --
> 1.8.5.2
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-rdma" in
> the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 833 bytes --]
next prev parent reply other threads:[~2016-12-10 14:34 UTC|newest]
Thread overview: 33+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-12-09 17:54 [PATCH V2 00/10] i40iw: Fixes and optimizations Tatyana Nikolova
[not found] ` <1481306104-19352-1-git-send-email-tatyana.e.nikolova-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
2016-12-09 17:54 ` [PATCH V2 01/10] i40iw: Optimize setting fragments Tatyana Nikolova
2016-12-09 17:54 ` [PATCH V2 02/10] i40iw: Remove unnecessary parameter Tatyana Nikolova
2016-12-09 17:54 ` [PATCH V2 03/10] i40iw: Fix incorrect assignment of SQ head Tatyana Nikolova
2016-12-09 17:54 ` [PATCH V2 04/10] i40iw: Optimize inline data copy Tatyana Nikolova
2016-12-09 17:54 ` [PATCH V2 05/10] i40iw: Remove unnecessary check for moving CQ head Tatyana Nikolova
2016-12-09 17:55 ` [PATCH V2 06/10] i40iw: Return correct error codes for destroy QP and CQ Tatyana Nikolova
2016-12-09 17:55 ` [PATCH V2 07/10] i40iw: Do not destroy QP/CQ if lock is held Tatyana Nikolova
2016-12-09 17:55 ` [PATCH V2 08/10] i40iw: Control debug error prints using env variable Tatyana Nikolova
[not found] ` <1481306104-19352-9-git-send-email-tatyana.e.nikolova-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org>
2016-12-10 14:34 ` Leon Romanovsky [this message]
[not found] ` <20161210143421.GC2521-U/DQcQFIOTAAJjI8aNfphQ@public.gmane.org>
2016-12-13 20:02 ` Nikolova, Tatyana E
[not found] ` <13AA599688F47243B14FCFCCC2C803BB10AC7081-96pTJSsuoYQ64kNsxIetb7fspsVTdybXVpNB7YpNyf8@public.gmane.org>
2016-12-14 17:11 ` Leon Romanovsky
[not found] ` <20161214171111.GA4521-U/DQcQFIOTAAJjI8aNfphQ@public.gmane.org>
2016-12-14 21:21 ` Jason Gunthorpe
[not found] ` <20161214212103.GA6947-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2016-12-14 22:36 ` Doug Ledford
[not found] ` <57fa42c9-5ef0-c6f5-f7fd-88ec5948d387-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2016-12-14 22:41 ` Jason Gunthorpe
2016-12-15 6:48 ` Leon Romanovsky
[not found] ` <20161215064807.GB811-U/DQcQFIOTAAJjI8aNfphQ@public.gmane.org>
2016-12-15 16:54 ` Jason Gunthorpe
[not found] ` <20161215165420.GA3264-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2016-12-15 18:35 ` Leon Romanovsky
[not found] ` <20161215183537.GH811-U/DQcQFIOTAAJjI8aNfphQ@public.gmane.org>
2016-12-15 18:50 ` Jason Gunthorpe
[not found] ` <20161215185034.GB16552-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2016-12-15 19:17 ` Leon Romanovsky
[not found] ` <20161215191751.GJ811-U/DQcQFIOTAAJjI8aNfphQ@public.gmane.org>
2016-12-15 19:55 ` Nikolova, Tatyana E
[not found] ` <13AA599688F47243B14FCFCCC2C803BB10AC7E53-96pTJSsuoYQ64kNsxIetb7fspsVTdybXVpNB7YpNyf8@public.gmane.org>
2016-12-15 20:10 ` Jason Gunthorpe
2016-12-15 20:19 ` Leon Romanovsky
[not found] ` <20161215201917.GL811-U/DQcQFIOTAAJjI8aNfphQ@public.gmane.org>
2016-12-16 4:26 ` Jason Gunthorpe
[not found] ` <20161216042632.GC3797-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2016-12-18 8:19 ` Leon Romanovsky
[not found] ` <20161218081915.GC1074-U/DQcQFIOTAAJjI8aNfphQ@public.gmane.org>
2016-12-25 16:16 ` Yishai Hadas
2016-12-09 17:55 ` [PATCH 09/10] i40iw: Use 2M huge pages for CQ/QP memory if available Tatyana Nikolova
2016-12-09 17:55 ` [PATCH 10/10] i40iw: Remove SQ size constraint Tatyana Nikolova
2016-12-09 18:33 ` [PATCH V2 00/10] i40iw: Fixes and optimizations Nikolova, Tatyana E
[not found] ` <13AA599688F47243B14FCFCCC2C803BB10AC5AA2-96pTJSsuoYQ64kNsxIetb7fspsVTdybXVpNB7YpNyf8@public.gmane.org>
2016-12-09 18:36 ` Jason Gunthorpe
[not found] ` <20161209183650.GB10830-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2016-12-09 23:24 ` Nikolova, Tatyana E
[not found] ` <13AA599688F47243B14FCFCCC2C803BB10AC5C2C-96pTJSsuoYQ64kNsxIetb7fspsVTdybXVpNB7YpNyf8@public.gmane.org>
2016-12-09 23:45 ` Jason Gunthorpe
2016-12-10 14:47 ` Leon Romanovsky
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20161210143421.GC2521@mtr-leonro.local \
--to=leonro-vpraknaxozvwk0htik3j/w@public.gmane.org \
--cc=dledford-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org \
--cc=e1000-rdma-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org \
--cc=jgunthorpe-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org \
--cc=linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=tatyana.e.nikolova-ral2JQCrhuEAvxtiuMwx3w@public.gmane.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).