From: Or Gerlitz <ogerlitz-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
To: Yishai Hadas <yishaih-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
Cc: roland-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org,
linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
jackm-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org
Subject: Re: [PATCH V1 for-next 1/2] IB/uverbs: Enable device removal when there are active user space applications
Date: Tue, 18 Nov 2014 16:40:42 +0200 [thread overview]
Message-ID: <546B5A6A.2050806@mellanox.com> (raw)
In-Reply-To: <1416312682-7899-2-git-send-email-yishaih-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
On 11/18/2014 2:11 PM, Yishai Hadas wrote:
> @@ -599,6 +638,8 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf,
> struct ib_uverbs_file *file = filp->private_data;
> struct ib_uverbs_cmd_hdr hdr;
> __u32 flags;
> + int srcu_key;
> + ssize_t ret;
>
> if (count < sizeof hdr)
> return -EINVAL;
> @@ -606,6 +647,12 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf,
> if (copy_from_user(&hdr, buf, sizeof hdr))
> return -EFAULT;
>
> + srcu_key = srcu_read_lock(&file->device->disassociate_srcu);
> + if (file->device->disassociated) {
> + ret = -EIO;
> + goto out;
> + }
> +
> flags = (hdr.command &
> IB_USER_VERBS_CMD_FLAGS_MASK) >> IB_USER_VERBS_CMD_FLAGS_SHIFT;
>
> @@ -613,26 +660,36 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf,
> __u32 command;
>
> if (hdr.command & ~(__u32)(IB_USER_VERBS_CMD_FLAGS_MASK |
> - IB_USER_VERBS_CMD_COMMAND_MASK))
> - return -EINVAL;
> + IB_USER_VERBS_CMD_COMMAND_MASK)) {
> + ret = -EINVAL;
> + goto out;
> + }
put this change and it's such in a pre-patch that does refactoring of
the ib_uverbs_write() code, to make the volume and amount of changes
introduced by this patch smaller
>
> command = hdr.command & IB_USER_VERBS_CMD_COMMAND_MASK;
>
> if (command >= ARRAY_SIZE(uverbs_cmd_table) ||
> - !uverbs_cmd_table[command])
> - return -EINVAL;
> + !uverbs_cmd_table[command]) {
> + ret = -EINVAL;
> + goto out;
> + }
>
> if (!file->ucontext &&
> - command != IB_USER_VERBS_CMD_GET_CONTEXT)
> - return -EINVAL;
> + command != IB_USER_VERBS_CMD_GET_CONTEXT) {
> + ret = -EINVAL;
> + goto out;
> + }
>
> - if (!(file->device->ib_dev->uverbs_cmd_mask & (1ull << command)))
> - return -ENOSYS;
> + if (!(file->device->ib_dev->uverbs_cmd_mask & (1ull << command))) {
> + ret = -ENOSYS;
> + goto out;
> + }
>
> - if (hdr.in_words * 4 != count)
> - return -EINVAL;
> + if (hdr.in_words * 4 != count) {
> + ret = -EINVAL;
> + goto out;
> + }
>
> - return uverbs_cmd_table[command](file,
> + ret = uverbs_cmd_table[command](file,
> buf + sizeof(hdr),
> hdr.in_words * 4,
> hdr.out_words * 4);
> @@ -647,47 +704,69 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf,
> size_t written_count = count;
>
> if (hdr.command & ~(__u32)(IB_USER_VERBS_CMD_FLAGS_MASK |
> - IB_USER_VERBS_CMD_COMMAND_MASK))
> - return -EINVAL;
> + IB_USER_VERBS_CMD_COMMAND_MASK)) {
> + ret = -EINVAL;
> + goto out;
> + }
>
> command = hdr.command & IB_USER_VERBS_CMD_COMMAND_MASK;
>
> if (command >= ARRAY_SIZE(uverbs_ex_cmd_table) ||
> - !uverbs_ex_cmd_table[command])
> - return -ENOSYS;
> + !uverbs_ex_cmd_table[command]) {
> + ret = -ENOSYS;
> + goto out;
> + }
>
> - if (!file->ucontext)
> - return -EINVAL;
> + if (!file->ucontext) {
> + ret = -EINVAL;
> + goto out;
> + }
>
> - if (!(file->device->ib_dev->uverbs_ex_cmd_mask & (1ull << command)))
> - return -ENOSYS;
> + if (!(file->device->ib_dev->uverbs_ex_cmd_mask & (1ull << command))) {
> + ret = -ENOSYS;
> + goto out;
> + }
>
> - if (count < (sizeof(hdr) + sizeof(ex_hdr)))
> - return -EINVAL;
> + if (count < (sizeof(hdr) + sizeof(ex_hdr))) {
> + ret = -EINVAL;
> + goto out;
> + }
>
> - if (copy_from_user(&ex_hdr, buf + sizeof(hdr), sizeof(ex_hdr)))
> - return -EFAULT;
> + if (copy_from_user(&ex_hdr, buf + sizeof(hdr), sizeof(ex_hdr))) {
> + ret = -EFAULT;
> + goto out;
> + }
>
> count -= sizeof(hdr) + sizeof(ex_hdr);
> buf += sizeof(hdr) + sizeof(ex_hdr);
>
> - if ((hdr.in_words + ex_hdr.provider_in_words) * 8 != count)
> - return -EINVAL;
> + if ((hdr.in_words + ex_hdr.provider_in_words) * 8 != count) {
> + ret = -EINVAL;
> + goto out;
> + }
>
> - if (ex_hdr.cmd_hdr_reserved)
> - return -EINVAL;
> + if (ex_hdr.cmd_hdr_reserved) {
> + ret = -EINVAL;
> + goto out;
> + }
>
> if (ex_hdr.response) {
> - if (!hdr.out_words && !ex_hdr.provider_out_words)
> - return -EINVAL;
> + if (!hdr.out_words && !ex_hdr.provider_out_words) {
> + ret = -EINVAL;
> + goto out;
> + }
>
> if (!access_ok(VERIFY_WRITE,
> (void __user *) (unsigned long) ex_hdr.response,
> - (hdr.out_words + ex_hdr.provider_out_words) * 8))
> - return -EFAULT;
> + (hdr.out_words + ex_hdr.provider_out_words) * 8)) {
> + ret = -EFAULT;
> + goto out;
> + }
> } else {
> - if (hdr.out_words || ex_hdr.provider_out_words)
> - return -EINVAL;
> + if (hdr.out_words || ex_hdr.provider_out_words) {
> + ret = -EINVAL;
> + goto out;
> + }
> }
>
> INIT_UDATA_BUF_OR_NULL(&ucore, buf, (unsigned long) ex_hdr.response,
> @@ -704,22 +783,37 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf,
> &uhw);
>
> if (err)
> - return err;
> -
> - return written_count;
> + ret = err;
> + else
> + ret = written_count;
> + } else {
> + ret = -ENOSYS;
> }
>
> - return -ENOSYS;
> +out:
> + srcu_read_unlock(&file->device->disassociate_srcu, srcu_key);
> + return ret;
> }
--
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
next prev parent reply other threads:[~2014-11-18 14:40 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-11-18 12:11 [PATCH V1 for-next 0/2] HW Device hot-removal support Yishai Hadas
[not found] ` <1416312682-7899-1-git-send-email-yishaih-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
2014-11-18 12:11 ` [PATCH V1 for-next 1/2] IB/uverbs: Enable device removal when there are active user space applications Yishai Hadas
[not found] ` <1416312682-7899-2-git-send-email-yishaih-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
2014-11-18 14:38 ` Or Gerlitz
[not found] ` <546B59E2.2050707-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
2014-11-18 16:24 ` Yishai Hadas
[not found] ` <546B72A1.2080403-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>
2014-11-18 21:42 ` Or Gerlitz
[not found] ` <CAJ3xEMh5f-qZuYQ30frjUa0ETNxexh2igguxxRm-pVtERCwn-Q-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2014-11-19 8:05 ` Or Gerlitz
2014-11-18 14:40 ` Or Gerlitz [this message]
2014-11-19 14:49 ` Or Gerlitz
[not found] ` <546CADEF.6070905-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
2014-11-20 7:52 ` Yishai Hadas
[not found] ` <546D9DB2.8050900-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>
2014-11-20 11:21 ` Or Gerlitz
2014-11-20 11:21 ` Or Gerlitz
2014-11-18 12:11 ` [PATCH V1 for-next 2/2] IB/mlx4_ib: Disassociate support Yishai Hadas
[not found] ` <1416312682-7899-3-git-send-email-yishaih-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
2014-11-18 14:42 ` Or Gerlitz
[not found] ` <546B5AE3.9060606-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
2014-11-18 16:48 ` Steve Wise
2014-11-18 17:14 ` Yishai Hadas
[not found] ` <546B7E73.40008-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>
2014-11-18 21:50 ` Or Gerlitz
[not found] ` <CAJ3xEMjzZdf_aML2e+ht=cbYx3T9U7Lr7DOR6+JenEKTcxQ+Zw-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2014-11-19 12:15 ` Yishai Hadas
[not found] ` <546C89E6.1000204-LDSdmyG8hGV8YrgS2mwiifqBs+8SCbDb@public.gmane.org>
2014-11-19 14:45 ` Or Gerlitz
2014-11-18 14:43 ` [PATCH V1 for-next 0/2] HW Device hot-removal support Or Gerlitz
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=546B5A6A.2050806@mellanox.com \
--to=ogerlitz-vpraknaxozvwk0htik3j/w@public.gmane.org \
--cc=jackm-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org \
--cc=linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=roland-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org \
--cc=yishaih-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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox