From: Leon Romanovsky <leon-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
To: Jason Gunthorpe <jgg-uk2M96/98Pc@public.gmane.org>
Cc: Doug Ledford <dledford-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>,
RDMA mailing list
<linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org>,
Mark Bloch <markb-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
Subject: Re: [PATCH rdma-next v2 7/7] RDMA/nldev: Provide detailed QP information
Date: Wed, 10 Jan 2018 09:17:22 +0200 [thread overview]
Message-ID: <20180110071722.GF7368@mtr-leonro.local> (raw)
In-Reply-To: <20180109200917.GF4518-uk2M96/98Pc@public.gmane.org>
[-- Attachment #1: Type: text/plain, Size: 1867 bytes --]
On Tue, Jan 09, 2018 at 01:09:17PM -0700, Jason Gunthorpe wrote:
> On Tue, Jan 02, 2018 at 10:18:32AM +0200, Leon Romanovsky wrote:
>
> > + /* PID == 0 means that this QP was created by kernel */
> > + if (qp->res.pid && nla_put_u32(msg,
> > + RDMA_NLDEV_ATTR_RES_PID, qp->res.pid))
>
> This is returning a pid in the init name space, obtained here:
>
> + res->pid = task_pid_nr(current);
>
> And since the netlink user is not running in the init name space this
> will return the wrong pid #, and worse potentially pids the current
> name space should not see.
>
> This API also needs to filter the results and only return pids
> visible, and translate the pids as well..
Correct, PID namespace wasn't taken into account, exactly as it wasn't
taken in CMA. So, right now, CMA netlink statistics is returning wrong
and unfiltered PIDs. How do you want to progress with that part of the code?
I personally have no plans to fix CMA netlink code and for my opinion it
should be removed, instead of beating that dead horse.
>
> I also suspsect this needs to be a netlink array of pids for future,
> as we have hope someday to have RDMA uobjects shared between multiple
> processes?
Not really, there is no such feature yet and once it will be introduced
the authors will need to update netlink interface and rdmatool to
support multiple PID option. They will add new netlink attribute and
fill it for their shared objects. For most users of RDMA stack, this
shared object thing is not needed and better to avoid from
over-engineering.
>
> > + if (nla_put_string(msg,
> > + RDMA_NLDEV_ATTR_RES_PID_COMM, qp->res.task_comm))
> > + goto err;
>
> Feels odd to return the content of /proc/XX/comm in netlink?
>
It was just to save extra syscalls for every object. I'll remove it for
the user created objects to simplify PID namespaces support.
> Jason
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 833 bytes --]
next prev parent reply other threads:[~2018-01-10 7:17 UTC|newest]
Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-01-02 8:18 [PATCH rdma-next v2 0/7] RDMA resource tracking Leon Romanovsky
[not found] ` <20180102081832.5264-1-leon-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
2018-01-02 8:18 ` [PATCH rdma-next v2 1/7] RDMA/restrack: Add general infrastructure to track RDMA resources Leon Romanovsky
2018-01-02 8:18 ` [PATCH rdma-next v2 2/7] RDMA/core: Add helper function to create named QPs Leon Romanovsky
2018-01-02 8:18 ` [PATCH rdma-next v2 3/7] RDMA: Annotate create QP callers Leon Romanovsky
2018-01-02 8:18 ` [PATCH rdma-next v2 4/7] RDMA/core: Add resource tracking for create and destroy CQs Leon Romanovsky
2018-01-02 8:18 ` [PATCH rdma-next v2 5/7] RDMA/core: Add resource tracking for create and destroy PDs Leon Romanovsky
2018-01-02 8:18 ` [PATCH rdma-next v2 6/7] RDMA/nldev: Provide global resource utilization Leon Romanovsky
2018-01-02 8:18 ` [PATCH rdma-next v2 7/7] RDMA/nldev: Provide detailed QP information Leon Romanovsky
[not found] ` <20180102081832.5264-8-leon-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
2018-01-09 20:09 ` Jason Gunthorpe
[not found] ` <20180109200917.GF4518-uk2M96/98Pc@public.gmane.org>
2018-01-09 21:46 ` Parav Pandit
2018-01-10 7:17 ` Leon Romanovsky [this message]
[not found] ` <20180110071722.GF7368-U/DQcQFIOTAAJjI8aNfphQ@public.gmane.org>
2018-01-10 22:56 ` Jason Gunthorpe
[not found] ` <20180110225622.GQ4518-uk2M96/98Pc@public.gmane.org>
2018-01-10 23:28 ` Steve Wise
2018-01-11 5:41 ` Leon Romanovsky
[not found] ` <20180111054141.GM7368-U/DQcQFIOTAAJjI8aNfphQ@public.gmane.org>
2018-01-11 15:17 ` Steve Wise
2018-01-11 15:47 ` Leon Romanovsky
2018-01-11 5:37 ` Leon Romanovsky
2018-01-08 20:53 ` [PATCH rdma-next v2 0/7] RDMA resource tracking Steve Wise
2018-01-09 7:53 ` Leon Romanovsky
[not found] ` <20180109075344.GD6823-U/DQcQFIOTAAJjI8aNfphQ@public.gmane.org>
2018-01-09 15:24 ` Steve Wise
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=20180110071722.GF7368@mtr-leonro.local \
--to=leon-dgejt+ai2ygdnm+yrofe0a@public.gmane.org \
--cc=dledford-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org \
--cc=jgg-uk2M96/98Pc@public.gmane.org \
--cc=linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=markb-VPRAkNaXOzVWk0Htik3J/w@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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.