Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1422660AbXAESQ7 (ORCPT ); Fri, 5 Jan 2007 13:16:59 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1422659AbXAESQ7 (ORCPT ); Fri, 5 Jan 2007 13:16:59 -0500 Received: from stargate.chelsio.com ([12.22.49.110]:27181 "EHLO stargate.chelsio.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1422651AbXAESQ6 convert rfc822-to-8bit (ORCPT ); Fri, 5 Jan 2007 13:16:58 -0500 X-Greylist: delayed 2610 seconds by postgrey-1.27 at vger.kernel.org; Fri, 05 Jan 2007 13:16:58 EST X-MimeOLE: Produced By Microsoft Exchange V6.5 Content-class: urn:content-classes:message MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 8BIT Subject: RE: [openib-general] [PATCH v4 01/13] Linux RDMA Core Changes Date: Fri, 5 Jan 2007 09:32:19 -0800 Message-ID: <8A71B368A89016469F72CD08050AD334F3BE50@maui.asicdesigners.com> X-MS-Has-Attach: X-MS-TNEF-Correlator: Thread-Topic: [openib-general] [PATCH v4 01/13] Linux RDMA Core Changes Thread-Index: Accw1SsiEqvnR96ZSkOdmcOVDF0AiQAGYbZA From: "Felix Marti" To: "Steve Wise" , "Roland Dreier" Cc: , , Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3171 Lines: 89 > -----Original Message----- > From: openib-general-bounces@openib.org [mailto:openib-general- > bounces@openib.org] On Behalf Of Steve Wise > Sent: Friday, January 05, 2007 6:22 AM > To: Roland Dreier > Cc: linux-kernel@vger.kernel.org; openib-general@openib.org; > netdev@vger.kernel.org > Subject: Re: [openib-general] [PATCH v4 01/13] Linux RDMA Core Changes > > On Thu, 2007-01-04 at 13:34 -0800, Roland Dreier wrote: > > OK, I'm back from vacation today. > > > > Anyway I don't have a definitive statement on this right now. I guess > > I agree that I don't like having an extra parameter to a function that > > should be pretty fast (although req notify isn't quite as hot as > > something like posting a send request or polling a cq), given that it > > adds measurable overhead. (And I am surprised that the overhead is > > measurable, since 3 arguments still fit in registers, but OK). > > > > I also agree that adding an extra entry point just to pass in the user > > data is ugly, and also racy. > > > > Giving the kernel driver a pointer it can read seems OK I guess, > > although it's a little ugly to have a backdoor channel like that. > > > > Another alternative is for the cq-index u32 memory to be allocated by > the kernel and mapped into the user process. So the lib can read/write > it, and the kernel can read it directly. This is the fastest way > perfwise, but I didn't want to do it because of the page granularity of > mapping. IE it would require a page of address space (and backing > memory I guess) just for 1 u32. The CQ element array memory is already > allocated this way (and its DMA coherent too), but I didn't want to > overload that memory with this extra variable either. Mapping just > seemed ugly and wasteful to me. > > So given 3 approaches: > > 1) allow user data to be passed into ib_req_notify_cq() via the standard > uverbs mechanisms. > > 2) hide this in the chelsio driver and have the driver copyin the info > directly. > > 3) allocate the memory for this in the kernel and map it to the user > process. > > I chose 1 because it seemed the cleanest from an architecture point of > view and I didn't think it would impact performance much. [Felix Marti] In addition, is arming the CQ really in the performance path? - Don't apps poll the CQ as long as there are pending CQEs and only arm the CQ for notification once there is nothing left to do? If this is the case, it would mean that we waste a few cycles 'idle' cycles. Steve, next to the micro benchmark that you did, did you run any performance benchmark that actually moves traffic? If so, did you see a difference in performance? > > > Steve. > > > > > > _______________________________________________ > openib-general mailing list > openib-general@openib.org > http://openib.org/mailman/listinfo/openib-general > > To unsubscribe, please visit http://openib.org/mailman/listinfo/openib-general - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/