On Wed, May 18, 2011 at 05:30:30PM +0000, Hefty, Sean wrote: > > As long as the version number in the ibv_context is increasing and not > > branching then I think it is OK. 0 = what we have now. 1 = + XRC, 2 = > > +XRC+ummunotify, etc. Drivers 0 out the function pointers they do not > > support. > > I was thinking more along this line, but I can see how using a named > extension could be useful for OFED or vendor specific extensions that aren't > part of the upstream libibverbs. (Whether _that_ is useful is another > matter, but it seems to be the world that we're in anyway.) > > I'm not familiar with OpenGL, so I'll take a look at it. (The concept sounds > similar to Window's COM interfaces.) > > Beyond the interfaces, are there any thoughts on how to handle structure > changes, such as: > > struct ibv_xrc_send_wr { > struct ibv_send_wr wr; > uint32_t remote_qpn; > }; > > ? Do we want to use the existing ibv_post_send() call, or add a new > ibv_post_xrc_send() routine specifically for this purpose (and > simplify the above definition)?
I prefer to see type safety, so ibv_post_xrc_send is my vote. Just looking at this, I think it can be stuffed into the existing wr.. union { struct { uint64_t remote_addr; uint32_t rkey; } rdma; struct { uint64_t remote_addr; uint64_t compare_add; uint64_t swap; uint32_t rkey; } atomic; struct { struct ibv_ah *ah; uint32_t remote_qpn; uint32_t remote_qkey; } ud; } wr; (ignoring 32 bit for now) This union must start 64 bit aligned. The size is 3*64 + 1*32 so there is a 32 bit pad, thus we can rewrite it as: union { struct { uint64_t remote_addr; uint32_t rkey; uint32_t xrc_remote_qpn; } rdma; struct { uint64_t remote_addr; uint64_t compare_add; uint64_t swap; uint32_t rkey; uint32_t xrc_remote_qpn; } atomic; struct { struct ibv_ah *ah; uint32_t remote_qpn; uint32_t remote_qkey; } ud; } wr; Without changing the size at all. 32 bit users will grow, but that is still ABI acceptable because the pass into ibverbs uses a linked list structure that clearly identifies the start of each wr. So long as the extended stuff is not touched if the WR is not related to XRC things will be OK. Jason -- To unsubscribe from this list: send the line "unsubscribe linux-rdma" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html