> Are PDs, QPs and CQs created before a fork shared by the parent and child > after fork() has returned (ie. both can submit WRs, poll CQ, etc.)?
no, QPs and CQs are accessible only in the parent. The child can still use the uverbs file descriptor to do things, but libibverbs will probably get very confused in this case. More userspace development would probably be required to make this really work. Since the PD is attached to the FD, it could be shared. > What about MRs registered before the fork? Even though the child doesn't > have access to the parent's memory, can he sill submit WRs on a QP with an > MR created before the fork? yes. > What if the MR pages in the above scenario are accessible in both parent and > child (shared memory)? Are there complications with registering shared > memory? shouldn't make a difference. > In general, are pointers returned by libibverbs pointer to user/process > address space (as ibv_mr pointers must be) or kernel space (eg. if an > unrelated process had another process's QP pointer, lkey, and a virtual > address could it post (almost certainly unsafely) a WR to the other > process's QP? Not sure I understand this. All the pointers from libibverbs are of course userspace pointers. What could a userspace process do with a kernel pointer? Processes own all their resources and can't access other resources. - R. -- Roland Dreier <rola...@cisco.com> || For corporate legal information go to: http://www.cisco.com/web/about/doing_business/legal/cri/index.html -- 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