* [PATCH 0/9] IB/core: batch of fix against create/destroy_flow uverbs for v3.12
@ 2013-10-11 17:18 Yann Droneaud
[not found] ` <cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org>
0 siblings, 1 reply; 31+ messages in thread
From: Yann Droneaud @ 2013-10-11 17:18 UTC (permalink / raw)
To: Roland Dreier, Roland Dreier, Or Gerlitz
Cc: Yann Droneaud, linux-rdma-u79uwXL29TY76Z2rM5mHXA
Hi,
As requested by Or Gerlitz, I've rebased my previous fixes [1]
against Matan Barak patch [2]. I've added two patches to fix issues
left or introduced by this patch.
Regarding the previous patchset [1], I've kept the public data
structure improving and renaming patches, but, in order to minimize
the overall changes, I've removed the changes which were modifying
the functions and variables names in the code.
I've removed "code beautifying" and left "hardening" / cleanup changes
for a latter release.
On top of this, I've added the two acknowledged and important patches
from my extended command infrastructure [3]. I've made cleanups in the
changelog regarding the 'email' citations.
It's in pretty good shape, and, if revert or temporarily disabling
are not an option, this can probably go in v3.12.
Regards.
Links:
[1]: http://marc.info/?i=cover.1381351016.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org
http://mid.gmane.org/cover.1381351016.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org
[2]: https://patchwork.kernel.org/patch/2924341/
[3]: http://marc.info/?i=cover.1381177342.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org
http://mid.gmane.org/cover.1381177342.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org
Matan Barak (1):
IB/core: clarify overflow/underflow checks on ib_create/destroy_flow
Yann Droneaud (8):
IB/core: Includes flow attribute size in uverbs create_flow
IB/core: Don't include command header size in uverbs create_flow
IB/core: Rename 'flow' structs to match other uverbs structs
IB/core: Makes uverbs flow structure using names more similar to verbs
ones
IB/core: Uses a common header for uverbs flow_specs
IB/core: Remove ib_uverbs_flow_spec structure from userspace
IB/core: extended command: an improved infrastructure for uverbs
commands
IB/core: extended command: move comp_mask to the extended header
drivers/infiniband/core/uverbs.h | 35 +++++++++-
drivers/infiniband/core/uverbs_cmd.c | 101 ++++++++++++++--------------
drivers/infiniband/core/uverbs_main.c | 123 +++++++++++++++++++++++++++-------
drivers/infiniband/hw/mlx4/main.c | 6 +-
include/rdma/ib_verbs.h | 1 +
include/uapi/rdma/ib_user_verbs.h | 95 +++++++++++++++-----------
6 files changed, 240 insertions(+), 121 deletions(-)
--
1.8.3.1
--
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
^ permalink raw reply [flat|nested] 31+ messages in thread[parent not found: <cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org>]
* [PATCH 1/9] IB/core: clarify overflow/underflow checks on ib_create/destroy_flow [not found] ` <cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> @ 2013-10-11 17:18 ` Yann Droneaud 2013-10-11 17:18 ` [PATCH 2/9] IB/core: Includes flow attribute size in uverbs create_flow Yann Droneaud ` (8 subsequent siblings) 9 siblings, 0 replies; 31+ messages in thread From: Yann Droneaud @ 2013-10-11 17:18 UTC (permalink / raw) To: Roland Dreier, Roland Dreier, Or Gerlitz Cc: Matan Barak, linux-rdma-u79uwXL29TY76Z2rM5mHXA From: Matan Barak <matanb-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> This patch fixes the following issues: 1. Unneeded checks were removed 2. Removed the fixed size out of flow_attr.size and by thus simplifying the checks. 3. Remove a 32bit hole on 64bit systems with strict alignment in struct ib_kern_flow_att by adding a reserved field. Signed-off-by: Matan Barak <matanb-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> --- drivers/infiniband/core/uverbs_cmd.c | 27 ++++++++++++--------------- include/uapi/rdma/ib_user_verbs.h | 1 + 2 files changed, 13 insertions(+), 15 deletions(-) diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c index f2b81b9..63c2700 100644 --- a/drivers/infiniband/core/uverbs_cmd.c +++ b/drivers/infiniband/core/uverbs_cmd.c @@ -2654,7 +2654,6 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, void *kern_spec; void *ib_spec; int i; - int kern_attr_size; if (out_len < sizeof(resp)) return -ENOSPC; @@ -2669,15 +2668,11 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, !capable(CAP_NET_ADMIN)) || !capable(CAP_NET_RAW)) return -EPERM; - if (cmd.flow_attr.num_of_specs < 0 || - cmd.flow_attr.num_of_specs > IB_FLOW_SPEC_SUPPORT_LAYERS) + if (cmd.flow_attr.num_of_specs > IB_FLOW_SPEC_SUPPORT_LAYERS) return -EINVAL; - kern_attr_size = cmd.flow_attr.size - sizeof(cmd) - - sizeof(struct ib_uverbs_cmd_hdr_ex); - - if (cmd.flow_attr.size < 0 || cmd.flow_attr.size > in_len || - kern_attr_size < 0 || kern_attr_size > + if (cmd.flow_attr.size > (in_len - sizeof(cmd) - sizeof(struct + ib_uverbs_cmd_hdr_ex)) || cmd.flow_attr.size > (cmd.flow_attr.num_of_specs * sizeof(struct ib_kern_spec))) return -EINVAL; @@ -2688,13 +2683,12 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, memcpy(kern_flow_attr, &cmd.flow_attr, sizeof(*kern_flow_attr)); if (copy_from_user(kern_flow_attr + 1, buf + sizeof(cmd), - kern_attr_size)) { + cmd.flow_attr.size)) { err = -EFAULT; goto err_free_attr; } } else { kern_flow_attr = &cmd.flow_attr; - kern_attr_size = sizeof(cmd.flow_attr); } uobj = kmalloc(sizeof(*uobj), GFP_KERNEL); @@ -2726,19 +2720,22 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, kern_spec = kern_flow_attr + 1; ib_spec = flow_attr + 1; - for (i = 0; i < flow_attr->num_of_specs && kern_attr_size > 0; i++) { + for (i = 0; i < flow_attr->num_of_specs && + cmd.flow_attr.size > offsetof(struct ib_kern_spec, reserved) && + cmd.flow_attr.size >= + ((struct ib_kern_spec *)kern_spec)->size; i++) { err = kern_spec_to_ib_spec(kern_spec, ib_spec); if (err) goto err_free; flow_attr->size += ((union ib_flow_spec *) ib_spec)->size; - kern_attr_size -= ((struct ib_kern_spec *) kern_spec)->size; + cmd.flow_attr.size -= ((struct ib_kern_spec *)kern_spec)->size; kern_spec += ((struct ib_kern_spec *) kern_spec)->size; ib_spec += ((union ib_flow_spec *) ib_spec)->size; } - if (kern_attr_size) { - pr_warn("create flow failed, %d bytes left from uverb cmd\n", - kern_attr_size); + if (cmd.flow_attr.size || (i != flow_attr->num_of_specs)) { + pr_warn("create flow failed, flow %d: %d bytes left from uverb cmd\n", + i, cmd.flow_attr.size); goto err_free; } flow_id = ib_create_flow(qp, flow_attr, IB_FLOW_DOMAIN_USER); diff --git a/include/uapi/rdma/ib_user_verbs.h b/include/uapi/rdma/ib_user_verbs.h index 0b233c5..71e994b 100644 --- a/include/uapi/rdma/ib_user_verbs.h +++ b/include/uapi/rdma/ib_user_verbs.h @@ -766,6 +766,7 @@ struct ib_kern_flow_attr { struct ib_uverbs_create_flow { __u32 comp_mask; + __u32 reserved; __u64 response; __u32 qp_handle; struct ib_kern_flow_attr flow_attr; -- 1.8.3.1 -- 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 ^ permalink raw reply related [flat|nested] 31+ messages in thread
* [PATCH 2/9] IB/core: Includes flow attribute size in uverbs create_flow [not found] ` <cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> 2013-10-11 17:18 ` [PATCH 1/9] IB/core: clarify overflow/underflow checks on ib_create/destroy_flow Yann Droneaud @ 2013-10-11 17:18 ` Yann Droneaud [not found] ` <a83e37e225cd16e5a556b35dcadc7a1234519c2a.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> 2013-10-11 17:18 ` [PATCH 3/9] IB/core: Don't include command header " Yann Droneaud ` (7 subsequent siblings) 9 siblings, 1 reply; 31+ messages in thread From: Yann Droneaud @ 2013-10-11 17:18 UTC (permalink / raw) To: Roland Dreier, Roland Dreier, Or Gerlitz Cc: Yann Droneaud, linux-rdma-u79uwXL29TY76Z2rM5mHXA In patch "IB/core: clarify overflow/underflow checks on ib_create/destroy_flow", the meaning of the size field was modified to only represent the size of the flow_spec appended to the flow_attr structure. The size of the flow_attr structure must be added when allocating memory for the whole flow_attr + flow_specs buffer. Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> Link: http://marc.info/?i=cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org --- drivers/infiniband/core/uverbs_cmd.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c index 63c2700..3b732f6 100644 --- a/drivers/infiniband/core/uverbs_cmd.c +++ b/drivers/infiniband/core/uverbs_cmd.c @@ -2677,7 +2677,8 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, return -EINVAL; if (cmd.flow_attr.num_of_specs) { - kern_flow_attr = kmalloc(cmd.flow_attr.size, GFP_KERNEL); + kern_flow_attr = kmalloc(sizeof(*kern_flow_attr) + cmd.flow_attr.size, + GFP_KERNEL); if (!kern_flow_attr) return -ENOMEM; @@ -2705,7 +2706,7 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, goto err_uobj; } - flow_attr = kmalloc(cmd.flow_attr.size, GFP_KERNEL); + flow_attr = kmalloc(sizeof(*flow_attr) + cmd.flow_attr.size, GFP_KERNEL); if (!flow_attr) { err = -ENOMEM; goto err_put; -- 1.8.3.1 -- 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 ^ permalink raw reply related [flat|nested] 31+ messages in thread
[parent not found: <a83e37e225cd16e5a556b35dcadc7a1234519c2a.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org>]
* Re: [PATCH 2/9] IB/core: Includes flow attribute size in uverbs create_flow [not found] ` <a83e37e225cd16e5a556b35dcadc7a1234519c2a.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> @ 2013-10-14 11:01 ` Or Gerlitz [not found] ` <525BCF21.3090706-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> 2013-10-14 15:13 ` Matan Barak 1 sibling, 1 reply; 31+ messages in thread From: Or Gerlitz @ 2013-10-14 11:01 UTC (permalink / raw) To: Yann Droneaud, Matan Barak Cc: Roland Dreier, Roland Dreier, linux-rdma-u79uwXL29TY76Z2rM5mHXA On 11/10/2013 20:18, Yann Droneaud wrote: > In patch "IB/core: clarify overflow/underflow checks on ib_create/destroy_flow", > the meaning of the size field was modified to only represent > the size of the flow_spec appended to the flow_attr structure. > > The size of the flow_attr structure must be added when > allocating memory for the whole flow_attr + flow_specs > buffer. wait, patch #2 fixes a problem introduced in patch #1? if this is the case, why not change patch #1? > Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> > Link: http://marc.info/?i=cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org > Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org > --- > drivers/infiniband/core/uverbs_cmd.c | 5 +++-- > 1 file changed, 3 insertions(+), 2 deletions(-) > > diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c > index 63c2700..3b732f6 100644 > --- a/drivers/infiniband/core/uverbs_cmd.c > +++ b/drivers/infiniband/core/uverbs_cmd.c > @@ -2677,7 +2677,8 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, > return -EINVAL; > > if (cmd.flow_attr.num_of_specs) { > - kern_flow_attr = kmalloc(cmd.flow_attr.size, GFP_KERNEL); > + kern_flow_attr = kmalloc(sizeof(*kern_flow_attr) + cmd.flow_attr.size, > + GFP_KERNEL); > if (!kern_flow_attr) > return -ENOMEM; > > @@ -2705,7 +2706,7 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, > goto err_uobj; > } > > - flow_attr = kmalloc(cmd.flow_attr.size, GFP_KERNEL); > + flow_attr = kmalloc(sizeof(*flow_attr) + cmd.flow_attr.size, GFP_KERNEL); > if (!flow_attr) { > err = -ENOMEM; > goto err_put; -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
[parent not found: <525BCF21.3090706-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>]
* Re: [PATCH 2/9] IB/core: Includes flow attribute size in uverbs create_flow [not found] ` <525BCF21.3090706-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> @ 2013-10-14 12:22 ` Yann Droneaud 0 siblings, 0 replies; 31+ messages in thread From: Yann Droneaud @ 2013-10-14 12:22 UTC (permalink / raw) To: Or Gerlitz Cc: Matan Barak, Roland Dreier, Roland Dreier, linux-rdma-u79uwXL29TY76Z2rM5mHXA Hi, Le 14.10.2013 13:01, Or Gerlitz a écrit : > On 11/10/2013 20:18, Yann Droneaud wrote: >> In patch "IB/core: clarify overflow/underflow checks on >> ib_create/destroy_flow", >> the meaning of the size field was modified to only represent >> the size of the flow_spec appended to the flow_attr structure. >> >> The size of the flow_attr structure must be added when >> allocating memory for the whole flow_attr + flow_specs >> buffer. > > wait, patch #2 fixes a problem introduced in patch #1? if this is the > case, why not change patch #1? You specifically asked me to rebase the patchset against Matan's patch instead of addressing the issues with my own. While I do think my patchset was better, I complied and used the aforementioned patch, but had to add fixes which were implicit with my patchset. Regards. -- Yann Droneaud OPTEYA -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
* Re: [PATCH 2/9] IB/core: Includes flow attribute size in uverbs create_flow [not found] ` <a83e37e225cd16e5a556b35dcadc7a1234519c2a.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> 2013-10-14 11:01 ` Or Gerlitz @ 2013-10-14 15:13 ` Matan Barak 1 sibling, 0 replies; 31+ messages in thread From: Matan Barak @ 2013-10-14 15:13 UTC (permalink / raw) To: Yann Droneaud, Roland Dreier, Roland Dreier, Or Gerlitz Cc: linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On 11/10/2013 8:19 PM, Yann Droneaud wrote: > In patch "IB/core: clarify overflow/underflow checks on ib_create/destroy_flow", > the meaning of the size field was modified to only represent > the size of the flow_spec appended to the flow_attr structure. > > The size of the flow_attr structure must be added when > allocating memory for the whole flow_attr + flow_specs > buffer. > > Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> > Link: http://marc.info/?i=ver.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org > Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org > --- > drivers/infiniband/core/uverbs_cmd.c | 5 +++-- > 1 file changed, 3 insertions(+), 2 deletions(-) > > diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c > index 63c2700..3b732f6 100644 > --- a/drivers/infiniband/core/uverbs_cmd.c > +++ b/drivers/infiniband/core/uverbs_cmd.c > @@ -2677,7 +2677,8 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, > return -EINVAL; > > if (cmd.flow_attr.num_of_specs) { > - kern_flow_attr =malloc(cmd.flow_attr.size, GFP_KERNEL); > + kern_flow_attr =malloc(sizeof(*kern_flow_attr) + cmd.flow_attr.size, > + GFP_KERNEL); > if (!kern_flow_attr) > return -ENOMEM; > > @@ -2705,7 +2706,7 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, > goto err_uobj; > } > > - flow_attr =malloc(cmd.flow_attr.size, GFP_KERNEL); > + flow_attr =malloc(sizeof(*flow_attr) + cmd.flow_attr.size, GFP_KERNEL); > if (!flow_attr) { > err =ENOMEM; > goto err_put; > -- > 1.8.3.1 > Hi, Since this patch mainly fixes PATCH 1, I see no point on sending them as 2 different patches. Squashing them seems like a better idea. Regards. -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
* [PATCH 3/9] IB/core: Don't include command header size in uverbs create_flow [not found] ` <cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> 2013-10-11 17:18 ` [PATCH 1/9] IB/core: clarify overflow/underflow checks on ib_create/destroy_flow Yann Droneaud 2013-10-11 17:18 ` [PATCH 2/9] IB/core: Includes flow attribute size in uverbs create_flow Yann Droneaud @ 2013-10-11 17:18 ` Yann Droneaud [not found] ` <ca92c22d0aea21d559d57e6152cb313729a11274.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> 2013-10-11 17:18 ` [PATCH 4/9] IB/core: Rename 'flow' structs to match other uverbs structs Yann Droneaud ` (6 subsequent siblings) 9 siblings, 1 reply; 31+ messages in thread From: Yann Droneaud @ 2013-10-11 17:18 UTC (permalink / raw) To: Roland Dreier, Roland Dreier, Or Gerlitz Cc: Yann Droneaud, linux-rdma-u79uwXL29TY76Z2rM5mHXA Flow spec length don't depend on the size of the command header: they are part of different layers. Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> Link: http://marc.info/?i=cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org --- drivers/infiniband/core/uverbs_cmd.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c index 3b732f6..1e5f0dd 100644 --- a/drivers/infiniband/core/uverbs_cmd.c +++ b/drivers/infiniband/core/uverbs_cmd.c @@ -2671,8 +2671,8 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, if (cmd.flow_attr.num_of_specs > IB_FLOW_SPEC_SUPPORT_LAYERS) return -EINVAL; - if (cmd.flow_attr.size > (in_len - sizeof(cmd) - sizeof(struct - ib_uverbs_cmd_hdr_ex)) || cmd.flow_attr.size > + if (cmd.flow_attr.size > (in_len - sizeof(cmd)) || + cmd.flow_attr.size > (cmd.flow_attr.num_of_specs * sizeof(struct ib_kern_spec))) return -EINVAL; -- 1.8.3.1 -- 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 ^ permalink raw reply related [flat|nested] 31+ messages in thread
[parent not found: <ca92c22d0aea21d559d57e6152cb313729a11274.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org>]
* Re: [PATCH 3/9] IB/core: Don't include command header size in uverbs create_flow [not found] ` <ca92c22d0aea21d559d57e6152cb313729a11274.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> @ 2013-10-14 15:21 ` Matan Barak [not found] ` <525C0BF2.2060201-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> 0 siblings, 1 reply; 31+ messages in thread From: Matan Barak @ 2013-10-14 15:21 UTC (permalink / raw) To: Yann Droneaud, Roland Dreier, Roland Dreier, Or Gerlitz Cc: linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On 11/10/2013 8:19 PM, Yann Droneaud wrote: > Flow spec length don't depend on the size of the command > header: they are part of different layers. > > Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> > Link: http://marc.info/?i=ver.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org > Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org > --- > drivers/infiniband/core/uverbs_cmd.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c > index 3b732f6..1e5f0dd 100644 > --- a/drivers/infiniband/core/uverbs_cmd.c > +++ b/drivers/infiniband/core/uverbs_cmd.c > @@ -2671,8 +2671,8 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, > if (cmd.flow_attr.num_of_specs > IB_FLOW_SPEC_SUPPORT_LAYERS) > return -EINVAL; > > - if (cmd.flow_attr.size > (in_len - sizeof(cmd) - sizeof(struct > - ib_uverbs_cmd_hdr_ex)) || cmd.flow_attr.size > > + if (cmd.flow_attr.size > (in_len - sizeof(cmd)) || > + cmd.flow_attr.size > > (cmd.flow_attr.num_of_specs * sizeof(struct ib_kern_spec))) > return -EINVAL; > > -- > 1.8.3.1 > Hi, I agree that it was better if the command size we pass to the uverb didn't include the header size, but since the current implementation of ib_uverbs_write and its user-space counterpart passes the command size including the header - I think this fix is incorrect. I think it'll actually break the current implementation. Furthermore, patch 8 overwrites this anyway, so I guess we could reduce this patchset size by removing it. Regards, Matan. -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
[parent not found: <525C0BF2.2060201-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>]
* Re: [PATCH 3/9] IB/core: Don't include command header size in uverbs create_flow [not found] ` <525C0BF2.2060201-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> @ 2013-10-14 15:46 ` Yann Droneaud [not found] ` <72b95284386dc57dfa1c7c883b4f45af-zgzEX58YAwA@public.gmane.org> 0 siblings, 1 reply; 31+ messages in thread From: Yann Droneaud @ 2013-10-14 15:46 UTC (permalink / raw) To: Matan Barak Cc: Roland Dreier, Roland Dreier, Or Gerlitz, linux-rdma-u79uwXL29TY76Z2rM5mHXA Hi, Le 14.10.2013 17:21, Matan Barak a écrit : > On 11/10/2013 8:19 PM, Yann Droneaud wrote: >> Flow spec length don't depend on the size of the command >> header: they are part of different layers. >> >> Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> >> Link: http://marc.info/?i=ver.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org >> Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org >> --- >> drivers/infiniband/core/uverbs_cmd.c | 4 ++-- >> 1 file changed, 2 insertions(+), 2 deletions(-) >> >> diff --git a/drivers/infiniband/core/uverbs_cmd.c >> b/drivers/infiniband/core/uverbs_cmd.c >> index 3b732f6..1e5f0dd 100644 >> --- a/drivers/infiniband/core/uverbs_cmd.c >> +++ b/drivers/infiniband/core/uverbs_cmd.c >> @@ -2671,8 +2671,8 @@ ssize_t ib_uverbs_create_flow(struct >> ib_uverbs_file *file, >> if (cmd.flow_attr.num_of_specs > IB_FLOW_SPEC_SUPPORT_LAYERS) >> return -EINVAL; >> >> - if (cmd.flow_attr.size > (in_len - sizeof(cmd) - sizeof(struct >> - ib_uverbs_cmd_hdr_ex)) || cmd.flow_attr.size > >> + if (cmd.flow_attr.size > (in_len - sizeof(cmd)) || >> + cmd.flow_attr.size > >> (cmd.flow_attr.num_of_specs * sizeof(struct >> ib_kern_spec))) >> return -EINVAL; >> >> -- >> 1.8.3.1 >> > > Hi, > > I agree that it was better if the command size we pass to the uverb > didn't include the header size, but since the current implementation > of ib_uverbs_write and its user-space counterpart passes the command > size including the header - I think this fix is incorrect. I think > it'll actually break the current implementation. You're correct. I'm wrong. I broke this. I'm so wrong, I've sent a whole patchset that *didn't* take this into account. See http://mid.gmane.org/cover.1376847403.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org I had to re-read it again: return uverbs_cmd_table[hdr.command](file, buf + sizeof hdr, hdr.in_words * 4, hdr.out_words * 4); Seems I'm not mentally trained to accept that the input buffer size is larger than buffer it's related to. I keep thinking it's written return uverbs_cmd_table[hdr.command](file, buf + sizeof hdr, hdr.in_words * 4 - sizeof hdr, hdr.out_words * 4); And that's what I've proposed in the extensible infrastructure. > Furthermore, patch 8 overwrites this anyway, so I guess we could > reduce this patchset size by removing it. > I will follow your advice. Let's try for inclusion in v3.12-rc6 Regards. -- Yann Droneaud OPTEYA -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
[parent not found: <72b95284386dc57dfa1c7c883b4f45af-zgzEX58YAwA@public.gmane.org>]
* Re: [PATCH 3/9] IB/core: Don't include command header size in uverbs create_flow [not found] ` <72b95284386dc57dfa1c7c883b4f45af-zgzEX58YAwA@public.gmane.org> @ 2013-10-14 18:19 ` Roland Dreier [not found] ` <CAL1RGDWarJPu_6u5oaL6NgZZJXBuB09vTi9xhxHALfiY_W9Sgg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 0 siblings, 1 reply; 31+ messages in thread From: Roland Dreier @ 2013-10-14 18:19 UTC (permalink / raw) To: Yann Droneaud Cc: Matan Barak, Or Gerlitz, linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On Mon, Oct 14, 2013 at 8:46 AM, Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> wrote: > Let's try for inclusion in v3.12-rc6 Hi everyone. First of sorry for being incommunicado for so long, been swamped with a lot of stuff. Anyway, given that everyone seems to agree we want something along the lines of this series, but that the series is not ready yet, it really seems to be that at this point the best option is Yann's simple patch to temporarily disable these commands. Can anyone talk me out of that? - R. -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
[parent not found: <CAL1RGDWarJPu_6u5oaL6NgZZJXBuB09vTi9xhxHALfiY_W9Sgg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>]
* Re: [PATCH 3/9] IB/core: Don't include command header size in uverbs create_flow [not found] ` <CAL1RGDWarJPu_6u5oaL6NgZZJXBuB09vTi9xhxHALfiY_W9Sgg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> @ 2013-10-15 14:08 ` Yann Droneaud [not found] ` <122f1a29d6fe45449a6a153a3a9ba8b1-zgzEX58YAwA@public.gmane.org> 0 siblings, 1 reply; 31+ messages in thread From: Yann Droneaud @ 2013-10-15 14:08 UTC (permalink / raw) To: Roland Dreier; +Cc: Matan Barak, Or Gerlitz, linux-rdma-u79uwXL29TY76Z2rM5mHXA Hi Roland, Le 14.10.2013 20:19, Roland Dreier a écrit : > On Mon, Oct 14, 2013 at 8:46 AM, Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> > wrote: >> Let's try for inclusion in v3.12-rc6 > > Hi everyone. First of sorry for being incommunicado for so long, been > swamped with a lot of stuff. > > Anyway, given that everyone seems to agree we want something along the > lines of this series, but that the series is not ready yet, it really > seems to be that at this point the best option is Yann's simple patch > to temporarily disable these commands. > > Can anyone talk me out of that? > From my point of view: - commit 400dbc9 "IB/core: Infrastructure for extensible uverbs commands" was introduced with the purpose of providing ground for new commands, but fail to actually provide real benefit, it just seems complicated for nothing. In fact, when reading the commit, I think the code is not doing what's advertised in the commit message and in the extended command header: What's the point of splitting "core" from "provider" buffer ? - commit 436f2ad "IB/core: Export ib_create/destroy_flow through uverbs" rely on the extensible uverbs infrastructure introduced in commit 400dbc9, but it's not clear why it needs the infrastructure, perhaps bigger command buffer is needed for large set of flow_spec ? More important, ABI/API exposed would welcome some cleanups: - The public data structures need a bit of rework: renaming, removing struct ib_kern_spec - The size of the flow_spec list is computed by subtracting the command header length and command to the total length. kern_attr_size = cmd.flow_attr.size - sizeof(cmd) - sizeof(struct ib_uverbs_cmd_hdr_ex); The size must not depend on the command header, I believe they are part of different layer. cmd.flow_attr.size should be the size of the flow_spec list. - The parsing flow_spec is a bit incorrect, it goes wrong at manipulating the size of flow_spec list. Additionally it should not rely on underflow kern_attr_size to detect error. - commit 22878db "IB/core: Better checking of userspace values for receive flow steering" add checks for negative value on unsigned variables - patch https://patchwork.kernel.org/patch/2924341/ "IB/core: clarify overflow/underflow checks on ib_create/destroy_flow" is improving ib_uverbs_create_flow() and ib_uverbs_destroy_flow() to fix the remarks I've made against commit 436f2ad and 22878db but introduce a bug, not adding the size of flow_attr, when allocating memory for the flow_attr + flow_specs. - Additionally, the improved extensible command scheme require changes in ib_uverbs_create_flow() and ib_uverbs_destroy_flow() function to use a new prototypes. I've proposed fixe for ib_uverbs_create_flow(), ib_uverbs_destroy_flow() and public API. I've proposed an improvement of the extensible scheme based on my understanding of the intent described in the commit 400dbc9 message. This scheme seems better, but it's not the silver bullet: it doesn't address new requirements provided by Matan Barak: http://marc.info/?i=524AB54F.9050205-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org > In addition, commands that have extensible sub-structures (for example, > extended address handle in QP attributes in IP based addressing patch) > should be given as a different UDATA in the cmd structure. Therefore, we > need a comp_mask in the cmd structure header to describe which UDATA > structure are included. http://marc.info/?i=5253F37C.90508-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org > Regarding the last patch, you are right that it simplifies things for > creating new uverbs where command parts are in-lined one after another, > but the infrastructure got a bit more complex. > If we're going to this direction, I think the we should also deal with > the problem of extending one of the command parts. Currently, we'll have > to put a comp_mask in the in-lined command part, consume this command > part and then continue with the other parts. It might be better than > using a pointer, but this put the burden of serializing the command > buffer into the kernel structures onto the uverb command writer. > We might want to avoid this. > Furthermore, the comp_mask of the command is different than the > comp_mask of the response. Therefore, I don't think we should pass the > command's comp_mask to the uverb as a pointer, but just pass a pointer > to value 0 that the uverb will set. http://marc.info/?i=525C1149.6000701-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org > I think that's a good idea to make the comp_mask field a part of our > infrastructure. But, I think we should consider making this symmetrical. > If we use the command's comp_mask as an input parameter, shouldn't we > use the response's comp_mask as an output parameter ? > What's about the provider's comp_mask ? http://marc.info/?i=525C0FF2.5040905-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org > This infrastructure (as well as the original one) doesn't deal with the > case we discussed about in the previous patches. When a command contains > a structure that can be extended, we don't have a clean nice way of > doing that. Though, because it's a limitation of the original design and > this patch cleans up the functionality of the original infrastructure, > I'm in favor of merging it. I would summarize: - having the ability to extend multiple part of the command, independently of the other; - same for the response; - having comp_mask in command for uverbs (eg. core/) and for provider (eg. hw/); - same for the response. I've provided a patch to handle "comp_mask" in response, but I don't feel confident in it: design doesn't sound clean. While I would like to address the unlimited command expansion problem, I think the scheme I've proposed is the wrong way. But in the same time I don't believe I have a good way to do it. The proposed new scheme is only good for core / hw split. But, in the mean time, we failed at providing the required fixes/cleanups before v3.12-rc5. We have not agreed on a definitive, small, urgent patchset for v3.12-rc5. And I think, and it's easy to think so, that Linus will be very upset to see more than a couple of patches for the Infiniband subsystem for v3.12-rc6. If there's a v3.12-rc6. So instead of fighting to squeeze the last good patch hunk for v3.12, we should think on what command/response scheme we need for v3.13. Regards. -- Yann Droneaud OPTEYA -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
[parent not found: <122f1a29d6fe45449a6a153a3a9ba8b1-zgzEX58YAwA@public.gmane.org>]
* Re: [PATCH 3/9] IB/core: Don't include command header size in uverbs create_flow [not found] ` <122f1a29d6fe45449a6a153a3a9ba8b1-zgzEX58YAwA@public.gmane.org> @ 2013-10-15 16:44 ` Roland Dreier [not found] ` <CAL1RGDXP3+X=go4GiW_SsvSvC_VS-B7uacJN0u5wVtU3NWfvQA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 0 siblings, 1 reply; 31+ messages in thread From: Roland Dreier @ 2013-10-15 16:44 UTC (permalink / raw) To: Yann Droneaud Cc: Matan Barak, Or Gerlitz, linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On Tue, Oct 15, 2013 at 7:08 AM, Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> wrote: > But, in the mean time, we failed at providing the required fixes/cleanups > before v3.12-rc5. > We have not agreed on a definitive, small, urgent patchset for v3.12-rc5. > And I think, and it's easy to think so, that Linus will be very upset to see > more > than a couple of patches for the Infiniband subsystem for v3.12-rc6. If > there's a v3.12-rc6. > > So instead of fighting to squeeze the last good patch hunk for v3.12, we > should think > on what command/response scheme we need for v3.13. I agree. So as I said before, I think the best idea is just to disable the half-baked command extension stuff before 3.12, and get things right for 3.13. Do you still think the patch you provided to disable the new stuff is good? - R. -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
[parent not found: <CAL1RGDXP3+X=go4GiW_SsvSvC_VS-B7uacJN0u5wVtU3NWfvQA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>]
* Re: [PATCH 3/9] IB/core: Don't include command header size in uverbs create_flow [not found] ` <CAL1RGDXP3+X=go4GiW_SsvSvC_VS-B7uacJN0u5wVtU3NWfvQA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> @ 2013-10-15 17:07 ` Yann Droneaud 2013-10-15 21:34 ` Or Gerlitz 1 sibling, 0 replies; 31+ messages in thread From: Yann Droneaud @ 2013-10-15 17:07 UTC (permalink / raw) To: Roland Dreier; +Cc: Matan Barak, Or Gerlitz, linux-rdma-u79uwXL29TY76Z2rM5mHXA Hi Roland, Le 15.10.2013 18:44, Roland Dreier a écrit : > On Tue, Oct 15, 2013 at 7:08 AM, Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> > wrote: >> But, in the mean time, we failed at providing the required >> fixes/cleanups >> before v3.12-rc5. >> We have not agreed on a definitive, small, urgent patchset for >> v3.12-rc5. >> And I think, and it's easy to think so, that Linus will be very upset >> to see >> more >> than a couple of patches for the Infiniband subsystem for v3.12-rc6. >> If >> there's a v3.12-rc6. >> >> So instead of fighting to squeeze the last good patch hunk for v3.12, >> we >> should think >> on what command/response scheme we need for v3.13. > > I agree. So as I said before, I think the best idea is just to > disable the half-baked command extension stuff before 3.12, and get > things right for 3.13. > At least, every voices seems to acknowledge that the current command extension scheme need some work. But I have the feeling the amount of work is not known. > Do you still think the patch you provided to disable the new stuff is > good? > This one : https://patchwork.kernel.org/patch/3015021/ I don't think is good ... adding a bunch of #if 0 / #endif is never good. But it's smaller than a revert and, perhaps, politically more appealing. Regarding the technical details, the kernel compiles without warning. It was "NACK"'ed by Or Gerlitz who would like to see my improvements applied ASAP. But in the mean time Matan Barack expressed concerns over the scheme as it is currently, even with my improvements. YMMV. Regards. -- Yann Droneaud OPTEYA -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
* Re: [PATCH 3/9] IB/core: Don't include command header size in uverbs create_flow [not found] ` <CAL1RGDXP3+X=go4GiW_SsvSvC_VS-B7uacJN0u5wVtU3NWfvQA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 2013-10-15 17:07 ` Yann Droneaud @ 2013-10-15 21:34 ` Or Gerlitz [not found] ` <CAJZOPZLr41MGb7qPHcFVQxNcwwAB8i4vnGQhEcu0oZ-BOiMBcg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 1 sibling, 1 reply; 31+ messages in thread From: Or Gerlitz @ 2013-10-15 21:34 UTC (permalink / raw) To: Roland Dreier Cc: Yann Droneaud, Matan Barak, Or Gerlitz, linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On Tue, Oct 15, 2013 at 7:44 PM, Roland Dreier <roland-BHEL68pLQRGGvPXPguhicg@public.gmane.org> wrote: > I agree. So as I said before, I think the best idea is just to > disable the half-baked command extension stuff before 3.12, and get > things right for 3.13. Roland, after applying a small fix which was sent to you by Matan on Sep 22nd + another tiny fix by Yann to Matan's patch (the two can be surely squashed into one small patch), things are working OK. Yann is suggesting to enhance them to work and look even better and for some reasons (life) he didn't get to do that on the 3-4 months the patches spent on the list and went through review of Sean/Jason/Shawn and you (RD). I don't see how/why you use the term half-baked here. -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
[parent not found: <CAJZOPZLr41MGb7qPHcFVQxNcwwAB8i4vnGQhEcu0oZ-BOiMBcg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>]
* Re: [PATCH 3/9] IB/core: Don't include command header size in uverbs create_flow [not found] ` <CAJZOPZLr41MGb7qPHcFVQxNcwwAB8i4vnGQhEcu0oZ-BOiMBcg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> @ 2013-10-16 0:04 ` Roland Dreier [not found] ` <CAL1RGDW7KwSOmmsRxDokUHR-Mh1OzaQvDege5Rq7JsSU8AgEHQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 0 siblings, 1 reply; 31+ messages in thread From: Roland Dreier @ 2013-10-16 0:04 UTC (permalink / raw) To: Or Gerlitz Cc: Yann Droneaud, Matan Barak, Or Gerlitz, linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On Tue, Oct 15, 2013 at 2:34 PM, Or Gerlitz <or.gerlitz-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> wrote: > Roland, after applying a small fix which was sent to you by Matan on > Sep 22nd + another tiny fix by Yann to Matan's patch (the two can be > surely squashed into one small patch), things are working OK. Yann is > suggesting to enhance them to work and look even better and for some > reasons (life) he didn't get to do that on the 3-4 months the patches > spent on the list and went through review of Sean/Jason/Shawn and you > (RD). I don't see how/why you use the term half-baked here. Unless I'm misunderstanding, Yann's suggestion for enhancement is not user/kernel ABI compatible with what is in the tree now. Given that we should really try to find an ABI that lasts for a long time, and that we already have a proposal to improve things, shouldn't we hold off on freezing the new ABI for one more kernel cycle? - R. -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
[parent not found: <CAL1RGDW7KwSOmmsRxDokUHR-Mh1OzaQvDege5Rq7JsSU8AgEHQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>]
* Re: [PATCH 3/9] IB/core: Don't include command header size in uverbs create_flow [not found] ` <CAL1RGDW7KwSOmmsRxDokUHR-Mh1OzaQvDege5Rq7JsSU8AgEHQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> @ 2013-10-17 9:19 ` Or Gerlitz [not found] ` <525FABA2.6000507-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> 0 siblings, 1 reply; 31+ messages in thread From: Or Gerlitz @ 2013-10-17 9:19 UTC (permalink / raw) To: Roland Dreier, Yann Droneaud Cc: Tzahi Oved, Matan Barak, linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On 16/10/2013 03:04, Roland Dreier wrote: > On Tue, Oct 15, 2013 at 2:34 PM, Or Gerlitz <or.gerlitz-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> wrote: >> Roland, after applying a small fix which was sent to you by Matan on >> Sep 22nd + another tiny fix by Yann to Matan's patch (the two can be >> surely squashed into one small patch), things are working OK. Yann is >> suggesting to enhance them to work and look even better and for some >> reasons (life) he didn't get to do that on the 3-4 months the patches >> spent on the list and went through review of Sean/Jason/Shawn and you >> (RD). I don't see how/why you use the term half-baked here. > Unless I'm misunderstanding, Yann's suggestion for enhancement is not > user/kernel ABI compatible with what is in the tree now. Given that > we should really try to find an ABI that lasts for a long time, and > that we already have a proposal to improve things, shouldn't we hold > off on freezing the new ABI for one more kernel cycle? > > Roland, Yann, the uverbs extensions + flow-steering patches spent many months on the list, once the review started we did quick fixes for all the comments and made it for 3.12-rc1 which was delay or two kernel cycles vs. what could happen if the feedback was on time (*). Indeed since we do want to have ABI that lasts for long, deferring the uverbs support for extensions to 3.13 along with flow-steering support to user space is something we can live with, conditioned on commitment of Yann to quickly submit his fixed patches that addresses the issues Matan raised and of you (RD) to pick them once Yann and Matan agree its done into for-next so they are safe for 3.13 Just to double check, by no means we are talking on reverting the whole series, flow-steering will be in 3.12 in the IB core and mlx4_ib OK?! Or. (*) ~Ditto for the IP based addressing series, I sent you detailed reply to your comments > month ago and not a word from you, so another kernel cycles is going to be wasted there too. -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
[parent not found: <525FABA2.6000507-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>]
* Re: [PATCH 3/9] IB/core: Don't include command header size in uverbs create_flow [not found] ` <525FABA2.6000507-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> @ 2013-10-17 15:29 ` Yann Droneaud [not found] ` <80c62f070af55a176923315b3fbb7b0d-zgzEX58YAwA@public.gmane.org> 0 siblings, 1 reply; 31+ messages in thread From: Yann Droneaud @ 2013-10-17 15:29 UTC (permalink / raw) To: Or Gerlitz Cc: Roland Dreier, Tzahi Oved, Matan Barak, linux-rdma-u79uwXL29TY76Z2rM5mHXA, linux-rdma-owner-u79uwXL29TY76Z2rM5mHXA Hi Or, Le 17.10.2013 11:19, Or Gerlitz a écrit : > On 16/10/2013 03:04, Roland Dreier wrote: >> On Tue, Oct 15, 2013 at 2:34 PM, Or Gerlitz <or.gerlitz-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> >> wrote: >>> Roland, after applying a small fix which was sent to you by Matan on >>> Sep 22nd + another tiny fix by Yann to Matan's patch (the two can be >>> surely squashed into one small patch), things are working OK. Yann is >>> suggesting to enhance them to work and look even better and for some >>> reasons (life) he didn't get to do that on the 3-4 months the patches >>> spent on the list and went through review of Sean/Jason/Shawn and you >>> (RD). I don't see how/why you use the term half-baked here. >> Unless I'm misunderstanding, Yann's suggestion for enhancement is not >> user/kernel ABI compatible with what is in the tree now. Given that >> we should really try to find an ABI that lasts for a long time, and >> that we already have a proposal to improve things, shouldn't we hold >> off on freezing the new ABI for one more kernel cycle? >> >> > > Roland, Yann, the uverbs extensions + flow-steering patches spent > many months on the list, once the review started > we did quick fixes for all the comments and made it for 3.12-rc1 which > was delay or two kernel cycles vs. what > could happen if the feedback was on time (*). > "On time" is a matter of schedule, and since we don't (all) work for the same employer, we don't have exact matching priorities. But more than an agenda, we share the principles of code quality, maintainability, coherency, usability. My purpose was not to delay the wide availability of the flow steering feature. I'm just lazily maintaining a "bound checking" patchset that got "hit" by the flow steering functions when they entered in -next. I was not very impressed by the new interface and provided some late feedback. Since then, I have more time (spare time between real work and kids) and focus more on the patches submitted on the list. But as spare time (kernel) developer, I'm not able to provide as much valuable contributions as full time kernel developer. > Indeed since we do want to have ABI that lasts for long, deferring the > uverbs support for extensions to 3.13 along with > flow-steering support to user space is something we can live with, > conditioned on commitment of Yann to quickly submit > his fixed patches that addresses the issues Matan raised and of you > (RD) to pick them once Yann and Matan agree > its done into for-next so they are safe for 3.13 > I can only agree to provide fixed patches for 3.13. If I could find time and inspiration, I will try to provide a novel scheme for command expansion that could fulfill the what was expressed by Matan. But perhaps someone would come with a better idea. > Just to double check, by no means we are talking on reverting the > whole series, flow-steering will be in > 3.12 in the IB core and mlx4_ib > I believe it will disable by #if 0 / #endif. It could be protected by #ifdef CONFIG_INFINIBAND_EXPERIMENTAL_UVERBS_FLOW_STEERING instead, but I don't know if it's acceptable practice for such piece of code that should be exposed in its current state. Regards. -- Yann Droneaud OPTEYA -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
[parent not found: <80c62f070af55a176923315b3fbb7b0d-zgzEX58YAwA@public.gmane.org>]
* Re: [PATCH 3/9] IB/core: Don't include command header size in uverbs create_flow [not found] ` <80c62f070af55a176923315b3fbb7b0d-zgzEX58YAwA@public.gmane.org> @ 2013-10-21 16:46 ` Roland Dreier 0 siblings, 0 replies; 31+ messages in thread From: Roland Dreier @ 2013-10-21 16:46 UTC (permalink / raw) To: Yann Droneaud Cc: Or Gerlitz, Tzahi Oved, Matan Barak, linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, linux-rdma-owner-u79uwXL29TY76Z2rM5mHXA On Thu, Oct 17, 2013 at 8:29 AM, Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> wrote: >> Just to double check, by no means we are talking on reverting the >> whole series, flow-steering will be in >> 3.12 in the IB core and mlx4_ib Correct, just hiding the unstable userspace ABI for now. > I believe it will disable by #if 0 / #endif. > It could be protected by #ifdef > CONFIG_INFINIBAND_EXPERIMENTAL_UVERBS_FLOW_STEERING > instead, but I don't know if it's acceptable practice for such piece of code > that should be exposed in its current state. I like the Kconfig option -- I just made a patch that does that (and made the option depend on STAGING), I'll post it for comments. - R. -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
* [PATCH 4/9] IB/core: Rename 'flow' structs to match other uverbs structs [not found] ` <cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> ` (2 preceding siblings ...) 2013-10-11 17:18 ` [PATCH 3/9] IB/core: Don't include command header " Yann Droneaud @ 2013-10-11 17:18 ` Yann Droneaud 2013-10-11 17:18 ` [PATCH 5/9] IB/core: Makes uverbs flow structure using names more similar to verbs ones Yann Droneaud ` (5 subsequent siblings) 9 siblings, 0 replies; 31+ messages in thread From: Yann Droneaud @ 2013-10-11 17:18 UTC (permalink / raw) To: Roland Dreier, Roland Dreier, Or Gerlitz Cc: Yann Droneaud, linux-rdma-u79uwXL29TY76Z2rM5mHXA Commit 436f2ad added public data structures to support receive flow steering. The new structs are not following the 'uverbs' pattern: they're lacking the common prefix 'ib_uverbs'. This patch replaces ib_kern prefix by ib_uverbs. Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> Link: http://marc.info/?i=cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org --- drivers/infiniband/core/uverbs_cmd.c | 14 +++++++------- include/uapi/rdma/ib_user_verbs.h | 36 ++++++++++++++++++------------------ 2 files changed, 25 insertions(+), 25 deletions(-) diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c index 1e5f0dd..20ad9c6 100644 --- a/drivers/infiniband/core/uverbs_cmd.c +++ b/drivers/infiniband/core/uverbs_cmd.c @@ -2599,7 +2599,7 @@ out_put: return ret ? ret : in_len; } -static int kern_spec_to_ib_spec(struct ib_kern_spec *kern_spec, +static int kern_spec_to_ib_spec(struct ib_uverbs_spec *kern_spec, union ib_flow_spec *ib_spec) { ib_spec->type = kern_spec->type; @@ -2647,7 +2647,7 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, struct ib_uverbs_create_flow_resp resp; struct ib_uobject *uobj; struct ib_flow *flow_id; - struct ib_kern_flow_attr *kern_flow_attr; + struct ib_uverbs_flow_attr *kern_flow_attr; struct ib_flow_attr *flow_attr; struct ib_qp *qp; int err = 0; @@ -2673,7 +2673,7 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, if (cmd.flow_attr.size > (in_len - sizeof(cmd)) || cmd.flow_attr.size > - (cmd.flow_attr.num_of_specs * sizeof(struct ib_kern_spec))) + (cmd.flow_attr.num_of_specs * sizeof(struct ib_uverbs_spec))) return -EINVAL; if (cmd.flow_attr.num_of_specs) { @@ -2722,16 +2722,16 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, kern_spec = kern_flow_attr + 1; ib_spec = flow_attr + 1; for (i = 0; i < flow_attr->num_of_specs && - cmd.flow_attr.size > offsetof(struct ib_kern_spec, reserved) && + cmd.flow_attr.size > offsetof(struct ib_uverbs_spec, reserved) && cmd.flow_attr.size >= - ((struct ib_kern_spec *)kern_spec)->size; i++) { + ((struct ib_uverbs_spec *)kern_spec)->size; i++) { err = kern_spec_to_ib_spec(kern_spec, ib_spec); if (err) goto err_free; flow_attr->size += ((union ib_flow_spec *) ib_spec)->size; - cmd.flow_attr.size -= ((struct ib_kern_spec *)kern_spec)->size; - kern_spec += ((struct ib_kern_spec *) kern_spec)->size; + cmd.flow_attr.size -= ((struct ib_uverbs_spec *)kern_spec)->size; + kern_spec += ((struct ib_uverbs_spec *) kern_spec)->size; ib_spec += ((union ib_flow_spec *) ib_spec)->size; } if (cmd.flow_attr.size || (i != flow_attr->num_of_specs)) { diff --git a/include/uapi/rdma/ib_user_verbs.h b/include/uapi/rdma/ib_user_verbs.h index 71e994b..6a8fd43 100644 --- a/include/uapi/rdma/ib_user_verbs.h +++ b/include/uapi/rdma/ib_user_verbs.h @@ -696,61 +696,61 @@ struct ib_uverbs_detach_mcast { __u64 driver_data[0]; }; -struct ib_kern_eth_filter { +struct ib_uverbs_eth_filter { __u8 dst_mac[6]; __u8 src_mac[6]; __be16 ether_type; __be16 vlan_tag; }; -struct ib_kern_spec_eth { +struct ib_uverbs_spec_eth { __u32 type; __u16 size; __u16 reserved; - struct ib_kern_eth_filter val; - struct ib_kern_eth_filter mask; + struct ib_uverbs_eth_filter val; + struct ib_uverbs_eth_filter mask; }; -struct ib_kern_ipv4_filter { +struct ib_uverbs_ipv4_filter { __be32 src_ip; __be32 dst_ip; }; -struct ib_kern_spec_ipv4 { +struct ib_uverbs_spec_ipv4 { __u32 type; __u16 size; __u16 reserved; - struct ib_kern_ipv4_filter val; - struct ib_kern_ipv4_filter mask; + struct ib_uverbs_ipv4_filter val; + struct ib_uverbs_ipv4_filter mask; }; -struct ib_kern_tcp_udp_filter { +struct ib_uverbs_tcp_udp_filter { __be16 dst_port; __be16 src_port; }; -struct ib_kern_spec_tcp_udp { +struct ib_uverbs_spec_tcp_udp { __u32 type; __u16 size; __u16 reserved; - struct ib_kern_tcp_udp_filter val; - struct ib_kern_tcp_udp_filter mask; + struct ib_uverbs_tcp_udp_filter val; + struct ib_uverbs_tcp_udp_filter mask; }; -struct ib_kern_spec { +struct ib_uverbs_spec { union { struct { __u32 type; __u16 size; __u16 reserved; }; - struct ib_kern_spec_eth eth; - struct ib_kern_spec_ipv4 ipv4; - struct ib_kern_spec_tcp_udp tcp_udp; + struct ib_uverbs_spec_eth eth; + struct ib_uverbs_spec_ipv4 ipv4; + struct ib_uverbs_spec_tcp_udp tcp_udp; }; }; -struct ib_kern_flow_attr { +struct ib_uverbs_flow_attr { __u32 type; __u16 size; __u16 priority; @@ -769,7 +769,7 @@ struct ib_uverbs_create_flow { __u32 reserved; __u64 response; __u32 qp_handle; - struct ib_kern_flow_attr flow_attr; + struct ib_uverbs_flow_attr flow_attr; }; struct ib_uverbs_create_flow_resp { -- 1.8.3.1 -- 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 ^ permalink raw reply related [flat|nested] 31+ messages in thread
* [PATCH 5/9] IB/core: Makes uverbs flow structure using names more similar to verbs ones [not found] ` <cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> ` (3 preceding siblings ...) 2013-10-11 17:18 ` [PATCH 4/9] IB/core: Rename 'flow' structs to match other uverbs structs Yann Droneaud @ 2013-10-11 17:18 ` Yann Droneaud 2013-10-11 17:18 ` [PATCH 6/9] IB/core: Uses a common header for uverbs flow_specs Yann Droneaud ` (4 subsequent siblings) 9 siblings, 0 replies; 31+ messages in thread From: Yann Droneaud @ 2013-10-11 17:18 UTC (permalink / raw) To: Roland Dreier, Roland Dreier, Or Gerlitz Cc: Yann Droneaud, linux-rdma-u79uwXL29TY76Z2rM5mHXA This patch add "flow" prefix to most of data structure added as part of commit 436f2ad to keep those names in sync with the data structures added in commit 319a441. It's just a matter of translating 'ib_flow' to 'ib_uverbs_flow'. Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> Link: http://marc.info/?i=cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org --- drivers/infiniband/core/uverbs_cmd.c | 12 ++++++------ include/uapi/rdma/ib_user_verbs.h | 32 ++++++++++++++++---------------- 2 files changed, 22 insertions(+), 22 deletions(-) diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c index 20ad9c6..052e07c 100644 --- a/drivers/infiniband/core/uverbs_cmd.c +++ b/drivers/infiniband/core/uverbs_cmd.c @@ -2599,7 +2599,7 @@ out_put: return ret ? ret : in_len; } -static int kern_spec_to_ib_spec(struct ib_uverbs_spec *kern_spec, +static int kern_spec_to_ib_spec(struct ib_uverbs_flow_spec *kern_spec, union ib_flow_spec *ib_spec) { ib_spec->type = kern_spec->type; @@ -2673,7 +2673,7 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, if (cmd.flow_attr.size > (in_len - sizeof(cmd)) || cmd.flow_attr.size > - (cmd.flow_attr.num_of_specs * sizeof(struct ib_uverbs_spec))) + (cmd.flow_attr.num_of_specs * sizeof(struct ib_uverbs_flow_spec))) return -EINVAL; if (cmd.flow_attr.num_of_specs) { @@ -2722,16 +2722,16 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, kern_spec = kern_flow_attr + 1; ib_spec = flow_attr + 1; for (i = 0; i < flow_attr->num_of_specs && - cmd.flow_attr.size > offsetof(struct ib_uverbs_spec, reserved) && + cmd.flow_attr.size > offsetof(struct ib_uverbs_flow_spec, reserved) && cmd.flow_attr.size >= - ((struct ib_uverbs_spec *)kern_spec)->size; i++) { + ((struct ib_uverbs_flow_spec *)kern_spec)->size; i++) { err = kern_spec_to_ib_spec(kern_spec, ib_spec); if (err) goto err_free; flow_attr->size += ((union ib_flow_spec *) ib_spec)->size; - cmd.flow_attr.size -= ((struct ib_uverbs_spec *)kern_spec)->size; - kern_spec += ((struct ib_uverbs_spec *) kern_spec)->size; + cmd.flow_attr.size -= ((struct ib_uverbs_flow_spec *)kern_spec)->size; + kern_spec += ((struct ib_uverbs_flow_spec *) kern_spec)->size; ib_spec += ((union ib_flow_spec *) ib_spec)->size; } if (cmd.flow_attr.size || (i != flow_attr->num_of_specs)) { diff --git a/include/uapi/rdma/ib_user_verbs.h b/include/uapi/rdma/ib_user_verbs.h index 6a8fd43..1a097d6 100644 --- a/include/uapi/rdma/ib_user_verbs.h +++ b/include/uapi/rdma/ib_user_verbs.h @@ -696,57 +696,57 @@ struct ib_uverbs_detach_mcast { __u64 driver_data[0]; }; -struct ib_uverbs_eth_filter { +struct ib_uverbs_flow_eth_filter { __u8 dst_mac[6]; __u8 src_mac[6]; __be16 ether_type; __be16 vlan_tag; }; -struct ib_uverbs_spec_eth { +struct ib_uverbs_flow_spec_eth { __u32 type; __u16 size; __u16 reserved; - struct ib_uverbs_eth_filter val; - struct ib_uverbs_eth_filter mask; + struct ib_uverbs_flow_eth_filter val; + struct ib_uverbs_flow_eth_filter mask; }; -struct ib_uverbs_ipv4_filter { +struct ib_uverbs_flow_ipv4_filter { __be32 src_ip; __be32 dst_ip; }; -struct ib_uverbs_spec_ipv4 { +struct ib_uverbs_flow_spec_ipv4 { __u32 type; __u16 size; __u16 reserved; - struct ib_uverbs_ipv4_filter val; - struct ib_uverbs_ipv4_filter mask; + struct ib_uverbs_flow_ipv4_filter val; + struct ib_uverbs_flow_ipv4_filter mask; }; -struct ib_uverbs_tcp_udp_filter { +struct ib_uverbs_flow_tcp_udp_filter { __be16 dst_port; __be16 src_port; }; -struct ib_uverbs_spec_tcp_udp { +struct ib_uverbs_flow_spec_tcp_udp { __u32 type; __u16 size; __u16 reserved; - struct ib_uverbs_tcp_udp_filter val; - struct ib_uverbs_tcp_udp_filter mask; + struct ib_uverbs_flow_tcp_udp_filter val; + struct ib_uverbs_flow_tcp_udp_filter mask; }; -struct ib_uverbs_spec { +struct ib_uverbs_flow_spec { union { struct { __u32 type; __u16 size; __u16 reserved; }; - struct ib_uverbs_spec_eth eth; - struct ib_uverbs_spec_ipv4 ipv4; - struct ib_uverbs_spec_tcp_udp tcp_udp; + struct ib_uverbs_flow_spec_eth eth; + struct ib_uverbs_flow_spec_ipv4 ipv4; + struct ib_uverbs_flow_spec_tcp_udp tcp_udp; }; }; -- 1.8.3.1 -- 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 ^ permalink raw reply related [flat|nested] 31+ messages in thread
* [PATCH 6/9] IB/core: Uses a common header for uverbs flow_specs [not found] ` <cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> ` (4 preceding siblings ...) 2013-10-11 17:18 ` [PATCH 5/9] IB/core: Makes uverbs flow structure using names more similar to verbs ones Yann Droneaud @ 2013-10-11 17:18 ` Yann Droneaud 2013-10-11 17:18 ` [PATCH 7/9] IB/core: Remove ib_uverbs_flow_spec structure from userspace Yann Droneaud ` (3 subsequent siblings) 9 siblings, 0 replies; 31+ messages in thread From: Yann Droneaud @ 2013-10-11 17:18 UTC (permalink / raw) To: Roland Dreier, Roland Dreier, Or Gerlitz Cc: Yann Droneaud, linux-rdma-u79uwXL29TY76Z2rM5mHXA A common header will allows better checking of flow specs size, while ensuring strict alignment to 64bits. Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> Link: http://marc.info/?i=cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org --- include/uapi/rdma/ib_user_verbs.h | 53 +++++++++++++++++++++++++++++---------- 1 file changed, 40 insertions(+), 13 deletions(-) diff --git a/include/uapi/rdma/ib_user_verbs.h b/include/uapi/rdma/ib_user_verbs.h index 1a097d6..f7f233b5 100644 --- a/include/uapi/rdma/ib_user_verbs.h +++ b/include/uapi/rdma/ib_user_verbs.h @@ -696,6 +696,14 @@ struct ib_uverbs_detach_mcast { __u64 driver_data[0]; }; +struct ib_uverbs_flow_spec_hdr { + __u32 type; + __u16 size; + __u16 reserved; + /* followed by flow_spec */ + __u64 flow_spec_data[0]; +}; + struct ib_uverbs_flow_eth_filter { __u8 dst_mac[6]; __u8 src_mac[6]; @@ -704,9 +712,14 @@ struct ib_uverbs_flow_eth_filter { }; struct ib_uverbs_flow_spec_eth { - __u32 type; - __u16 size; - __u16 reserved; + union { + struct ib_uverbs_flow_spec_hdr hdr; + struct { + __u32 type; + __u16 size; + __u16 reserved; + }; + }; struct ib_uverbs_flow_eth_filter val; struct ib_uverbs_flow_eth_filter mask; }; @@ -717,9 +730,14 @@ struct ib_uverbs_flow_ipv4_filter { }; struct ib_uverbs_flow_spec_ipv4 { - __u32 type; - __u16 size; - __u16 reserved; + union { + struct ib_uverbs_flow_spec_hdr hdr; + struct { + __u32 type; + __u16 size; + __u16 reserved; + }; + }; struct ib_uverbs_flow_ipv4_filter val; struct ib_uverbs_flow_ipv4_filter mask; }; @@ -730,19 +748,27 @@ struct ib_uverbs_flow_tcp_udp_filter { }; struct ib_uverbs_flow_spec_tcp_udp { - __u32 type; - __u16 size; - __u16 reserved; + union { + struct ib_uverbs_flow_spec_hdr hdr; + struct { + __u32 type; + __u16 size; + __u16 reserved; + }; + }; struct ib_uverbs_flow_tcp_udp_filter val; struct ib_uverbs_flow_tcp_udp_filter mask; }; struct ib_uverbs_flow_spec { union { - struct { - __u32 type; - __u16 size; - __u16 reserved; + union { + struct ib_uverbs_flow_spec_hdr hdr; + struct { + __u32 type; + __u16 size; + __u16 reserved; + }; }; struct ib_uverbs_flow_spec_eth eth; struct ib_uverbs_flow_spec_ipv4 ipv4; @@ -762,6 +788,7 @@ struct ib_uverbs_flow_attr { * struct ib_flow_spec_xxx * struct ib_flow_spec_yyy */ + struct ib_uverbs_flow_spec_hdr flow_specs[0]; }; struct ib_uverbs_create_flow { -- 1.8.3.1 -- 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 ^ permalink raw reply related [flat|nested] 31+ messages in thread
* [PATCH 7/9] IB/core: Remove ib_uverbs_flow_spec structure from userspace [not found] ` <cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> ` (5 preceding siblings ...) 2013-10-11 17:18 ` [PATCH 6/9] IB/core: Uses a common header for uverbs flow_specs Yann Droneaud @ 2013-10-11 17:18 ` Yann Droneaud [not found] ` <f8673f302536d503cdeef005a67f4531706ae578.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> 2013-10-11 17:18 ` [PATCH 8/9] IB/core: extended command: an improved infrastructure for uverbs commands Yann Droneaud ` (2 subsequent siblings) 9 siblings, 1 reply; 31+ messages in thread From: Yann Droneaud @ 2013-10-11 17:18 UTC (permalink / raw) To: Roland Dreier, Roland Dreier, Or Gerlitz Cc: Yann Droneaud, linux-rdma-u79uwXL29TY76Z2rM5mHXA The structure holding any types of flow_spec is of no use to userspace. It would be wrong for userspace to do: struct ib_uverbs_flow_spec flow_spec; flow_spec.type = IB_FLOW_SPEC_TCP; flow_spec.size = sizeof(flow_spec); Instead, userspace should use the dedicated flow_spec structure for - Ethernet : struct ib_uverbs_flow_spec_eth, - IPv4 : struct ib_uverbs_flow_spec_ipv4, - TCP/UDP : struct ib_uverbs_flow_spec_tcp_udp. In other words, struct ib_uverbs_flow_spec is a "virtual" data structure that can only be use by the kernel as an alias to the other. Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> Link: http://marc.info/?i=cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org --- drivers/infiniband/core/uverbs.h | 16 ++++++++++++++++ include/uapi/rdma/ib_user_verbs.h | 16 ---------------- 2 files changed, 16 insertions(+), 16 deletions(-) diff --git a/drivers/infiniband/core/uverbs.h b/drivers/infiniband/core/uverbs.h index d040b87..4ae0307 100644 --- a/drivers/infiniband/core/uverbs.h +++ b/drivers/infiniband/core/uverbs.h @@ -178,6 +178,22 @@ void ib_uverbs_event_handler(struct ib_event_handler *handler, struct ib_event *event); void ib_uverbs_dealloc_xrcd(struct ib_uverbs_device *dev, struct ib_xrcd *xrcd); +struct ib_uverbs_flow_spec { + union { + union { + struct ib_uverbs_flow_spec_hdr hdr; + struct { + __u32 type; + __u16 size; + __u16 reserved; + }; + }; + struct ib_uverbs_flow_spec_eth eth; + struct ib_uverbs_flow_spec_ipv4 ipv4; + struct ib_uverbs_flow_spec_tcp_udp tcp_udp; + }; +}; + #define IB_UVERBS_DECLARE_CMD(name) \ ssize_t ib_uverbs_##name(struct ib_uverbs_file *file, \ const char __user *buf, int in_len, \ diff --git a/include/uapi/rdma/ib_user_verbs.h b/include/uapi/rdma/ib_user_verbs.h index f7f233b5..93577fc 100644 --- a/include/uapi/rdma/ib_user_verbs.h +++ b/include/uapi/rdma/ib_user_verbs.h @@ -760,22 +760,6 @@ struct ib_uverbs_flow_spec_tcp_udp { struct ib_uverbs_flow_tcp_udp_filter mask; }; -struct ib_uverbs_flow_spec { - union { - union { - struct ib_uverbs_flow_spec_hdr hdr; - struct { - __u32 type; - __u16 size; - __u16 reserved; - }; - }; - struct ib_uverbs_flow_spec_eth eth; - struct ib_uverbs_flow_spec_ipv4 ipv4; - struct ib_uverbs_flow_spec_tcp_udp tcp_udp; - }; -}; - struct ib_uverbs_flow_attr { __u32 type; __u16 size; -- 1.8.3.1 -- 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 ^ permalink raw reply related [flat|nested] 31+ messages in thread
[parent not found: <f8673f302536d503cdeef005a67f4531706ae578.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org>]
* Re: [PATCH 7/9] IB/core: Remove ib_uverbs_flow_spec structure from userspace [not found] ` <f8673f302536d503cdeef005a67f4531706ae578.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> @ 2013-10-14 15:26 ` Matan Barak 0 siblings, 0 replies; 31+ messages in thread From: Matan Barak @ 2013-10-14 15:26 UTC (permalink / raw) To: Yann Droneaud, Roland Dreier, Roland Dreier, Or Gerlitz Cc: linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On 11/10/2013 8:56 PM, Yann Droneaud wrote: > The structure holding any types of flow_spec is of no use to userspace. > It would be wrong for userspace to do: > > struct ib_uverbs_flow_spec flow_spec; > > flow_spec.type =B_FLOW_SPEC_TCP; > flow_spec.size =izeof(flow_spec); > > Instead, userspace should use the dedicated flow_spec structure for > - Ethernet : struct ib_uverbs_flow_spec_eth, > - IPv4 : struct ib_uverbs_flow_spec_ipv4, > - TCP/UDP : struct ib_uverbs_flow_spec_tcp_udp. > > In other words, struct ib_uverbs_flow_spec is a "virtual" > data structure that can only be use by the kernel as an alias > to the other. > > Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> > Link: http://marc.info/?i=ver.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org > Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org > --- > drivers/infiniband/core/uverbs.h | 16 ++++++++++++++++ > include/uapi/rdma/ib_user_verbs.h | 16 ---------------- > 2 files changed, 16 insertions(+), 16 deletions(-) > > diff --git a/drivers/infiniband/core/uverbs.h b/drivers/infiniband/core/uverbs.h > index d040b87..4ae0307 100644 > --- a/drivers/infiniband/core/uverbs.h > +++ b/drivers/infiniband/core/uverbs.h > @@ -178,6 +178,22 @@ void ib_uverbs_event_handler(struct ib_event_handler *handler, > struct ib_event *event); > void ib_uverbs_dealloc_xrcd(struct ib_uverbs_device *dev, struct ib_xrcd *xrcd); > > +struct ib_uverbs_flow_spec { > + union { > + union { > + struct ib_uverbs_flow_spec_hdr hdr; > + struct { > + __u32 type; > + __u16 size; > + __u16 reserved; > + }; > + }; > + struct ib_uverbs_flow_spec_eth eth; > + struct ib_uverbs_flow_spec_ipv4 ipv4; > + struct ib_uverbs_flow_spec_tcp_udp tcp_udp; > + }; > +}; > + > #define IB_UVERBS_DECLARE_CMD(name) \ > ssize_t ib_uverbs_##name(struct ib_uverbs_file *file, \ > const char __user *buf, int in_len, \ > diff --git a/include/uapi/rdma/ib_user_verbs.h b/include/uapi/rdma/ib_user_verbs.h > index f7f233b5..93577fc 100644 > --- a/include/uapi/rdma/ib_user_verbs.h > +++ b/include/uapi/rdma/ib_user_verbs.h > @@ -760,22 +760,6 @@ struct ib_uverbs_flow_spec_tcp_udp { > struct ib_uverbs_flow_tcp_udp_filter mask; > }; > > -struct ib_uverbs_flow_spec { > - union { > - union { > - struct ib_uverbs_flow_spec_hdr hdr; > - struct { > - __u32 type; > - __u16 size; > - __u16 reserved; > - }; > - }; > - struct ib_uverbs_flow_spec_eth eth; > - struct ib_uverbs_flow_spec_ipv4 ipv4; > - struct ib_uverbs_flow_spec_tcp_udp tcp_udp; > - }; > -}; > - > struct ib_uverbs_flow_attr { > __u32 type; > __u16 size; > -- > 1.8.3.1 > Hi, Nice catch - exposing struct ib_uverbs_flow_spec to userspace imposes another risk. Adding a spec that is larger than all previous specs will result in a larger ib_uverbs_flow_spec structure. This in turn could lead to ABI breaks - something we definitely don't want. The ABI shouldn't include a "do-it-all" spec. Matan -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
* [PATCH 8/9] IB/core: extended command: an improved infrastructure for uverbs commands [not found] ` <cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> ` (6 preceding siblings ...) 2013-10-11 17:18 ` [PATCH 7/9] IB/core: Remove ib_uverbs_flow_spec structure from userspace Yann Droneaud @ 2013-10-11 17:18 ` Yann Droneaud [not found] ` <0b84e20b204eb0fc67db9ca9106d6bf753a12ae3.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> 2013-10-11 17:18 ` [PATCH 9/9] IB/core: extended command: move comp_mask to the extended header Yann Droneaud 2013-10-14 15:36 ` [PATCH 0/9] IB/core: batch of fix against create/destroy_flow uverbs for v3.12 Or Gerlitz 9 siblings, 1 reply; 31+ messages in thread From: Yann Droneaud @ 2013-10-11 17:18 UTC (permalink / raw) To: Roland Dreier, Roland Dreier, Or Gerlitz Cc: Yann Droneaud, linux-rdma-u79uwXL29TY76Z2rM5mHXA, Igor Ivanov, Matan Barak Commit 400dbc9 added an infrastructure for extensible uverbs commands while later commit 436f2ad exported ib_create_flow()/ib_destroy_flow() functions using this new infrastructure. According to the commit 400dbc9, the purpose of this infrastructure is to support passing around provider (eg. hardware) specific buffers when userspace issue commands to the kernel, so that it would be possible to extend uverbs (eg. core) buffers independently from the provider buffers. But the new kernel command function prototypes were not modified to take advantage of this extension. This issue was exposed by Roland Dreier in a previous review[1]. So the following patch is an attempt to a revised extensible command infrastructure. This improved extensible command infrastructure distinguish between core (eg. legacy)'s command/response buffers from provider (eg. hardware)'s command/response buffers: each extended command implementing function is given a struct ib_udata to hold core (eg. uverbs) input and output buffers, and another struct ib_udata to hold the hw (eg. provider) input and output buffers. Having those buffers identified separately make it easier to increase one buffer to support extension without having to add some code to guess the exact size of each command/response parts: This should make the extended functions more reliable. Additionally, instead of relying on command identifier being greater than IB_USER_VERBS_CMD_THRESHOLD, the proposed infrastructure rely on unused bits in command field: on the 32 bits provided by command field, only 6 bits are really needed to encode the identifier of commands currently supported by the kernel. (Even using only 6 bits leaves room for about 23 new commands). So this patch makes use of some high order bits in command field to store flags, leaving enough room for more command identifiers than one will ever need (eg. 256). The new flags are used to specify if the command should be processed as an extended one or a legacy one. While designing the new command format, care was taken to make usage of flags itself extensible. Using high order bits of the commands field ensure that newer libibverbs on older kernel will properly fail when trying to call extended commands. On the other hand, older libibverbs on newer kernel will never be able to issue calls to extended commands. The extended command header includes the optional response pointer so that output buffer length and output buffer pointer are located together in the command, allowing proper parameters checking. This should make implementing functions easier and safer. Additionally the extended header ensure 64bits alignment, while making all sizes multiple of 8 bytes, extending the maximum buffer size: legacy extended Maximum command buffer: 256KBytes 1024KBytes (512KBytes + 512KBytes) Maximum response buffer: 256KBytes 1024KBytes (512KBytes + 512KBytes) For the purpose of doing proper buffer size accounting, the headers size are no more taken in account in "in_words". One of the odds of the current extensible infrastructure, reading twice the "legacy" command header, is fixed by removing the "legacy" command header from the extended command header: they are processed as two different parts of the command: memory is read once and information are not duplicated: it's making clear that's an extended command scheme and not a different command scheme. The proposed scheme will format input (command) and output (response) buffers this way: - command: legacy header + extended header + command data (core + hw): +----------------------------------------+ | flags | 00 00 | command | | in_words | out_words | +----------------------------------------+ | response | | response | | provider_in_words | provider_out_words | | padding | +----------------------------------------+ | | . <uverbs input> . . (in_words * 8) . | | +----------------------------------------+ | | . <provider input> . . (provider_in_words * 8) . | | +----------------------------------------+ - response, if present: +----------------------------------------+ | | . <uverbs output space> . . (out_words * 8) . | | +----------------------------------------+ | | . <provider output space> . . (provider_out_words * 8) . | | +----------------------------------------+ The overall design is to ensure that the extensible infrastructure is itself extensible while begin more reliable with more input and bound checking. [1]: http://marc.info/?i=CAL1RGDWxmM17W2o_era24A-TTDeKyoL6u3NRu_=t_dhV_ZA9MA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org Cc: Igor Ivanov <Igor.Ivanov-wN0M4riKYwLQT0dZR+AlfA@public.gmane.org> Cc: Matan Barak <matanb-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> Link: http://marc.info/?i=cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org --- drivers/infiniband/core/uverbs.h | 18 ++++- drivers/infiniband/core/uverbs_cmd.c | 56 ++++++++-------- drivers/infiniband/core/uverbs_main.c | 121 ++++++++++++++++++++++++++-------- drivers/infiniband/hw/mlx4/main.c | 6 +- include/rdma/ib_verbs.h | 1 + include/uapi/rdma/ib_user_verbs.h | 21 +++--- 6 files changed, 154 insertions(+), 69 deletions(-) diff --git a/drivers/infiniband/core/uverbs.h b/drivers/infiniband/core/uverbs.h index 4ae0307..bdc842e 100644 --- a/drivers/infiniband/core/uverbs.h +++ b/drivers/infiniband/core/uverbs.h @@ -47,6 +47,14 @@ #include <rdma/ib_umem.h> #include <rdma/ib_user_verbs.h> +#define INIT_UDATA(udata, ibuf, obuf, ilen, olen) \ + do { \ + (udata)->inbuf = (void __user *) (ibuf); \ + (udata)->outbuf = (void __user *) (obuf); \ + (udata)->inlen = (ilen); \ + (udata)->outlen = (olen); \ + } while (0) + /* * Our lifetime rules for these structs are the following: * @@ -233,7 +241,13 @@ IB_UVERBS_DECLARE_CMD(destroy_srq); IB_UVERBS_DECLARE_CMD(create_xsrq); IB_UVERBS_DECLARE_CMD(open_xrcd); IB_UVERBS_DECLARE_CMD(close_xrcd); -IB_UVERBS_DECLARE_CMD(create_flow); -IB_UVERBS_DECLARE_CMD(destroy_flow); + +#define IB_UVERBS_DECLARE_EX_CMD(name) \ + int ib_uverbs_ex_##name(struct ib_uverbs_file *file, \ + struct ib_udata *ucore, \ + struct ib_udata *uhw) + +IB_UVERBS_DECLARE_EX_CMD(create_flow); +IB_UVERBS_DECLARE_EX_CMD(destroy_flow); #endif /* UVERBS_H */ diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c index 052e07c..e35877d 100644 --- a/drivers/infiniband/core/uverbs_cmd.c +++ b/drivers/infiniband/core/uverbs_cmd.c @@ -56,14 +56,6 @@ static struct uverbs_lock_class srq_lock_class = { .name = "SRQ-uobj" }; static struct uverbs_lock_class xrcd_lock_class = { .name = "XRCD-uobj" }; static struct uverbs_lock_class rule_lock_class = { .name = "RULE-uobj" }; -#define INIT_UDATA(udata, ibuf, obuf, ilen, olen) \ - do { \ - (udata)->inbuf = (void __user *) (ibuf); \ - (udata)->outbuf = (void __user *) (obuf); \ - (udata)->inlen = (ilen); \ - (udata)->outlen = (olen); \ - } while (0) - /* * The ib_uobject locking scheme is as follows: * @@ -2639,9 +2631,9 @@ static int kern_spec_to_ib_spec(struct ib_uverbs_flow_spec *kern_spec, return 0; } -ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, - const char __user *buf, int in_len, - int out_len) +int ib_uverbs_ex_create_flow(struct ib_uverbs_file *file, + struct ib_udata *ucore, + struct ib_udata *uhw) { struct ib_uverbs_create_flow cmd; struct ib_uverbs_create_flow_resp resp; @@ -2655,11 +2647,15 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, void *ib_spec; int i; - if (out_len < sizeof(resp)) + if (ucore->outlen < sizeof(resp)) return -ENOSPC; - if (copy_from_user(&cmd, buf, sizeof(cmd))) - return -EFAULT; + err = ib_copy_from_udata(&cmd, ucore, sizeof(cmd)); + if (err) + return err; + + ucore->inbuf += sizeof(cmd); + ucore->inlen -= sizeof(cmd); if (cmd.comp_mask) return -EINVAL; @@ -2671,7 +2667,7 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, if (cmd.flow_attr.num_of_specs > IB_FLOW_SPEC_SUPPORT_LAYERS) return -EINVAL; - if (cmd.flow_attr.size > (in_len - sizeof(cmd)) || + if (cmd.flow_attr.size > ucore->inlen || cmd.flow_attr.size > (cmd.flow_attr.num_of_specs * sizeof(struct ib_uverbs_flow_spec))) return -EINVAL; @@ -2683,11 +2679,10 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, return -ENOMEM; memcpy(kern_flow_attr, &cmd.flow_attr, sizeof(*kern_flow_attr)); - if (copy_from_user(kern_flow_attr + 1, buf + sizeof(cmd), - cmd.flow_attr.size)) { - err = -EFAULT; + err = ib_copy_from_udata(kern_flow_attr + 1, ucore, + cmd.flow_attr.size); + if (err) goto err_free_attr; - } } else { kern_flow_attr = &cmd.flow_attr; } @@ -2755,11 +2750,10 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, memset(&resp, 0, sizeof(resp)); resp.flow_handle = uobj->id; - if (copy_to_user((void __user *)(unsigned long) cmd.response, - &resp, sizeof(resp))) { - err = -EFAULT; + err = ib_copy_to_udata(ucore, + &resp, sizeof(resp)); + if (err) goto err_copy; - } put_qp_read(qp); mutex_lock(&file->mutex); @@ -2772,7 +2766,7 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, kfree(flow_attr); if (cmd.flow_attr.num_of_specs) kfree(kern_flow_attr); - return in_len; + return 0; err_copy: idr_remove_uobj(&ib_uverbs_rule_idr, uobj); destroy_flow: @@ -2789,16 +2783,18 @@ err_free_attr: return err; } -ssize_t ib_uverbs_destroy_flow(struct ib_uverbs_file *file, - const char __user *buf, int in_len, - int out_len) { +int ib_uverbs_ex_destroy_flow(struct ib_uverbs_file *file, + struct ib_udata *ucore, + struct ib_udata *uhw) +{ struct ib_uverbs_destroy_flow cmd; struct ib_flow *flow_id; struct ib_uobject *uobj; int ret; - if (copy_from_user(&cmd, buf, sizeof(cmd))) - return -EFAULT; + ret = ib_copy_from_udata(&cmd, ucore, sizeof(cmd)); + if (ret) + return ret; uobj = idr_write_uobj(&ib_uverbs_rule_idr, cmd.flow_handle, file->ucontext); @@ -2820,7 +2816,7 @@ ssize_t ib_uverbs_destroy_flow(struct ib_uverbs_file *file, put_uobj(uobj); - return ret ? ret : in_len; + return ret ? ret : 0; } static int __uverbs_create_xsrq(struct ib_uverbs_file *file, diff --git a/drivers/infiniband/core/uverbs_main.c b/drivers/infiniband/core/uverbs_main.c index 75ad86c..4f00654 100644 --- a/drivers/infiniband/core/uverbs_main.c +++ b/drivers/infiniband/core/uverbs_main.c @@ -115,8 +115,13 @@ static ssize_t (*uverbs_cmd_table[])(struct ib_uverbs_file *file, [IB_USER_VERBS_CMD_CLOSE_XRCD] = ib_uverbs_close_xrcd, [IB_USER_VERBS_CMD_CREATE_XSRQ] = ib_uverbs_create_xsrq, [IB_USER_VERBS_CMD_OPEN_QP] = ib_uverbs_open_qp, - [IB_USER_VERBS_CMD_CREATE_FLOW] = ib_uverbs_create_flow, - [IB_USER_VERBS_CMD_DESTROY_FLOW] = ib_uverbs_destroy_flow +}; + +static int (*uverbs_ex_cmd_table[])(struct ib_uverbs_file *file, + struct ib_udata *ucore, + struct ib_udata *uhw) = { + [IB_USER_VERBS_EX_CMD_CREATE_FLOW] = ib_uverbs_ex_create_flow, + [IB_USER_VERBS_EX_CMD_DESTROY_FLOW] = ib_uverbs_ex_destroy_flow }; static void ib_uverbs_add_one(struct ib_device *device); @@ -587,6 +592,7 @@ 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; if (count < sizeof hdr) return -EINVAL; @@ -594,41 +600,104 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf, if (copy_from_user(&hdr, buf, sizeof hdr)) return -EFAULT; - if (hdr.command >= ARRAY_SIZE(uverbs_cmd_table) || - !uverbs_cmd_table[hdr.command]) - return -EINVAL; + flags = (hdr.command & + IB_USER_VERBS_CMD_FLAGS_MASK) >> IB_USER_VERBS_CMD_FLAGS_SHIFT; - if (!file->ucontext && - hdr.command != IB_USER_VERBS_CMD_GET_CONTEXT) - return -EINVAL; + if (!flags) { + __u32 command; - if (!(file->device->ib_dev->uverbs_cmd_mask & (1ull << hdr.command))) - return -ENOSYS; + if (hdr.command & ~(__u32)(IB_USER_VERBS_CMD_FLAGS_MASK | + IB_USER_VERBS_CMD_COMMAND_MASK)) + return -EINVAL; - if (hdr.command >= IB_USER_VERBS_CMD_THRESHOLD) { - struct ib_uverbs_cmd_hdr_ex hdr_ex; + command = hdr.command & IB_USER_VERBS_CMD_COMMAND_MASK; - if (copy_from_user(&hdr_ex, buf, sizeof(hdr_ex))) - return -EFAULT; + if (command >= ARRAY_SIZE(uverbs_cmd_table) || + !uverbs_cmd_table[command]) + return -EINVAL; - if (((hdr_ex.in_words + hdr_ex.provider_in_words) * 4) != count) + if (!file->ucontext && + command != IB_USER_VERBS_CMD_GET_CONTEXT) return -EINVAL; - return uverbs_cmd_table[hdr.command](file, - buf + sizeof(hdr_ex), - (hdr_ex.in_words + - hdr_ex.provider_in_words) * 4, - (hdr_ex.out_words + - hdr_ex.provider_out_words) * 4); - } else { + if (!(file->device->ib_dev->uverbs_cmd_mask & (1ull << command))) + return -ENOSYS; + if (hdr.in_words * 4 != count) return -EINVAL; - return uverbs_cmd_table[hdr.command](file, - buf + sizeof(hdr), - hdr.in_words * 4, - hdr.out_words * 4); + return uverbs_cmd_table[command](file, + buf + sizeof(hdr), + hdr.in_words * 4, + hdr.out_words * 4); + + } else if (flags == IB_USER_VERBS_CMD_FLAG_EXTENDED) { + __u32 command; + + struct ib_uverbs_ex_cmd_hdr ex_hdr; + struct ib_udata ucore; + struct ib_udata uhw; + int err; + + if (hdr.command & ~(__u32)(IB_USER_VERBS_CMD_FLAGS_MASK | + IB_USER_VERBS_CMD_COMMAND_MASK)) + return -EINVAL; + + command = hdr.command & IB_USER_VERBS_CMD_COMMAND_MASK; + + if (command >= ARRAY_SIZE(uverbs_ex_cmd_table) || + !uverbs_ex_cmd_table[command]) + return -ENOSYS; + + if (!file->ucontext) + return -EINVAL; + + if (!(file->device->ib_dev->uverbs_ex_cmd_mask & (1ull << command))) + return -ENOSYS; + + if (count < (sizeof(hdr) + sizeof(ex_hdr))) + return -EINVAL; + + if (copy_from_user(&ex_hdr, buf + sizeof(hdr), sizeof(ex_hdr))) + return -EFAULT; + + 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 (ex_hdr.response) { + if (!hdr.out_words && !ex_hdr.provider_out_words) + return -EINVAL; + } else { + if (hdr.out_words || ex_hdr.provider_out_words) + return -EINVAL; + } + + INIT_UDATA(&ucore, + (hdr.in_words) ? buf : 0, + (unsigned long)ex_hdr.response, + hdr.in_words * 8, + hdr.out_words * 8); + + INIT_UDATA(&uhw, + (ex_hdr.provider_in_words) ? buf + ucore.inlen : 0, + (ex_hdr.provider_out_words) ? (unsigned long)ex_hdr.response + ucore.outlen : 0, + ex_hdr.provider_in_words * 8, + ex_hdr.provider_out_words * 8); + + err = uverbs_ex_cmd_table[command](file, + &ucore, + &uhw); + + if (err) + return err; + + return count; } + + return -ENOSYS; } static int ib_uverbs_mmap(struct file *filp, struct vm_area_struct *vma) diff --git a/drivers/infiniband/hw/mlx4/main.c b/drivers/infiniband/hw/mlx4/main.c index d6c5a73..1aad9b3 100644 --- a/drivers/infiniband/hw/mlx4/main.c +++ b/drivers/infiniband/hw/mlx4/main.c @@ -1691,9 +1691,9 @@ static void *mlx4_ib_add(struct mlx4_dev *dev) ibdev->ib_dev.create_flow = mlx4_ib_create_flow; ibdev->ib_dev.destroy_flow = mlx4_ib_destroy_flow; - ibdev->ib_dev.uverbs_cmd_mask |= - (1ull << IB_USER_VERBS_CMD_CREATE_FLOW) | - (1ull << IB_USER_VERBS_CMD_DESTROY_FLOW); + ibdev->ib_dev.uverbs_ex_cmd_mask |= + (1ull << IB_USER_VERBS_EX_CMD_CREATE_FLOW) | + (1ull << IB_USER_VERBS_EX_CMD_DESTROY_FLOW); } mlx4_ib_alloc_eqs(dev, ibdev); diff --git a/include/rdma/ib_verbs.h b/include/rdma/ib_verbs.h index e393171..a06fc12 100644 --- a/include/rdma/ib_verbs.h +++ b/include/rdma/ib_verbs.h @@ -1436,6 +1436,7 @@ struct ib_device { int uverbs_abi_ver; u64 uverbs_cmd_mask; + u64 uverbs_ex_cmd_mask; char node_desc[64]; __be64 node_guid; diff --git a/include/uapi/rdma/ib_user_verbs.h b/include/uapi/rdma/ib_user_verbs.h index 93577fc..cbfdd4c 100644 --- a/include/uapi/rdma/ib_user_verbs.h +++ b/include/uapi/rdma/ib_user_verbs.h @@ -87,8 +87,11 @@ enum { IB_USER_VERBS_CMD_CLOSE_XRCD, IB_USER_VERBS_CMD_CREATE_XSRQ, IB_USER_VERBS_CMD_OPEN_QP, - IB_USER_VERBS_CMD_CREATE_FLOW = IB_USER_VERBS_CMD_THRESHOLD, - IB_USER_VERBS_CMD_DESTROY_FLOW +}; + +enum { + IB_USER_VERBS_EX_CMD_CREATE_FLOW = IB_USER_VERBS_CMD_THRESHOLD, + IB_USER_VERBS_EX_CMD_DESTROY_FLOW }; /* @@ -120,16 +123,20 @@ struct ib_uverbs_comp_event_desc { * the rest of the command struct based on these value. */ +#define IB_USER_VERBS_CMD_COMMAND_MASK 0xff +#define IB_USER_VERBS_CMD_FLAGS_MASK 0xff000000u +#define IB_USER_VERBS_CMD_FLAGS_SHIFT 24 + +#define IB_USER_VERBS_CMD_FLAG_EXTENDED 0x80 + struct ib_uverbs_cmd_hdr { __u32 command; __u16 in_words; __u16 out_words; }; -struct ib_uverbs_cmd_hdr_ex { - __u32 command; - __u16 in_words; - __u16 out_words; +struct ib_uverbs_ex_cmd_hdr { + __u64 response; __u16 provider_in_words; __u16 provider_out_words; __u32 cmd_hdr_reserved; @@ -777,8 +784,6 @@ struct ib_uverbs_flow_attr { struct ib_uverbs_create_flow { __u32 comp_mask; - __u32 reserved; - __u64 response; __u32 qp_handle; struct ib_uverbs_flow_attr flow_attr; }; -- 1.8.3.1 -- 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 ^ permalink raw reply related [flat|nested] 31+ messages in thread
[parent not found: <0b84e20b204eb0fc67db9ca9106d6bf753a12ae3.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org>]
* Re: [PATCH 8/9] IB/core: extended command: an improved infrastructure for uverbs commands [not found] ` <0b84e20b204eb0fc67db9ca9106d6bf753a12ae3.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> @ 2013-10-14 15:38 ` Matan Barak [not found] ` <525C0FF2.5040905-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> 0 siblings, 1 reply; 31+ messages in thread From: Matan Barak @ 2013-10-14 15:38 UTC (permalink / raw) To: Yann Droneaud, Roland Dreier, Roland Dreier, Or Gerlitz Cc: linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, Igor Ivanov On 11/10/2013 8:57 PM, Yann Droneaud wrote: > Commit 400dbc9 added an infrastructure for extensible uverbs > commands while later commit 436f2ad exported ib_create_flow()/ib_destroy_flow() > functions using this new infrastructure. > > According to the commit 400dbc9, the purpose of this infrastructure is > to support passing around provider (eg. hardware) specific buffers > when userspace issue commands to the kernel, so that it would be possible > to extend uverbs (eg. core) buffers independently from the provider buffers. > > But the new kernel command function prototypes were not modified > to take advantage of this extension. This issue was exposed by > Roland Dreier in a previous review[1]. > > So the following patch is an attempt to a revised extensible command > infrastructure. > > This improved extensible command infrastructure distinguish between > core (eg. legacy)'s command/response buffers from provider (eg. hardware)'s > command/response buffers: each extended command implementing function > is given a struct ib_udata to hold core (eg. uverbs) input and output buffers, > and another struct ib_udata to hold the hw (eg. provider) input and output > buffers. > Having those buffers identified separately make it easier to increase one > buffer to support extension without having to add some code to guess > the exact size of each command/response parts: This should make the extended > functions more reliable. > > Additionally, instead of relying on command identifier being greater > than IB_USER_VERBS_CMD_THRESHOLD, the proposed infrastructure > rely on unused bits in command field: on the 32 bits provided by > command field, only 6 bits are really needed to encode the identifier > of commands currently supported by the kernel. (Even using only 6 bits > leaves room for about 23 new commands). > > So this patch makes use of some high order bits in command field > to store flags, leaving enough room for more command identifiers > than one will ever need (eg. 256). > > The new flags are used to specify if the command should be processed > as an extended one or a legacy one. While designing the new command format, > care was taken to make usage of flags itself extensible. > > Using high order bits of the commands field ensure > that newer libibverbs on older kernel will properly fail > when trying to call extended commands. On the other hand, > older libibverbs on newer kernel will never be able to issue > calls to extended commands. > > The extended command header includes the optional response > pointer so that output buffer length and output buffer pointer > are located together in the command, allowing proper parameters > checking. This should make implementing functions easier and safer. > > Additionally the extended header ensure 64bits alignment, > while making all sizes multiple of 8 bytes, extending > the maximum buffer size: > > legacy extended > > Maximum command buffer: 256KBytes 1024KBytes (512KBytes + 512KBytes) > Maximum response buffer: 256KBytes 1024KBytes (512KBytes + 512KBytes) > > For the purpose of doing proper buffer size accounting, the headers size > are no more taken in account in "in_words". > > One of the odds of the current extensible infrastructure, reading twice > the "legacy" command header, is fixed by removing the "legacy" command header > from the extended command header: they are processed as two different parts > of the command: memory is read once and information are not duplicated: > it's making clear that's an extended command scheme and not a different > command scheme. > > The proposed scheme will format input (command) and output (response) > buffers this way: > > - command: > > legacy header + > extended header + > command data (core + hw): > > +----------------------------------------+ > | flags | 00 00 | command | > | in_words | out_words | > +----------------------------------------+ > | response | > | response | > | provider_in_words | provider_out_words | > | padding | > +----------------------------------------+ > | | > . <uverbs input> . > . (in_words * 8) . > | | > +----------------------------------------+ > | | > . <provider input> . > . (provider_in_words * 8) . > | | > +----------------------------------------+ > > - response, if present: > > +----------------------------------------+ > | | > . <uverbs output space> . > . (out_words * 8) . > | | > +----------------------------------------+ > | | > . <provider output space> . > . (provider_out_words * 8) . > | | > +----------------------------------------+ > > The overall design is to ensure that the extensible > infrastructure is itself extensible while begin more > reliable with more input and bound checking. > > [1]: > http://marc.info/?iÊL1RGDWxmM17W2o_era24A-TTDeKyoL6u3NRu_=t_dhV_ZA9MA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org > > Cc: Igor Ivanov <Igor.Ivanov-wN0M4riKYwLQT0dZR+AlfA@public.gmane.org> > Cc: Matan Barak <matanb-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> > Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> > Link: http://marc.info/?i=ver.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org > Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org > --- > drivers/infiniband/core/uverbs.h | 18 ++++- > drivers/infiniband/core/uverbs_cmd.c | 56 ++++++++-------- > drivers/infiniband/core/uverbs_main.c | 121 ++++++++++++++++++++++++++-------- > drivers/infiniband/hw/mlx4/main.c | 6 +- > include/rdma/ib_verbs.h | 1 + > include/uapi/rdma/ib_user_verbs.h | 21 +++--- > 6 files changed, 154 insertions(+), 69 deletions(-) > > diff --git a/drivers/infiniband/core/uverbs.h b/drivers/infiniband/core/uverbs.h > index 4ae0307..bdc842e 100644 > --- a/drivers/infiniband/core/uverbs.h > +++ b/drivers/infiniband/core/uverbs.h > @@ -47,6 +47,14 @@ > #include <rdma/ib_umem.h> > #include <rdma/ib_user_verbs.h> > > +#define INIT_UDATA(udata, ibuf, obuf, ilen, olen) \ > + do { \ > + (udata)->inbuf =void __user *) (ibuf); \ > + (udata)->outbuf =void __user *) (obuf); \ > + (udata)->inlen =ilen); \ > + (udata)->outlen =olen); \ > + } while (0) > + > /* > * Our lifetime rules for these structs are the following: > * > @@ -233,7 +241,13 @@ IB_UVERBS_DECLARE_CMD(destroy_srq); > IB_UVERBS_DECLARE_CMD(create_xsrq); > IB_UVERBS_DECLARE_CMD(open_xrcd); > IB_UVERBS_DECLARE_CMD(close_xrcd); > -IB_UVERBS_DECLARE_CMD(create_flow); > -IB_UVERBS_DECLARE_CMD(destroy_flow); > + > +#define IB_UVERBS_DECLARE_EX_CMD(name) \ > + int ib_uverbs_ex_##name(struct ib_uverbs_file *file, \ > + struct ib_udata *ucore, \ > + struct ib_udata *uhw) > + > +IB_UVERBS_DECLARE_EX_CMD(create_flow); > +IB_UVERBS_DECLARE_EX_CMD(destroy_flow); > > #endif /* UVERBS_H */ > diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c > index 052e07c..e35877d 100644 > --- a/drivers/infiniband/core/uverbs_cmd.c > +++ b/drivers/infiniband/core/uverbs_cmd.c > @@ -56,14 +56,6 @@ static struct uverbs_lock_class srq_lock_class = .name = "SRQ-uobj" }; > static struct uverbs_lock_class xrcd_lock_class = .name = "XRCD-uobj" }; > static struct uverbs_lock_class rule_lock_class = .name = "RULE-uobj" }; > > -#define INIT_UDATA(udata, ibuf, obuf, ilen, olen) \ > - do { \ > - (udata)->inbuf =void __user *) (ibuf); \ > - (udata)->outbuf =void __user *) (obuf); \ > - (udata)->inlen =ilen); \ > - (udata)->outlen =olen); \ > - } while (0) > - > /* > * The ib_uobject locking scheme is as follows: > * > @@ -2639,9 +2631,9 @@ static int kern_spec_to_ib_spec(struct ib_uverbs_flow_spec *kern_spec, > return 0; > } > > -ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, > - const char __user *buf, int in_len, > - int out_len) > +int ib_uverbs_ex_create_flow(struct ib_uverbs_file *file, > + struct ib_udata *ucore, > + struct ib_udata *uhw) > { > struct ib_uverbs_create_flow cmd; > struct ib_uverbs_create_flow_resp resp; > @@ -2655,11 +2647,15 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, > void *ib_spec; > int i; > > - if (out_len < sizeof(resp)) > + if (ucore->outlen < sizeof(resp)) > return -ENOSPC; > > - if (copy_from_user(&cmd, buf, sizeof(cmd))) > - return -EFAULT; > + err =b_copy_from_udata(&cmd, ucore, sizeof(cmd)); > + if (err) > + return err; > + > + ucore->inbuf +=izeof(cmd); > + ucore->inlen -=izeof(cmd); > > if (cmd.comp_mask) > return -EINVAL; > @@ -2671,7 +2667,7 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, > if (cmd.flow_attr.num_of_specs > IB_FLOW_SPEC_SUPPORT_LAYERS) > return -EINVAL; > > - if (cmd.flow_attr.size > (in_len - sizeof(cmd)) || > + if (cmd.flow_attr.size > ucore->inlen || > cmd.flow_attr.size > > (cmd.flow_attr.num_of_specs * sizeof(struct ib_uverbs_flow_spec))) > return -EINVAL; > @@ -2683,11 +2679,10 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, > return -ENOMEM; > > memcpy(kern_flow_attr, &cmd.flow_attr, sizeof(*kern_flow_attr)); > - if (copy_from_user(kern_flow_attr + 1, buf + sizeof(cmd), > - cmd.flow_attr.size)) { > - err =EFAULT; > + err =b_copy_from_udata(kern_flow_attr + 1, ucore, > + cmd.flow_attr.size); > + if (err) > goto err_free_attr; > - } > } else { > kern_flow_attr =cmd.flow_attr; > } > @@ -2755,11 +2750,10 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, > memset(&resp, 0, sizeof(resp)); > resp.flow_handle =obj->id; > > - if (copy_to_user((void __user *)(unsigned long) cmd.response, > - &resp, sizeof(resp))) { > - err =EFAULT; > + err =b_copy_to_udata(ucore, > + &resp, sizeof(resp)); > + if (err) > goto err_copy; > - } > > put_qp_read(qp); > mutex_lock(&file->mutex); > @@ -2772,7 +2766,7 @@ ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, > kfree(flow_attr); > if (cmd.flow_attr.num_of_specs) > kfree(kern_flow_attr); > - return in_len; > + return 0; > err_copy: > idr_remove_uobj(&ib_uverbs_rule_idr, uobj); > destroy_flow: > @@ -2789,16 +2783,18 @@ err_free_attr: > return err; > } > > -ssize_t ib_uverbs_destroy_flow(struct ib_uverbs_file *file, > - const char __user *buf, int in_len, > - int out_len) { > +int ib_uverbs_ex_destroy_flow(struct ib_uverbs_file *file, > + struct ib_udata *ucore, > + struct ib_udata *uhw) > +{ > struct ib_uverbs_destroy_flow cmd; > struct ib_flow *flow_id; > struct ib_uobject *uobj; > int ret; > > - if (copy_from_user(&cmd, buf, sizeof(cmd))) > - return -EFAULT; > + ret =b_copy_from_udata(&cmd, ucore, sizeof(cmd)); > + if (ret) > + return ret; > > uobj =dr_write_uobj(&ib_uverbs_rule_idr, cmd.flow_handle, > file->ucontext); > @@ -2820,7 +2816,7 @@ ssize_t ib_uverbs_destroy_flow(struct ib_uverbs_file *file, > > put_uobj(uobj); > > - return ret ? ret : in_len; > + return ret ? ret : 0; > } > > static int __uverbs_create_xsrq(struct ib_uverbs_file *file, > diff --git a/drivers/infiniband/core/uverbs_main.c b/drivers/infiniband/core/uverbs_main.c > index 75ad86c..4f00654 100644 > --- a/drivers/infiniband/core/uverbs_main.c > +++ b/drivers/infiniband/core/uverbs_main.c > @@ -115,8 +115,13 @@ static ssize_t (*uverbs_cmd_table[])(struct ib_uverbs_file *file, > [IB_USER_VERBS_CMD_CLOSE_XRCD] =b_uverbs_close_xrcd, > [IB_USER_VERBS_CMD_CREATE_XSRQ] =b_uverbs_create_xsrq, > [IB_USER_VERBS_CMD_OPEN_QP] =b_uverbs_open_qp, > - [IB_USER_VERBS_CMD_CREATE_FLOW] =b_uverbs_create_flow, > - [IB_USER_VERBS_CMD_DESTROY_FLOW] =b_uverbs_destroy_flow > +}; > + > +static int (*uverbs_ex_cmd_table[])(struct ib_uverbs_file *file, > + struct ib_udata *ucore, > + struct ib_udata *uhw) = > + [IB_USER_VERBS_EX_CMD_CREATE_FLOW] =b_uverbs_ex_create_flow, > + [IB_USER_VERBS_EX_CMD_DESTROY_FLOW] =b_uverbs_ex_destroy_flow > }; > > static void ib_uverbs_add_one(struct ib_device *device); > @@ -587,6 +592,7 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf, > { > struct ib_uverbs_file *file =ilp->private_data; > struct ib_uverbs_cmd_hdr hdr; > + __u32 flags; > > if (count < sizeof hdr) > return -EINVAL; > @@ -594,41 +600,104 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf, > if (copy_from_user(&hdr, buf, sizeof hdr)) > return -EFAULT; > > - if (hdr.command >=RRAY_SIZE(uverbs_cmd_table) || > - !uverbs_cmd_table[hdr.command]) > - return -EINVAL; > + flags =hdr.command & > + IB_USER_VERBS_CMD_FLAGS_MASK) >> IB_USER_VERBS_CMD_FLAGS_SHIFT; > > - if (!file->ucontext && > - hdr.command !=B_USER_VERBS_CMD_GET_CONTEXT) > - return -EINVAL; > + if (!flags) { > + __u32 command; > > - if (!(file->device->ib_dev->uverbs_cmd_mask & (1ull << hdr.command))) > - return -ENOSYS; > + if (hdr.command & ~(__u32)(IB_USER_VERBS_CMD_FLAGS_MASK | > + IB_USER_VERBS_CMD_COMMAND_MASK)) > + return -EINVAL; > > - if (hdr.command >=B_USER_VERBS_CMD_THRESHOLD) { > - struct ib_uverbs_cmd_hdr_ex hdr_ex; > + command =dr.command & IB_USER_VERBS_CMD_COMMAND_MASK; > > - if (copy_from_user(&hdr_ex, buf, sizeof(hdr_ex))) > - return -EFAULT; > + if (command >=RRAY_SIZE(uverbs_cmd_table) || > + !uverbs_cmd_table[command]) > + return -EINVAL; > > - if (((hdr_ex.in_words + hdr_ex.provider_in_words) * 4) !=ount) > + if (!file->ucontext && > + command !=B_USER_VERBS_CMD_GET_CONTEXT) > return -EINVAL; > > - return uverbs_cmd_table[hdr.command](file, > - buf + sizeof(hdr_ex), > - (hdr_ex.in_words + > - hdr_ex.provider_in_words) * 4, > - (hdr_ex.out_words + > - hdr_ex.provider_out_words) * 4); > - } else { > + if (!(file->device->ib_dev->uverbs_cmd_mask & (1ull << command))) > + return -ENOSYS; > + > if (hdr.in_words * 4 !=ount) > return -EINVAL; > > - return uverbs_cmd_table[hdr.command](file, > - buf + sizeof(hdr), > - hdr.in_words * 4, > - hdr.out_words * 4); > + return uverbs_cmd_table[command](file, > + buf + sizeof(hdr), > + hdr.in_words * 4, > + hdr.out_words * 4); > + > + } else if (flags =IB_USER_VERBS_CMD_FLAG_EXTENDED) { > + __u32 command; > + > + struct ib_uverbs_ex_cmd_hdr ex_hdr; > + struct ib_udata ucore; > + struct ib_udata uhw; > + int err; > + > + if (hdr.command & ~(__u32)(IB_USER_VERBS_CMD_FLAGS_MASK | > + IB_USER_VERBS_CMD_COMMAND_MASK)) > + return -EINVAL; > + > + command =dr.command & IB_USER_VERBS_CMD_COMMAND_MASK; > + > + if (command >=RRAY_SIZE(uverbs_ex_cmd_table) || > + !uverbs_ex_cmd_table[command]) > + return -ENOSYS; > + > + if (!file->ucontext) > + return -EINVAL; > + > + if (!(file->device->ib_dev->uverbs_ex_cmd_mask & (1ull << command))) > + return -ENOSYS; > + > + if (count < (sizeof(hdr) + sizeof(ex_hdr))) > + return -EINVAL; > + > + if (copy_from_user(&ex_hdr, buf + sizeof(hdr), sizeof(ex_hdr))) > + return -EFAULT; > + > + count -=izeof(hdr) + sizeof(ex_hdr); > + buf +=izeof(hdr) + sizeof(ex_hdr); > + > + if ((hdr.in_words + ex_hdr.provider_in_words) * 8 !=ount) > + return -EINVAL; > + > + if (ex_hdr.response) { > + if (!hdr.out_words && !ex_hdr.provider_out_words) > + return -EINVAL; > + } else { > + if (hdr.out_words || ex_hdr.provider_out_words) > + return -EINVAL; > + } > + > + INIT_UDATA(&ucore, > + (hdr.in_words) ? buf : 0, > + (unsigned long)ex_hdr.response, > + hdr.in_words * 8, > + hdr.out_words * 8); > + > + INIT_UDATA(&uhw, > + (ex_hdr.provider_in_words) ? buf + ucore.inlen : 0, > + (ex_hdr.provider_out_words) ? (unsigned long)ex_hdr.response + ucore.outlen : 0, > + ex_hdr.provider_in_words * 8, > + ex_hdr.provider_out_words * 8); > + > + err =verbs_ex_cmd_table[command](file, > + &ucore, > + &uhw); > + > + if (err) > + return err; > + > + return count; > } > + > + return -ENOSYS; > } > > static int ib_uverbs_mmap(struct file *filp, struct vm_area_struct *vma) > diff --git a/drivers/infiniband/hw/mlx4/main.c b/drivers/infiniband/hw/mlx4/main.c > index d6c5a73..1aad9b3 100644 > --- a/drivers/infiniband/hw/mlx4/main.c > +++ b/drivers/infiniband/hw/mlx4/main.c > @@ -1691,9 +1691,9 @@ static void *mlx4_ib_add(struct mlx4_dev *dev) > ibdev->ib_dev.create_flow =lx4_ib_create_flow; > ibdev->ib_dev.destroy_flow =lx4_ib_destroy_flow; > > - ibdev->ib_dev.uverbs_cmd_mask |- (1ull << IB_USER_VERBS_CMD_CREATE_FLOW) | > - (1ull << IB_USER_VERBS_CMD_DESTROY_FLOW); > + ibdev->ib_dev.uverbs_ex_cmd_mask |+ (1ull << IB_USER_VERBS_EX_CMD_CREATE_FLOW) | > + (1ull << IB_USER_VERBS_EX_CMD_DESTROY_FLOW); > } > > mlx4_ib_alloc_eqs(dev, ibdev); > diff --git a/include/rdma/ib_verbs.h b/include/rdma/ib_verbs.h > index e393171..a06fc12 100644 > --- a/include/rdma/ib_verbs.h > +++ b/include/rdma/ib_verbs.h > @@ -1436,6 +1436,7 @@ struct ib_device { > > int uverbs_abi_ver; > u64 uverbs_cmd_mask; > + u64 uverbs_ex_cmd_mask; > > char node_desc[64]; > __be64 node_guid; > diff --git a/include/uapi/rdma/ib_user_verbs.h b/include/uapi/rdma/ib_user_verbs.h > index 93577fc..cbfdd4c 100644 > --- a/include/uapi/rdma/ib_user_verbs.h > +++ b/include/uapi/rdma/ib_user_verbs.h > @@ -87,8 +87,11 @@ enum { > IB_USER_VERBS_CMD_CLOSE_XRCD, > IB_USER_VERBS_CMD_CREATE_XSRQ, > IB_USER_VERBS_CMD_OPEN_QP, > - IB_USER_VERBS_CMD_CREATE_FLOW =B_USER_VERBS_CMD_THRESHOLD, > - IB_USER_VERBS_CMD_DESTROY_FLOW > +}; > + > +enum { > + IB_USER_VERBS_EX_CMD_CREATE_FLOW =B_USER_VERBS_CMD_THRESHOLD, > + IB_USER_VERBS_EX_CMD_DESTROY_FLOW > }; I think B_USER_VERBS_CMD_THRESHOLD could be removed. > > /* > @@ -120,16 +123,20 @@ struct ib_uverbs_comp_event_desc { > * the rest of the command struct based on these value. > */ > > +#define IB_USER_VERBS_CMD_COMMAND_MASK 0xff > +#define IB_USER_VERBS_CMD_FLAGS_MASK 0xff000000u > +#define IB_USER_VERBS_CMD_FLAGS_SHIFT 24 > + > +#define IB_USER_VERBS_CMD_FLAG_EXTENDED 0x80 > + > struct ib_uverbs_cmd_hdr { > __u32 command; > __u16 in_words; > __u16 out_words; > }; > > -struct ib_uverbs_cmd_hdr_ex { > - __u32 command; > - __u16 in_words; > - __u16 out_words; > +struct ib_uverbs_ex_cmd_hdr { > + __u64 response; > __u16 provider_in_words; > __u16 provider_out_words; > __u32 cmd_hdr_reserved; > @@ -777,8 +784,6 @@ struct ib_uverbs_flow_attr { > > struct ib_uverbs_create_flow { > __u32 comp_mask; > - __u32 reserved; > - __u64 response; > __u32 qp_handle; > struct ib_uverbs_flow_attr flow_attr; > }; > -- > 1.8.3.1 > This infrastructure (as well as the original one) doesn't deal with the case we discussed about in the previous patches. When a command contains a structure that can be extended, we don't have a clean nice way of doing that. Though, because it's a limitation of the original design and this patch cleans up the functionality of the original infrastructure, I'm in favor of merging it. Matan -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
[parent not found: <525C0FF2.5040905-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>]
* Re: [PATCH 8/9] IB/core: extended command: an improved infrastructure for uverbs commands [not found] ` <525C0FF2.5040905-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> @ 2013-10-17 14:41 ` Matan Barak [not found] ` <525FF724.5050601-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> 0 siblings, 1 reply; 31+ messages in thread From: Matan Barak @ 2013-10-17 14:41 UTC (permalink / raw) To: Yann Droneaud, Roland Dreier, Roland Dreier, Or Gerlitz Cc: linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, Igor Ivanov On 14/10/2013 6:38 PM, Matan Barak wrote: > On 11/10/2013 8:57 PM, Yann Droneaud wrote: >> Commit 400dbc9 added an infrastructure for extensible uverbs >> commands while later commit 436f2ad exported >> ib_create_flow()/ib_destroy_flow() >> functions using this new infrastructure. >> >> According to the commit 400dbc9, the purpose of this infrastructure is >> to support passing around provider (eg. hardware) specific buffers >> when userspace issue commands to the kernel, so that it would be possible >> to extend uverbs (eg. core) buffers independently from the provider >> buffers. >> >> But the new kernel command function prototypes were not modified >> to take advantage of this extension. This issue was exposed by >> Roland Dreier in a previous review[1]. >> >> So the following patch is an attempt to a revised extensible command >> infrastructure. >> >> This improved extensible command infrastructure distinguish between >> core (eg. legacy)'s command/response buffers from provider (eg. >> hardware)'s >> command/response buffers: each extended command implementing function >> is given a struct ib_udata to hold core (eg. uverbs) input and output >> buffers, >> and another struct ib_udata to hold the hw (eg. provider) input and >> output >> buffers. >> Having those buffers identified separately make it easier to increase one >> buffer to support extension without having to add some code to guess >> the exact size of each command/response parts: This should make the >> extended >> functions more reliable. >> >> Additionally, instead of relying on command identifier being greater >> than IB_USER_VERBS_CMD_THRESHOLD, the proposed infrastructure >> rely on unused bits in command field: on the 32 bits provided by >> command field, only 6 bits are really needed to encode the identifier >> of commands currently supported by the kernel. (Even using only 6 bits >> leaves room for about 23 new commands). >> >> So this patch makes use of some high order bits in command field >> to store flags, leaving enough room for more command identifiers >> than one will ever need (eg. 256). >> >> The new flags are used to specify if the command should be processed >> as an extended one or a legacy one. While designing the new command >> format, >> care was taken to make usage of flags itself extensible. >> >> Using high order bits of the commands field ensure >> that newer libibverbs on older kernel will properly fail >> when trying to call extended commands. On the other hand, >> older libibverbs on newer kernel will never be able to issue >> calls to extended commands. >> >> The extended command header includes the optional response >> pointer so that output buffer length and output buffer pointer >> are located together in the command, allowing proper parameters >> checking. This should make implementing functions easier and safer. >> >> Additionally the extended header ensure 64bits alignment, >> while making all sizes multiple of 8 bytes, extending >> the maximum buffer size: >> >> legacy extended >> >> Maximum command buffer: 256KBytes 1024KBytes (512KBytes + >> 512KBytes) >> Maximum response buffer: 256KBytes 1024KBytes (512KBytes + >> 512KBytes) >> >> For the purpose of doing proper buffer size accounting, the headers size >> are no more taken in account in "in_words". >> >> One of the odds of the current extensible infrastructure, reading twice >> the "legacy" command header, is fixed by removing the "legacy" command >> header >> from the extended command header: they are processed as two different >> parts >> of the command: memory is read once and information are not duplicated: >> it's making clear that's an extended command scheme and not a different >> command scheme. >> >> The proposed scheme will format input (command) and output (response) >> buffers this way: >> >> - command: >> >> legacy header + >> extended header + >> command data (core + hw): >> >> +----------------------------------------+ >> | flags | 00 00 | command | >> | in_words | out_words | >> +----------------------------------------+ >> | response | >> | response | >> | provider_in_words | provider_out_words | >> | padding | >> +----------------------------------------+ >> | | >> . <uverbs input> . >> . (in_words * 8) . >> | | >> +----------------------------------------+ >> | | >> . <provider input> . >> . (provider_in_words * 8) . >> | | >> +----------------------------------------+ >> >> - response, if present: >> >> +----------------------------------------+ >> | | >> . <uverbs output space> . >> . (out_words * 8) . >> | | >> +----------------------------------------+ >> | | >> . <provider output space> . >> . (provider_out_words * 8) . >> | | >> +----------------------------------------+ >> >> The overall design is to ensure that the extensible >> infrastructure is itself extensible while begin more >> reliable with more input and bound checking. >> >> [1]: >> http://marc.info/?iÊL1RGDWxmM17W2o_era24A-TTDeKyoL6u3NRu_=t_dhV_ZA9MA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org >> >> >> Cc: Igor Ivanov <Igor.Ivanov-wN0M4riKYwLQT0dZR+AlfA@public.gmane.org> >> Cc: Matan Barak <matanb-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> >> Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> >> Link: http://marc.info/?i=ver.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org >> Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org >> --- >> drivers/infiniband/core/uverbs.h | 18 ++++- >> drivers/infiniband/core/uverbs_cmd.c | 56 ++++++++-------- >> drivers/infiniband/core/uverbs_main.c | 121 >> ++++++++++++++++++++++++++-------- >> drivers/infiniband/hw/mlx4/main.c | 6 +- >> include/rdma/ib_verbs.h | 1 + >> include/uapi/rdma/ib_user_verbs.h | 21 +++--- >> 6 files changed, 154 insertions(+), 69 deletions(-) >> >> diff --git a/drivers/infiniband/core/uverbs.h >> b/drivers/infiniband/core/uverbs.h >> index 4ae0307..bdc842e 100644 >> --- a/drivers/infiniband/core/uverbs.h >> +++ b/drivers/infiniband/core/uverbs.h >> @@ -47,6 +47,14 @@ >> #include <rdma/ib_umem.h> >> #include <rdma/ib_user_verbs.h> >> >> +#define INIT_UDATA(udata, ibuf, obuf, ilen, olen) \ >> + do { \ >> + (udata)->inbuf =void __user *) (ibuf); \ >> + (udata)->outbuf =void __user *) (obuf); \ >> + (udata)->inlen =ilen); \ >> + (udata)->outlen =olen); \ >> + } while (0) >> + >> /* >> * Our lifetime rules for these structs are the following: >> * >> @@ -233,7 +241,13 @@ IB_UVERBS_DECLARE_CMD(destroy_srq); >> IB_UVERBS_DECLARE_CMD(create_xsrq); >> IB_UVERBS_DECLARE_CMD(open_xrcd); >> IB_UVERBS_DECLARE_CMD(close_xrcd); >> -IB_UVERBS_DECLARE_CMD(create_flow); >> -IB_UVERBS_DECLARE_CMD(destroy_flow); >> + >> +#define IB_UVERBS_DECLARE_EX_CMD(name) \ >> + int ib_uverbs_ex_##name(struct ib_uverbs_file *file, \ >> + struct ib_udata *ucore, \ >> + struct ib_udata *uhw) >> + >> +IB_UVERBS_DECLARE_EX_CMD(create_flow); >> +IB_UVERBS_DECLARE_EX_CMD(destroy_flow); >> >> #endif /* UVERBS_H */ >> diff --git a/drivers/infiniband/core/uverbs_cmd.c >> b/drivers/infiniband/core/uverbs_cmd.c >> index 052e07c..e35877d 100644 >> --- a/drivers/infiniband/core/uverbs_cmd.c >> +++ b/drivers/infiniband/core/uverbs_cmd.c >> @@ -56,14 +56,6 @@ static struct uverbs_lock_class >> srq_lock_class = .name = "SRQ-uobj" }; >> static struct uverbs_lock_class xrcd_lock_class = .name = >> "XRCD-uobj" }; >> static struct uverbs_lock_class rule_lock_class = .name = >> "RULE-uobj" }; >> >> -#define INIT_UDATA(udata, ibuf, obuf, ilen, olen) \ >> - do { \ >> - (udata)->inbuf =void __user *) (ibuf); \ >> - (udata)->outbuf =void __user *) (obuf); \ >> - (udata)->inlen =ilen); \ >> - (udata)->outlen =olen); \ >> - } while (0) >> - >> /* >> * The ib_uobject locking scheme is as follows: >> * >> @@ -2639,9 +2631,9 @@ static int kern_spec_to_ib_spec(struct >> ib_uverbs_flow_spec *kern_spec, >> return 0; >> } >> >> -ssize_t ib_uverbs_create_flow(struct ib_uverbs_file *file, >> - const char __user *buf, int in_len, >> - int out_len) >> +int ib_uverbs_ex_create_flow(struct ib_uverbs_file *file, >> + struct ib_udata *ucore, >> + struct ib_udata *uhw) >> { >> struct ib_uverbs_create_flow cmd; >> struct ib_uverbs_create_flow_resp resp; >> @@ -2655,11 +2647,15 @@ ssize_t ib_uverbs_create_flow(struct >> ib_uverbs_file *file, >> void *ib_spec; >> int i; >> >> - if (out_len < sizeof(resp)) >> + if (ucore->outlen < sizeof(resp)) >> return -ENOSPC; >> >> - if (copy_from_user(&cmd, buf, sizeof(cmd))) >> - return -EFAULT; >> + err =b_copy_from_udata(&cmd, ucore, sizeof(cmd)); >> + if (err) >> + return err; >> + >> + ucore->inbuf +=izeof(cmd); >> + ucore->inlen -=izeof(cmd); >> >> if (cmd.comp_mask) >> return -EINVAL; >> @@ -2671,7 +2667,7 @@ ssize_t ib_uverbs_create_flow(struct >> ib_uverbs_file *file, >> if (cmd.flow_attr.num_of_specs > IB_FLOW_SPEC_SUPPORT_LAYERS) >> return -EINVAL; >> >> - if (cmd.flow_attr.size > (in_len - sizeof(cmd)) || >> + if (cmd.flow_attr.size > ucore->inlen || >> cmd.flow_attr.size > >> (cmd.flow_attr.num_of_specs * sizeof(struct >> ib_uverbs_flow_spec))) >> return -EINVAL; >> @@ -2683,11 +2679,10 @@ ssize_t ib_uverbs_create_flow(struct >> ib_uverbs_file *file, >> return -ENOMEM; >> >> memcpy(kern_flow_attr, &cmd.flow_attr, >> sizeof(*kern_flow_attr)); >> - if (copy_from_user(kern_flow_attr + 1, buf + sizeof(cmd), >> - cmd.flow_attr.size)) { >> - err =EFAULT; >> + err =b_copy_from_udata(kern_flow_attr + 1, ucore, >> + cmd.flow_attr.size); >> + if (err) >> goto err_free_attr; >> - } >> } else { >> kern_flow_attr =cmd.flow_attr; >> } >> @@ -2755,11 +2750,10 @@ ssize_t ib_uverbs_create_flow(struct >> ib_uverbs_file *file, >> memset(&resp, 0, sizeof(resp)); >> resp.flow_handle =obj->id; >> >> - if (copy_to_user((void __user *)(unsigned long) cmd.response, >> - &resp, sizeof(resp))) { >> - err =EFAULT; >> + err =b_copy_to_udata(ucore, >> + &resp, sizeof(resp)); >> + if (err) >> goto err_copy; >> - } >> >> put_qp_read(qp); >> mutex_lock(&file->mutex); >> @@ -2772,7 +2766,7 @@ ssize_t ib_uverbs_create_flow(struct >> ib_uverbs_file *file, >> kfree(flow_attr); >> if (cmd.flow_attr.num_of_specs) >> kfree(kern_flow_attr); >> - return in_len; >> + return 0; >> err_copy: >> idr_remove_uobj(&ib_uverbs_rule_idr, uobj); >> destroy_flow: >> @@ -2789,16 +2783,18 @@ err_free_attr: >> return err; >> } >> >> -ssize_t ib_uverbs_destroy_flow(struct ib_uverbs_file *file, >> - const char __user *buf, int in_len, >> - int out_len) { >> +int ib_uverbs_ex_destroy_flow(struct ib_uverbs_file *file, >> + struct ib_udata *ucore, >> + struct ib_udata *uhw) >> +{ >> struct ib_uverbs_destroy_flow cmd; >> struct ib_flow *flow_id; >> struct ib_uobject *uobj; >> int ret; >> >> - if (copy_from_user(&cmd, buf, sizeof(cmd))) >> - return -EFAULT; >> + ret =b_copy_from_udata(&cmd, ucore, sizeof(cmd)); >> + if (ret) >> + return ret; >> >> uobj =dr_write_uobj(&ib_uverbs_rule_idr, cmd.flow_handle, >> file->ucontext); >> @@ -2820,7 +2816,7 @@ ssize_t ib_uverbs_destroy_flow(struct >> ib_uverbs_file *file, >> >> put_uobj(uobj); >> >> - return ret ? ret : in_len; >> + return ret ? ret : 0; >> } >> >> static int __uverbs_create_xsrq(struct ib_uverbs_file *file, >> diff --git a/drivers/infiniband/core/uverbs_main.c >> b/drivers/infiniband/core/uverbs_main.c >> index 75ad86c..4f00654 100644 >> --- a/drivers/infiniband/core/uverbs_main.c >> +++ b/drivers/infiniband/core/uverbs_main.c >> @@ -115,8 +115,13 @@ static ssize_t (*uverbs_cmd_table[])(struct >> ib_uverbs_file *file, >> [IB_USER_VERBS_CMD_CLOSE_XRCD] =b_uverbs_close_xrcd, >> [IB_USER_VERBS_CMD_CREATE_XSRQ] =b_uverbs_create_xsrq, >> [IB_USER_VERBS_CMD_OPEN_QP] =b_uverbs_open_qp, >> - [IB_USER_VERBS_CMD_CREATE_FLOW] =b_uverbs_create_flow, >> - [IB_USER_VERBS_CMD_DESTROY_FLOW] =b_uverbs_destroy_flow >> +}; >> + >> +static int (*uverbs_ex_cmd_table[])(struct ib_uverbs_file *file, >> + struct ib_udata *ucore, >> + struct ib_udata *uhw) = >> + [IB_USER_VERBS_EX_CMD_CREATE_FLOW] =b_uverbs_ex_create_flow, >> + [IB_USER_VERBS_EX_CMD_DESTROY_FLOW] =b_uverbs_ex_destroy_flow >> }; >> >> static void ib_uverbs_add_one(struct ib_device *device); >> @@ -587,6 +592,7 @@ static ssize_t ib_uverbs_write(struct file *filp, >> const char __user *buf, >> { >> struct ib_uverbs_file *file =ilp->private_data; >> struct ib_uverbs_cmd_hdr hdr; >> + __u32 flags; >> >> if (count < sizeof hdr) >> return -EINVAL; >> @@ -594,41 +600,104 @@ static ssize_t ib_uverbs_write(struct file >> *filp, const char __user *buf, >> if (copy_from_user(&hdr, buf, sizeof hdr)) >> return -EFAULT; >> >> - if (hdr.command >=RRAY_SIZE(uverbs_cmd_table) || >> - !uverbs_cmd_table[hdr.command]) >> - return -EINVAL; >> + flags =hdr.command & >> + IB_USER_VERBS_CMD_FLAGS_MASK) >> >> IB_USER_VERBS_CMD_FLAGS_SHIFT; >> >> - if (!file->ucontext && >> - hdr.command !=B_USER_VERBS_CMD_GET_CONTEXT) >> - return -EINVAL; >> + if (!flags) { >> + __u32 command; >> >> - if (!(file->device->ib_dev->uverbs_cmd_mask & (1ull << >> hdr.command))) >> - return -ENOSYS; >> + if (hdr.command & ~(__u32)(IB_USER_VERBS_CMD_FLAGS_MASK | >> + >> IB_USER_VERBS_CMD_COMMAND_MASK)) >> + return -EINVAL; >> >> - if (hdr.command >=B_USER_VERBS_CMD_THRESHOLD) { >> - struct ib_uverbs_cmd_hdr_ex hdr_ex; >> + command =dr.command & IB_USER_VERBS_CMD_COMMAND_MASK; >> >> - if (copy_from_user(&hdr_ex, buf, sizeof(hdr_ex))) >> - return -EFAULT; >> + if (command >=RRAY_SIZE(uverbs_cmd_table) || >> + !uverbs_cmd_table[command]) >> + return -EINVAL; >> >> - if (((hdr_ex.in_words + hdr_ex.provider_in_words) * 4) >> !=ount) >> + if (!file->ucontext && >> + command !=B_USER_VERBS_CMD_GET_CONTEXT) >> return -EINVAL; >> >> - return uverbs_cmd_table[hdr.command](file, >> - buf + >> sizeof(hdr_ex), >> - (hdr_ex.in_words + >> - >> hdr_ex.provider_in_words) * 4, >> - (hdr_ex.out_words + >> - >> hdr_ex.provider_out_words) * 4); >> - } else { >> + if (!(file->device->ib_dev->uverbs_cmd_mask & (1ull << >> command))) >> + return -ENOSYS; >> + >> if (hdr.in_words * 4 !=ount) >> return -EINVAL; >> >> - return uverbs_cmd_table[hdr.command](file, >> - buf + sizeof(hdr), >> - hdr.in_words * 4, >> - hdr.out_words * 4); >> + return uverbs_cmd_table[command](file, >> + buf + sizeof(hdr), >> + hdr.in_words * 4, >> + hdr.out_words * 4); >> + >> + } else if (flags =IB_USER_VERBS_CMD_FLAG_EXTENDED) { >> + __u32 command; >> + >> + struct ib_uverbs_ex_cmd_hdr ex_hdr; >> + struct ib_udata ucore; >> + struct ib_udata uhw; >> + int err; >> + >> + if (hdr.command & ~(__u32)(IB_USER_VERBS_CMD_FLAGS_MASK | >> + >> IB_USER_VERBS_CMD_COMMAND_MASK)) >> + return -EINVAL; >> + >> + command =dr.command & IB_USER_VERBS_CMD_COMMAND_MASK; >> + >> + if (command >=RRAY_SIZE(uverbs_ex_cmd_table) || >> + !uverbs_ex_cmd_table[command]) >> + return -ENOSYS; >> + >> + if (!file->ucontext) >> + return -EINVAL; >> + >> + if (!(file->device->ib_dev->uverbs_ex_cmd_mask & (1ull >> << command))) >> + return -ENOSYS; >> + >> + if (count < (sizeof(hdr) + sizeof(ex_hdr))) >> + return -EINVAL; >> + >> + if (copy_from_user(&ex_hdr, buf + sizeof(hdr), >> sizeof(ex_hdr))) >> + return -EFAULT; >> + >> + count -=izeof(hdr) + sizeof(ex_hdr); A small issue: count is reduced here and the write function returns the reduced size. I think we should return the amount of data the user wrote and not to subtract the headers from the returned size. >> + buf +=izeof(hdr) + sizeof(ex_hdr); >> + >> + if ((hdr.in_words + ex_hdr.provider_in_words) * 8 !=ount) >> + return -EINVAL; >> + >> + if (ex_hdr.response) { >> + if (!hdr.out_words && !ex_hdr.provider_out_words) >> + return -EINVAL; >> + } else { >> + if (hdr.out_words || ex_hdr.provider_out_words) >> + return -EINVAL; >> + } >> + >> + INIT_UDATA(&ucore, >> + (hdr.in_words) ? buf : 0, >> + (unsigned long)ex_hdr.response, >> + hdr.in_words * 8, >> + hdr.out_words * 8); >> + >> + INIT_UDATA(&uhw, >> + (ex_hdr.provider_in_words) ? buf + >> ucore.inlen : 0, >> + (ex_hdr.provider_out_words) ? (unsigned >> long)ex_hdr.response + ucore.outlen : 0, >> + ex_hdr.provider_in_words * 8, >> + ex_hdr.provider_out_words * 8); >> + >> + err =verbs_ex_cmd_table[command](file, >> + &ucore, >> + &uhw); >> + >> + if (err) >> + return err; >> + >> + return count; ====================^ >> } >> + >> + return -ENOSYS; >> } >> >> static int ib_uverbs_mmap(struct file *filp, struct vm_area_struct >> *vma) >> diff --git a/drivers/infiniband/hw/mlx4/main.c >> b/drivers/infiniband/hw/mlx4/main.c >> index d6c5a73..1aad9b3 100644 >> --- a/drivers/infiniband/hw/mlx4/main.c >> +++ b/drivers/infiniband/hw/mlx4/main.c >> @@ -1691,9 +1691,9 @@ static void *mlx4_ib_add(struct mlx4_dev *dev) >> ibdev->ib_dev.create_flow =lx4_ib_create_flow; >> ibdev->ib_dev.destroy_flow =lx4_ib_destroy_flow; >> >> - ibdev->ib_dev.uverbs_cmd_mask >> |- (1ull << IB_USER_VERBS_CMD_CREATE_FLOW) | >> - (1ull << IB_USER_VERBS_CMD_DESTROY_FLOW); >> + ibdev->ib_dev.uverbs_ex_cmd_mask >> |+ (1ull << IB_USER_VERBS_EX_CMD_CREATE_FLOW) | >> + (1ull << IB_USER_VERBS_EX_CMD_DESTROY_FLOW); >> } >> >> mlx4_ib_alloc_eqs(dev, ibdev); >> diff --git a/include/rdma/ib_verbs.h b/include/rdma/ib_verbs.h >> index e393171..a06fc12 100644 >> --- a/include/rdma/ib_verbs.h >> +++ b/include/rdma/ib_verbs.h >> @@ -1436,6 +1436,7 @@ struct ib_device { >> >> int uverbs_abi_ver; >> u64 uverbs_cmd_mask; >> + u64 uverbs_ex_cmd_mask; >> >> char node_desc[64]; >> __be64 node_guid; >> diff --git a/include/uapi/rdma/ib_user_verbs.h >> b/include/uapi/rdma/ib_user_verbs.h >> index 93577fc..cbfdd4c 100644 >> --- a/include/uapi/rdma/ib_user_verbs.h >> +++ b/include/uapi/rdma/ib_user_verbs.h >> @@ -87,8 +87,11 @@ enum { >> IB_USER_VERBS_CMD_CLOSE_XRCD, >> IB_USER_VERBS_CMD_CREATE_XSRQ, >> IB_USER_VERBS_CMD_OPEN_QP, >> - IB_USER_VERBS_CMD_CREATE_FLOW =B_USER_VERBS_CMD_THRESHOLD, >> - IB_USER_VERBS_CMD_DESTROY_FLOW >> +}; >> + >> +enum { >> + IB_USER_VERBS_EX_CMD_CREATE_FLOW =B_USER_VERBS_CMD_THRESHOLD, >> + IB_USER_VERBS_EX_CMD_DESTROY_FLOW >> }; > > I think B_USER_VERBS_CMD_THRESHOLD could be removed. > >> >> /* >> @@ -120,16 +123,20 @@ struct ib_uverbs_comp_event_desc { >> * the rest of the command struct based on these value. >> */ >> >> +#define IB_USER_VERBS_CMD_COMMAND_MASK 0xff >> +#define IB_USER_VERBS_CMD_FLAGS_MASK 0xff000000u >> +#define IB_USER_VERBS_CMD_FLAGS_SHIFT 24 >> + >> +#define IB_USER_VERBS_CMD_FLAG_EXTENDED 0x80 >> + >> struct ib_uverbs_cmd_hdr { >> __u32 command; >> __u16 in_words; >> __u16 out_words; >> }; >> >> -struct ib_uverbs_cmd_hdr_ex { >> - __u32 command; >> - __u16 in_words; >> - __u16 out_words; >> +struct ib_uverbs_ex_cmd_hdr { >> + __u64 response; >> __u16 provider_in_words; >> __u16 provider_out_words; >> __u32 cmd_hdr_reserved; >> @@ -777,8 +784,6 @@ struct ib_uverbs_flow_attr { >> >> struct ib_uverbs_create_flow { >> __u32 comp_mask; >> - __u32 reserved; >> - __u64 response; >> __u32 qp_handle; >> struct ib_uverbs_flow_attr flow_attr; >> }; >> -- >> 1.8.3.1 >> > > This infrastructure (as well as the original one) doesn't deal with the > case we discussed about in the previous patches. When a command contains > a structure that can be extended, we don't have a clean nice way of > doing that. Though, because it's a limitation of the original design and > this patch cleans up the functionality of the original infrastructure, > I'm in favor of merging it. > > Matan Regarding the disable of flow steering commands, we could just remove the flow steering uverbs from the commands array, but then we'll have to count on the compiler to do the required optimizations. Matan -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
[parent not found: <525FF724.5050601-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>]
* Re: [PATCH 8/9] IB/core: extended command: an improved infrastructure for uverbs commands [not found] ` <525FF724.5050601-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> @ 2013-10-17 15:05 ` Yann Droneaud [not found] ` <f45595bcb4399ea2cb81d99a914dd9a0-zgzEX58YAwA@public.gmane.org> 0 siblings, 1 reply; 31+ messages in thread From: Yann Droneaud @ 2013-10-17 15:05 UTC (permalink / raw) To: Matan Barak Cc: Roland Dreier, Roland Dreier, Or Gerlitz, linux-rdma-u79uwXL29TY76Z2rM5mHXA, Igor Ivanov Hi, Le 17.10.2013 16:41, Matan Barak a écrit : > On 14/10/2013 6:38 PM, Matan Barak wrote: >> On 11/10/2013 8:57 PM, Yann Droneaud wrote: >>> Commit 400dbc9 added an infrastructure for extensible uverbs >>> commands while later commit 436f2ad exported >>> ib_create_flow()/ib_destroy_flow() >>> functions using this new infrastructure. >>> >>> diff --git a/drivers/infiniband/core/uverbs_main.c >>> b/drivers/infiniband/core/uverbs_main.c >>> index 75ad86c..4f00654 100644 >>> --- a/drivers/infiniband/core/uverbs_main.c >>> +++ b/drivers/infiniband/core/uverbs_main.c >>> @@ -587,6 +592,7 @@ static ssize_t ib_uverbs_write(struct file *filp, >>> @@ -594,41 +600,104 @@ static ssize_t ib_uverbs_write(struct file >>> *filp, const char __user *buf, >>> if (copy_from_user(&hdr, buf, sizeof hdr)) >>> return -EFAULT; >>> >>> - if (hdr.command >=RRAY_SIZE(uverbs_cmd_table) || >>> - !uverbs_cmd_table[hdr.command]) >>> - return -EINVAL; >>> + flags =hdr.command & >>> + IB_USER_VERBS_CMD_FLAGS_MASK) >> >>> IB_USER_VERBS_CMD_FLAGS_SHIFT; >>> >>> - if (!file->ucontext && >>> - hdr.command !=B_USER_VERBS_CMD_GET_CONTEXT) >>> - return -EINVAL; >>> + if (!flags) { >>> + __u32 command; >>> >>> - if (!(file->device->ib_dev->uverbs_cmd_mask & (1ull << >>> hdr.command))) >>> - return -ENOSYS; >>> + if (hdr.command & >>> ~(__u32)(IB_USER_VERBS_CMD_FLAGS_MASK | >>> + >>> IB_USER_VERBS_CMD_COMMAND_MASK)) >>> + return -EINVAL; >>> >>> - if (hdr.command >=B_USER_VERBS_CMD_THRESHOLD) { >>> - struct ib_uverbs_cmd_hdr_ex hdr_ex; >>> + command =dr.command & IB_USER_VERBS_CMD_COMMAND_MASK; >>> >>> - if (copy_from_user(&hdr_ex, buf, sizeof(hdr_ex))) >>> - return -EFAULT; >>> + if (command >=RRAY_SIZE(uverbs_cmd_table) || >>> + !uverbs_cmd_table[command]) >>> + return -EINVAL; >>> >>> - if (((hdr_ex.in_words + hdr_ex.provider_in_words) * >>> 4) >>> !=ount) >>> + if (!file->ucontext && >>> + command !=B_USER_VERBS_CMD_GET_CONTEXT) >>> return -EINVAL; >>> >>> - return uverbs_cmd_table[hdr.command](file, >>> - buf + >>> sizeof(hdr_ex), >>> - (hdr_ex.in_words >>> + >>> - >>> hdr_ex.provider_in_words) * 4, >>> - >>> (hdr_ex.out_words + >>> - >>> hdr_ex.provider_out_words) * 4); >>> - } else { >>> + if (!(file->device->ib_dev->uverbs_cmd_mask & (1ull >>> << >>> command))) >>> + return -ENOSYS; >>> + >>> if (hdr.in_words * 4 !=ount) >>> return -EINVAL; >>> >>> - return uverbs_cmd_table[hdr.command](file, >>> - buf + >>> sizeof(hdr), >>> - hdr.in_words * >>> 4, >>> - hdr.out_words * >>> 4); >>> + return uverbs_cmd_table[command](file, >>> + buf + sizeof(hdr), >>> + hdr.in_words * 4, >>> + hdr.out_words * 4); >>> + >>> + } else if (flags =IB_USER_VERBS_CMD_FLAG_EXTENDED) { >>> + __u32 command; >>> + >>> + struct ib_uverbs_ex_cmd_hdr ex_hdr; >>> + struct ib_udata ucore; >>> + struct ib_udata uhw; >>> + int err; >>> + >>> + if (hdr.command & >>> ~(__u32)(IB_USER_VERBS_CMD_FLAGS_MASK | >>> + >>> IB_USER_VERBS_CMD_COMMAND_MASK)) >>> + return -EINVAL; >>> + >>> + command =dr.command & IB_USER_VERBS_CMD_COMMAND_MASK; >>> + >>> + if (command >=RRAY_SIZE(uverbs_ex_cmd_table) || >>> + !uverbs_ex_cmd_table[command]) >>> + return -ENOSYS; >>> + >>> + if (!file->ucontext) >>> + return -EINVAL; >>> + >>> + if (!(file->device->ib_dev->uverbs_ex_cmd_mask & >>> (1ull >>> << command))) >>> + return -ENOSYS; >>> + >>> + if (count < (sizeof(hdr) + sizeof(ex_hdr))) >>> + return -EINVAL; >>> + >>> + if (copy_from_user(&ex_hdr, buf + sizeof(hdr), >>> sizeof(ex_hdr))) >>> + return -EFAULT; >>> + >>> + count -=izeof(hdr) + sizeof(ex_hdr); > > A small issue: count is reduced here and the write function returns > the reduced size. > I think we should return the amount of data the user wrote and not to > subtract the headers from the returned size. > Good catch. >>> + >>> + return count; > > ====================^ > >>> diff --git a/include/uapi/rdma/ib_user_verbs.h >>> b/include/uapi/rdma/ib_user_verbs.h >>> index 93577fc..cbfdd4c 100644 >>> --- a/include/uapi/rdma/ib_user_verbs.h >>> +++ b/include/uapi/rdma/ib_user_verbs.h >>> @@ -87,8 +87,11 @@ enum { >>> IB_USER_VERBS_CMD_CLOSE_XRCD, >>> IB_USER_VERBS_CMD_CREATE_XSRQ, >>> IB_USER_VERBS_CMD_OPEN_QP, >>> - IB_USER_VERBS_CMD_CREATE_FLOW = IB_USER_VERBS_CMD_THRESHOLD, >>> - IB_USER_VERBS_CMD_DESTROY_FLOW >>> +}; >>> + >>> +enum { >>> + IB_USER_VERBS_EX_CMD_CREATE_FLOW = >>> IB_USER_VERBS_CMD_THRESHOLD, >>> + IB_USER_VERBS_EX_CMD_DESTROY_FLOW >>> }; >> >> I think B_USER_VERBS_CMD_THRESHOLD could be removed. >> If it's removed, CREATE_FLOW will be the first command. I thought it could be interesting to keep room for the "legacy" commands if they're going to be supported as extended commands in the future. Regards. -- Yann Droneaud OPTEYA -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
[parent not found: <f45595bcb4399ea2cb81d99a914dd9a0-zgzEX58YAwA@public.gmane.org>]
* Re: [PATCH 8/9] IB/core: extended command: an improved infrastructure for uverbs commands [not found] ` <f45595bcb4399ea2cb81d99a914dd9a0-zgzEX58YAwA@public.gmane.org> @ 2013-10-24 0:34 ` Or Gerlitz 0 siblings, 0 replies; 31+ messages in thread From: Or Gerlitz @ 2013-10-24 0:34 UTC (permalink / raw) To: Yann Droneaud Cc: Matan Barak, Roland Dreier, Roland Dreier, Or Gerlitz, linux-rdma, Igor Ivanov On Thu, Oct 17, 2013 at 6:05 PM, Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> wrote: > Hi, > > Le 17.10.2013 16:41, Matan Barak a écrit : > >> On 14/10/2013 6:38 PM, Matan Barak wrote: >>> >>> On 11/10/2013 8:57 PM, Yann Droneaud wrote: >>>> >>>> Commit 400dbc9 added an infrastructure for extensible uverbs >>>> commands while later commit 436f2ad exported >>>> ib_create_flow()/ib_destroy_flow() >>>> functions using this new infrastructure. >>>> > >>>> diff --git a/drivers/infiniband/core/uverbs_main.c >>>> b/drivers/infiniband/core/uverbs_main.c >>>> index 75ad86c..4f00654 100644 >>>> --- a/drivers/infiniband/core/uverbs_main.c >>>> +++ b/drivers/infiniband/core/uverbs_main.c >>>> @@ -587,6 +592,7 @@ static ssize_t ib_uverbs_write(struct file *filp, >>>> @@ -594,41 +600,104 @@ static ssize_t ib_uverbs_write(struct file >>>> *filp, const char __user *buf, >>>> if (copy_from_user(&hdr, buf, sizeof hdr)) >>>> return -EFAULT; >>>> >>>> - if (hdr.command >=RRAY_SIZE(uverbs_cmd_table) || >>>> - !uverbs_cmd_table[hdr.command]) >>>> - return -EINVAL; >>>> + flags =hdr.command & >>>> + IB_USER_VERBS_CMD_FLAGS_MASK) >> >>>> IB_USER_VERBS_CMD_FLAGS_SHIFT; >>>> >>>> - if (!file->ucontext && >>>> - hdr.command !=B_USER_VERBS_CMD_GET_CONTEXT) >>>> - return -EINVAL; >>>> + if (!flags) { >>>> + __u32 command; >>>> >>>> - if (!(file->device->ib_dev->uverbs_cmd_mask & (1ull << >>>> hdr.command))) >>>> - return -ENOSYS; >>>> + if (hdr.command & ~(__u32)(IB_USER_VERBS_CMD_FLAGS_MASK >>>> | >>>> + >>>> IB_USER_VERBS_CMD_COMMAND_MASK)) >>>> + return -EINVAL; >>>> >>>> - if (hdr.command >=B_USER_VERBS_CMD_THRESHOLD) { >>>> - struct ib_uverbs_cmd_hdr_ex hdr_ex; >>>> + command =dr.command & IB_USER_VERBS_CMD_COMMAND_MASK; >>>> >>>> - if (copy_from_user(&hdr_ex, buf, sizeof(hdr_ex))) >>>> - return -EFAULT; >>>> + if (command >=RRAY_SIZE(uverbs_cmd_table) || >>>> + !uverbs_cmd_table[command]) >>>> + return -EINVAL; >>>> >>>> - if (((hdr_ex.in_words + hdr_ex.provider_in_words) * 4) >>>> !=ount) >>>> + if (!file->ucontext && >>>> + command !=B_USER_VERBS_CMD_GET_CONTEXT) >>>> return -EINVAL; >>>> >>>> - return uverbs_cmd_table[hdr.command](file, >>>> - buf + >>>> sizeof(hdr_ex), >>>> - (hdr_ex.in_words + >>>> - >>>> hdr_ex.provider_in_words) * 4, >>>> - (hdr_ex.out_words + >>>> - >>>> hdr_ex.provider_out_words) * 4); >>>> - } else { >>>> + if (!(file->device->ib_dev->uverbs_cmd_mask & (1ull << >>>> command))) >>>> + return -ENOSYS; >>>> + >>>> if (hdr.in_words * 4 !=ount) >>>> return -EINVAL; >>>> >>>> - return uverbs_cmd_table[hdr.command](file, >>>> - buf + sizeof(hdr), >>>> - hdr.in_words * 4, >>>> - hdr.out_words * 4); >>>> + return uverbs_cmd_table[command](file, >>>> + buf + sizeof(hdr), >>>> + hdr.in_words * 4, >>>> + hdr.out_words * 4); >>>> + >>>> + } else if (flags =IB_USER_VERBS_CMD_FLAG_EXTENDED) { >>>> + __u32 command; >>>> + >>>> + struct ib_uverbs_ex_cmd_hdr ex_hdr; >>>> + struct ib_udata ucore; >>>> + struct ib_udata uhw; >>>> + int err; >>>> + >>>> + if (hdr.command & ~(__u32)(IB_USER_VERBS_CMD_FLAGS_MASK >>>> | >>>> + >>>> IB_USER_VERBS_CMD_COMMAND_MASK)) >>>> + return -EINVAL; >>>> + >>>> + command =dr.command & IB_USER_VERBS_CMD_COMMAND_MASK; >>>> + >>>> + if (command >=RRAY_SIZE(uverbs_ex_cmd_table) || >>>> + !uverbs_ex_cmd_table[command]) >>>> + return -ENOSYS; >>>> + >>>> + if (!file->ucontext) >>>> + return -EINVAL; >>>> + >>>> + if (!(file->device->ib_dev->uverbs_ex_cmd_mask & (1ull >>>> << command))) >>>> + return -ENOSYS; >>>> + >>>> + if (count < (sizeof(hdr) + sizeof(ex_hdr))) >>>> + return -EINVAL; >>>> + >>>> + if (copy_from_user(&ex_hdr, buf + sizeof(hdr), >>>> sizeof(ex_hdr))) >>>> + return -EFAULT; >>>> + >>>> + count -=izeof(hdr) + sizeof(ex_hdr); >> >> >> A small issue: count is reduced here and the write function returns >> the reduced size. >> I think we should return the amount of data the user wrote and not to >> subtract the headers from the returned size. >> > > Good catch. Yann, the 3.13 merge window is coming closer, can you please post V2 of this series with fixes to the few issues Matan was pointing on and possibly one squash @ the beginning of the series, if this is possible. > > >>>> + >>>> + return count; >> >> >> ====================^ >> > > >>>> diff --git a/include/uapi/rdma/ib_user_verbs.h >>>> b/include/uapi/rdma/ib_user_verbs.h >>>> index 93577fc..cbfdd4c 100644 >>>> --- a/include/uapi/rdma/ib_user_verbs.h >>>> +++ b/include/uapi/rdma/ib_user_verbs.h >>>> @@ -87,8 +87,11 @@ enum { >>>> IB_USER_VERBS_CMD_CLOSE_XRCD, >>>> IB_USER_VERBS_CMD_CREATE_XSRQ, >>>> IB_USER_VERBS_CMD_OPEN_QP, >>>> - IB_USER_VERBS_CMD_CREATE_FLOW = IB_USER_VERBS_CMD_THRESHOLD, >>>> >>>> - IB_USER_VERBS_CMD_DESTROY_FLOW >>>> +}; >>>> + >>>> +enum { >>>> + IB_USER_VERBS_EX_CMD_CREATE_FLOW = IB_USER_VERBS_CMD_THRESHOLD, >>>> + IB_USER_VERBS_EX_CMD_DESTROY_FLOW >>>> }; >>> >>> >>> I think B_USER_VERBS_CMD_THRESHOLD could be removed. >>> > > If it's removed, CREATE_FLOW will be the first command. > > I thought it could be interesting to keep room for the "legacy" > commands if they're going to be supported as extended commands > in the future. > > Regards. > > -- > Yann Droneaud > OPTEYA > > > -- > 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 -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
* [PATCH 9/9] IB/core: extended command: move comp_mask to the extended header [not found] ` <cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> ` (7 preceding siblings ...) 2013-10-11 17:18 ` [PATCH 8/9] IB/core: extended command: an improved infrastructure for uverbs commands Yann Droneaud @ 2013-10-11 17:18 ` Yann Droneaud [not found] ` <40175eda10d670d098204da6aa4c327a0171ae5f.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> 2013-10-14 15:36 ` [PATCH 0/9] IB/core: batch of fix against create/destroy_flow uverbs for v3.12 Or Gerlitz 9 siblings, 1 reply; 31+ messages in thread From: Yann Droneaud @ 2013-10-11 17:18 UTC (permalink / raw) To: Roland Dreier, Roland Dreier, Or Gerlitz Cc: Yann Droneaud, linux-rdma-u79uwXL29TY76Z2rM5mHXA, Igor Ivanov, Matan Barak The unused field in the extended header is a perfect candidate to hold the command "comp_mask" (eg. bit field used to handle compatibility). This was suggested by Roland Dreier in a previous review[1]. So this patch move comp_mask from create_flow/destroy_flow commands to the extended command header. Then comp_mask is passed as part of function parameters. [1]: http://marc.info/?i=CAL1RGDXJtrc849M6_XNZT5xO1+ybKtLWGq6yg6LhoSsKpsmkYA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org Cc: Igor Ivanov <Igor.Ivanov-wN0M4riKYwLQT0dZR+AlfA@public.gmane.org> Cc: Matan Barak <matanb-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> Link: http://marc.info/?i=cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org --- drivers/infiniband/core/uverbs.h | 3 ++- drivers/infiniband/core/uverbs_cmd.c | 15 ++++++++++----- drivers/infiniband/core/uverbs_main.c | 6 ++++-- include/uapi/rdma/ib_user_verbs.h | 6 +++--- 4 files changed, 19 insertions(+), 11 deletions(-) diff --git a/drivers/infiniband/core/uverbs.h b/drivers/infiniband/core/uverbs.h index bdc842e..a12b516 100644 --- a/drivers/infiniband/core/uverbs.h +++ b/drivers/infiniband/core/uverbs.h @@ -245,7 +245,8 @@ IB_UVERBS_DECLARE_CMD(close_xrcd); #define IB_UVERBS_DECLARE_EX_CMD(name) \ int ib_uverbs_ex_##name(struct ib_uverbs_file *file, \ struct ib_udata *ucore, \ - struct ib_udata *uhw) + struct ib_udata *uhw, \ + __u32 comp_mask) IB_UVERBS_DECLARE_EX_CMD(create_flow); IB_UVERBS_DECLARE_EX_CMD(destroy_flow); diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c index e35877d..a8ecb3a 100644 --- a/drivers/infiniband/core/uverbs_cmd.c +++ b/drivers/infiniband/core/uverbs_cmd.c @@ -2633,7 +2633,8 @@ static int kern_spec_to_ib_spec(struct ib_uverbs_flow_spec *kern_spec, int ib_uverbs_ex_create_flow(struct ib_uverbs_file *file, struct ib_udata *ucore, - struct ib_udata *uhw) + struct ib_udata *uhw, + __u32 comp_mask) { struct ib_uverbs_create_flow cmd; struct ib_uverbs_create_flow_resp resp; @@ -2647,6 +2648,9 @@ int ib_uverbs_ex_create_flow(struct ib_uverbs_file *file, void *ib_spec; int i; + if (comp_mask) + return -EINVAL; + if (ucore->outlen < sizeof(resp)) return -ENOSPC; @@ -2657,9 +2661,6 @@ int ib_uverbs_ex_create_flow(struct ib_uverbs_file *file, ucore->inbuf += sizeof(cmd); ucore->inlen -= sizeof(cmd); - if (cmd.comp_mask) - return -EINVAL; - if ((cmd.flow_attr.type == IB_FLOW_ATTR_SNIFFER && !capable(CAP_NET_ADMIN)) || !capable(CAP_NET_RAW)) return -EPERM; @@ -2785,13 +2786,17 @@ err_free_attr: int ib_uverbs_ex_destroy_flow(struct ib_uverbs_file *file, struct ib_udata *ucore, - struct ib_udata *uhw) + struct ib_udata *uhw, + __u32 comp_mask) { struct ib_uverbs_destroy_flow cmd; struct ib_flow *flow_id; struct ib_uobject *uobj; int ret; + if (comp_mask) + return -EINVAL; + ret = ib_copy_from_udata(&cmd, ucore, sizeof(cmd)); if (ret) return ret; diff --git a/drivers/infiniband/core/uverbs_main.c b/drivers/infiniband/core/uverbs_main.c index 4f00654..a9687dd 100644 --- a/drivers/infiniband/core/uverbs_main.c +++ b/drivers/infiniband/core/uverbs_main.c @@ -119,7 +119,8 @@ static ssize_t (*uverbs_cmd_table[])(struct ib_uverbs_file *file, static int (*uverbs_ex_cmd_table[])(struct ib_uverbs_file *file, struct ib_udata *ucore, - struct ib_udata *uhw) = { + struct ib_udata *uhw, + __u32 comp_mask) = { [IB_USER_VERBS_EX_CMD_CREATE_FLOW] = ib_uverbs_ex_create_flow, [IB_USER_VERBS_EX_CMD_DESTROY_FLOW] = ib_uverbs_ex_destroy_flow }; @@ -689,7 +690,8 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf, err = uverbs_ex_cmd_table[command](file, &ucore, - &uhw); + &uhw, + ex_hdr.comp_mask); if (err) return err; diff --git a/include/uapi/rdma/ib_user_verbs.h b/include/uapi/rdma/ib_user_verbs.h index cbfdd4c..095a2bd 100644 --- a/include/uapi/rdma/ib_user_verbs.h +++ b/include/uapi/rdma/ib_user_verbs.h @@ -139,7 +139,7 @@ struct ib_uverbs_ex_cmd_hdr { __u64 response; __u16 provider_in_words; __u16 provider_out_words; - __u32 cmd_hdr_reserved; + __u32 comp_mask; }; struct ib_uverbs_get_context { @@ -783,8 +783,8 @@ struct ib_uverbs_flow_attr { }; struct ib_uverbs_create_flow { - __u32 comp_mask; __u32 qp_handle; + __u32 reserved; struct ib_uverbs_flow_attr flow_attr; }; @@ -794,8 +794,8 @@ struct ib_uverbs_create_flow_resp { }; struct ib_uverbs_destroy_flow { - __u32 comp_mask; __u32 flow_handle; + __u32 reserved; }; struct ib_uverbs_create_srq { -- 1.8.3.1 -- 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 ^ permalink raw reply related [flat|nested] 31+ messages in thread
[parent not found: <40175eda10d670d098204da6aa4c327a0171ae5f.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org>]
* Re: [PATCH 9/9] IB/core: extended command: move comp_mask to the extended header [not found] ` <40175eda10d670d098204da6aa4c327a0171ae5f.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> @ 2013-10-14 15:44 ` Matan Barak 0 siblings, 0 replies; 31+ messages in thread From: Matan Barak @ 2013-10-14 15:44 UTC (permalink / raw) To: Yann Droneaud, Roland Dreier, Roland Dreier, Or Gerlitz Cc: linux-rdma-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, Igor Ivanov On 11/10/2013 8:57 PM, Yann Droneaud wrote: > The unused field in the extended header is a perfect candidate > to hold the command "comp_mask" (eg. bit field used to handle > compatibility). This was suggested by Roland Dreier in a previous > review[1]. > > So this patch move comp_mask from create_flow/destroy_flow commands > to the extended command header. Then comp_mask is passed as part > of function parameters. > > [1]: > http://marc.info/?iÊL1RGDXJtrc849M6_XNZT5xO1+ybKtLWGq6yg6LhoSsKpsmkYA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org > > Cc: Igor Ivanov <Igor.Ivanov-wN0M4riKYwLQT0dZR+AlfA@public.gmane.org> > Cc: Matan Barak <matanb-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org> > Signed-off-by: Yann Droneaud <ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> > Link: http://marc.info/?i=ver.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org > Link: http://mid.gmane.org/cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org > --- > drivers/infiniband/core/uverbs.h | 3 ++- > drivers/infiniband/core/uverbs_cmd.c | 15 ++++++++++----- > drivers/infiniband/core/uverbs_main.c | 6 ++++-- > include/uapi/rdma/ib_user_verbs.h | 6 +++--- > 4 files changed, 19 insertions(+), 11 deletions(-) > > diff --git a/drivers/infiniband/core/uverbs.h b/drivers/infiniband/core/uverbs.h > index bdc842e..a12b516 100644 > --- a/drivers/infiniband/core/uverbs.h > +++ b/drivers/infiniband/core/uverbs.h > @@ -245,7 +245,8 @@ IB_UVERBS_DECLARE_CMD(close_xrcd); > #define IB_UVERBS_DECLARE_EX_CMD(name) \ > int ib_uverbs_ex_##name(struct ib_uverbs_file *file, \ > struct ib_udata *ucore, \ > - struct ib_udata *uhw) > + struct ib_udata *uhw, \ > + __u32 comp_mask) > > IB_UVERBS_DECLARE_EX_CMD(create_flow); > IB_UVERBS_DECLARE_EX_CMD(destroy_flow); > diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c > index e35877d..a8ecb3a 100644 > --- a/drivers/infiniband/core/uverbs_cmd.c > +++ b/drivers/infiniband/core/uverbs_cmd.c > @@ -2633,7 +2633,8 @@ static int kern_spec_to_ib_spec(struct ib_uverbs_flow_spec *kern_spec, > > int ib_uverbs_ex_create_flow(struct ib_uverbs_file *file, > struct ib_udata *ucore, > - struct ib_udata *uhw) > + struct ib_udata *uhw, > + __u32 comp_mask) > { > struct ib_uverbs_create_flow cmd; > struct ib_uverbs_create_flow_resp resp; > @@ -2647,6 +2648,9 @@ int ib_uverbs_ex_create_flow(struct ib_uverbs_file *file, > void *ib_spec; > int i; > > + if (comp_mask) > + return -EINVAL; > + > if (ucore->outlen < sizeof(resp)) > return -ENOSPC; > > @@ -2657,9 +2661,6 @@ int ib_uverbs_ex_create_flow(struct ib_uverbs_file *file, > ucore->inbuf +=izeof(cmd); > ucore->inlen -=izeof(cmd); > > - if (cmd.comp_mask) > - return -EINVAL; > - > if ((cmd.flow_attr.type =IB_FLOW_ATTR_SNIFFER && > !capable(CAP_NET_ADMIN)) || !capable(CAP_NET_RAW)) > return -EPERM; > @@ -2785,13 +2786,17 @@ err_free_attr: > > int ib_uverbs_ex_destroy_flow(struct ib_uverbs_file *file, > struct ib_udata *ucore, > - struct ib_udata *uhw) > + struct ib_udata *uhw, > + __u32 comp_mask) > { > struct ib_uverbs_destroy_flow cmd; > struct ib_flow *flow_id; > struct ib_uobject *uobj; > int ret; > > + if (comp_mask) > + return -EINVAL; > + > ret =b_copy_from_udata(&cmd, ucore, sizeof(cmd)); > if (ret) > return ret; > diff --git a/drivers/infiniband/core/uverbs_main.c b/drivers/infiniband/core/uverbs_main.c > index 4f00654..a9687dd 100644 > --- a/drivers/infiniband/core/uverbs_main.c > +++ b/drivers/infiniband/core/uverbs_main.c > @@ -119,7 +119,8 @@ static ssize_t (*uverbs_cmd_table[])(struct ib_uverbs_file *file, > > static int (*uverbs_ex_cmd_table[])(struct ib_uverbs_file *file, > struct ib_udata *ucore, > - struct ib_udata *uhw) = > + struct ib_udata *uhw, > + __u32 comp_mask) = > [IB_USER_VERBS_EX_CMD_CREATE_FLOW] =b_uverbs_ex_create_flow, > [IB_USER_VERBS_EX_CMD_DESTROY_FLOW] =b_uverbs_ex_destroy_flow > }; > @@ -689,7 +690,8 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf, > > err =verbs_ex_cmd_table[command](file, > &ucore, > - &uhw); > + &uhw, > + ex_hdr.comp_mask); > > if (err) > return err; > diff --git a/include/uapi/rdma/ib_user_verbs.h b/include/uapi/rdma/ib_user_verbs.h > index cbfdd4c..095a2bd 100644 > --- a/include/uapi/rdma/ib_user_verbs.h > +++ b/include/uapi/rdma/ib_user_verbs.h > @@ -139,7 +139,7 @@ struct ib_uverbs_ex_cmd_hdr { > __u64 response; > __u16 provider_in_words; > __u16 provider_out_words; > - __u32 cmd_hdr_reserved; > + __u32 comp_mask; > }; > > struct ib_uverbs_get_context { > @@ -783,8 +783,8 @@ struct ib_uverbs_flow_attr { > }; > > struct ib_uverbs_create_flow { > - __u32 comp_mask; > __u32 qp_handle; > + __u32 reserved; > struct ib_uverbs_flow_attr flow_attr; > }; > > @@ -794,8 +794,8 @@ struct ib_uverbs_create_flow_resp { > }; > > struct ib_uverbs_destroy_flow { > - __u32 comp_mask; > __u32 flow_handle; > + __u32 reserved; > }; > > struct ib_uverbs_create_srq { > -- > 1.8.3.1 > I think that's a good idea to make the comp_mask field a part of our infrastructure. But, I think we should consider making this symmetrical. If we use the command's comp_mask as an input parameter, shouldn't we use the response's comp_mask as an output parameter ? What's about the provider's comp_mask ? Matan -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
* Re: [PATCH 0/9] IB/core: batch of fix against create/destroy_flow uverbs for v3.12 [not found] ` <cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org> ` (8 preceding siblings ...) 2013-10-11 17:18 ` [PATCH 9/9] IB/core: extended command: move comp_mask to the extended header Yann Droneaud @ 2013-10-14 15:36 ` Or Gerlitz 9 siblings, 0 replies; 31+ messages in thread From: Or Gerlitz @ 2013-10-14 15:36 UTC (permalink / raw) To: Yann Droneaud Cc: Roland Dreier, Roland Dreier, linux-rdma-u79uwXL29TY76Z2rM5mHXA On 11/10/2013 20:18, Yann Droneaud wrote: > As requested by Or Gerlitz, I've rebased my previous fixes [1] > against Matan Barak patch [2]. I've added two patches to fix issues > left or introduced by this patch. > Regarding the previous patchset [1], I've kept the public data > structure improving and renaming patches, but, in order to minimize > the overall changes, I've removed the changes which were modifying > the functions and variables names in the code. > I've removed "code beautifying" and left "hardening" / cleanup changes > for a latter release. > > On top of this, I've added the two acknowledged and important patches > from my extended command infrastructure [3]. I've made cleanups in the > changelog regarding the 'email' citations. Hi Yann, Matan provided some feedback, I think he has little more which he will send tomorrow. Please make sure to use version-ing for the patch series, e.g if I got it right, this post was V2 and the next is V3 -- so you can just --subject-prefix="PATCH V3" for git format-patch, also leave the listing of the change history on the cover letter e.g V2 --> V3 changes: xxx - what you will change in V3 V1 --> V2 changes: yyy (what's written above) -- 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 ^ permalink raw reply [flat|nested] 31+ messages in thread
end of thread, other threads:[~2013-10-24 0:34 UTC | newest]
Thread overview: 31+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-10-11 17:18 [PATCH 0/9] IB/core: batch of fix against create/destroy_flow uverbs for v3.12 Yann Droneaud
[not found] ` <cover.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org>
2013-10-11 17:18 ` [PATCH 1/9] IB/core: clarify overflow/underflow checks on ib_create/destroy_flow Yann Droneaud
2013-10-11 17:18 ` [PATCH 2/9] IB/core: Includes flow attribute size in uverbs create_flow Yann Droneaud
[not found] ` <a83e37e225cd16e5a556b35dcadc7a1234519c2a.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org>
2013-10-14 11:01 ` Or Gerlitz
[not found] ` <525BCF21.3090706-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
2013-10-14 12:22 ` Yann Droneaud
2013-10-14 15:13 ` Matan Barak
2013-10-11 17:18 ` [PATCH 3/9] IB/core: Don't include command header " Yann Droneaud
[not found] ` <ca92c22d0aea21d559d57e6152cb313729a11274.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org>
2013-10-14 15:21 ` Matan Barak
[not found] ` <525C0BF2.2060201-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
2013-10-14 15:46 ` Yann Droneaud
[not found] ` <72b95284386dc57dfa1c7c883b4f45af-zgzEX58YAwA@public.gmane.org>
2013-10-14 18:19 ` Roland Dreier
[not found] ` <CAL1RGDWarJPu_6u5oaL6NgZZJXBuB09vTi9xhxHALfiY_W9Sgg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2013-10-15 14:08 ` Yann Droneaud
[not found] ` <122f1a29d6fe45449a6a153a3a9ba8b1-zgzEX58YAwA@public.gmane.org>
2013-10-15 16:44 ` Roland Dreier
[not found] ` <CAL1RGDXP3+X=go4GiW_SsvSvC_VS-B7uacJN0u5wVtU3NWfvQA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2013-10-15 17:07 ` Yann Droneaud
2013-10-15 21:34 ` Or Gerlitz
[not found] ` <CAJZOPZLr41MGb7qPHcFVQxNcwwAB8i4vnGQhEcu0oZ-BOiMBcg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2013-10-16 0:04 ` Roland Dreier
[not found] ` <CAL1RGDW7KwSOmmsRxDokUHR-Mh1OzaQvDege5Rq7JsSU8AgEHQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2013-10-17 9:19 ` Or Gerlitz
[not found] ` <525FABA2.6000507-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
2013-10-17 15:29 ` Yann Droneaud
[not found] ` <80c62f070af55a176923315b3fbb7b0d-zgzEX58YAwA@public.gmane.org>
2013-10-21 16:46 ` Roland Dreier
2013-10-11 17:18 ` [PATCH 4/9] IB/core: Rename 'flow' structs to match other uverbs structs Yann Droneaud
2013-10-11 17:18 ` [PATCH 5/9] IB/core: Makes uverbs flow structure using names more similar to verbs ones Yann Droneaud
2013-10-11 17:18 ` [PATCH 6/9] IB/core: Uses a common header for uverbs flow_specs Yann Droneaud
2013-10-11 17:18 ` [PATCH 7/9] IB/core: Remove ib_uverbs_flow_spec structure from userspace Yann Droneaud
[not found] ` <f8673f302536d503cdeef005a67f4531706ae578.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org>
2013-10-14 15:26 ` Matan Barak
2013-10-11 17:18 ` [PATCH 8/9] IB/core: extended command: an improved infrastructure for uverbs commands Yann Droneaud
[not found] ` <0b84e20b204eb0fc67db9ca9106d6bf753a12ae3.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org>
2013-10-14 15:38 ` Matan Barak
[not found] ` <525C0FF2.5040905-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
2013-10-17 14:41 ` Matan Barak
[not found] ` <525FF724.5050601-VPRAkNaXOzVWk0Htik3J/w@public.gmane.org>
2013-10-17 15:05 ` Yann Droneaud
[not found] ` <f45595bcb4399ea2cb81d99a914dd9a0-zgzEX58YAwA@public.gmane.org>
2013-10-24 0:34 ` Or Gerlitz
2013-10-11 17:18 ` [PATCH 9/9] IB/core: extended command: move comp_mask to the extended header Yann Droneaud
[not found] ` <40175eda10d670d098204da6aa4c327a0171ae5f.1381510045.git.ydroneaud-RlY5vtjFyJ3QT0dZR+AlfA@public.gmane.org>
2013-10-14 15:44 ` Matan Barak
2013-10-14 15:36 ` [PATCH 0/9] IB/core: batch of fix against create/destroy_flow uverbs for v3.12 Or Gerlitz
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox