From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mga02.intel.com (mga02.intel.com [134.134.136.20]) by dpdk.org (Postfix) with ESMTP id CC58C2A5E for ; Thu, 8 Dec 2016 10:30:54 +0100 (CET) Received: from orsmga002.jf.intel.com ([10.7.209.21]) by orsmga101.jf.intel.com with ESMTP; 08 Dec 2016 01:30:53 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.33,318,1477983600"; d="scan'208";a="15327358" Received: from bricha3-mobl3.ger.corp.intel.com ([10.237.221.64]) by orsmga002.jf.intel.com with SMTP; 08 Dec 2016 01:30:49 -0800 Received: by (sSMTP sendmail emulation); Thu, 08 Dec 2016 09:30:49 +0000 Date: Thu, 8 Dec 2016 09:30:49 +0000 From: Bruce Richardson To: Jerin Jacob Cc: dev@dpdk.org, thomas.monjalon@6wind.com, hemant.agrawal@nxp.com, gage.eads@intel.com, harry.van.haaren@intel.com Message-ID: <20161208093048.GA55440@bricha3-MOBL3.ger.corp.intel.com> References: <1479447902-3700-2-git-send-email-jerin.jacob@caviumnetworks.com> <1480996340-29871-1-git-send-email-jerin.jacob@caviumnetworks.com> <1480996340-29871-2-git-send-email-jerin.jacob@caviumnetworks.com> <20161206165119.GB22224@bricha3-MOBL3.ger.corp.intel.com> <20161207185303.GA7001@svelivela-lt.caveonetworks.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20161207185303.GA7001@svelivela-lt.caveonetworks.com> Organization: Intel Research and =?iso-8859-1?Q?De=ACvel?= =?iso-8859-1?Q?opment?= Ireland Ltd. User-Agent: Mutt/1.7.1 (2016-10-04) Subject: Re: [dpdk-dev] [PATCH v2 1/6] eventdev: introduce event driven programming model X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 08 Dec 2016 09:30:55 -0000 On Thu, Dec 08, 2016 at 12:23:03AM +0530, Jerin Jacob wrote: > On Tue, Dec 06, 2016 at 04:51:19PM +0000, Bruce Richardson wrote: > > On Tue, Dec 06, 2016 at 09:22:15AM +0530, Jerin Jacob wrote: > > > In a polling model, lcores poll ethdev ports and associated > > > rx queues directly to look for packet. In an event driven model, > > > by contrast, lcores call the scheduler that selects packets for > > > them based on programmer-specified criteria. Eventdev library > > > adds support for event driven programming model, which offer > > > applications automatic multicore scaling, dynamic load balancing, > > > pipelining, packet ingress order maintenance and > > > synchronization services to simplify application packet processing. > > > > > > By introducing event driven programming model, DPDK can support > > > both polling and event driven programming models for packet processing, > > > and applications are free to choose whatever model > > > (or combination of the two) that best suits their needs. > > > > > > This patch adds the eventdev specification header file. > > > > > > Signed-off-by: Jerin Jacob > > > --- > > > + /** WORD1 */ > > > + RTE_STD_C11 > > > + union { > > > + uint64_t u64; > > > + /**< Opaque 64-bit value */ > > > + uintptr_t event_ptr; > > > + /**< Opaque event pointer */ > > > > Since we have a uint64_t member of the union, might this be better as a > > void * rather than uintptr_t? > > No strong opinion here. For me, uintptr_t looks clean. > But, It is OK to change to void* as per your input. > > > > > > + struct rte_mbuf *mbuf; > > > + /**< mbuf pointer if dequeued event is associated with mbuf */ > > > + }; > > > +}; > > > + > > > > > +/** > > > + * Link multiple source event queues supplied in *rte_event_queue_link* > > > + * structure as *queue_id* to the destination event port designated by its > > > + * *port_id* on the event device designated by its *dev_id*. > > > + * > > > + * The link establishment shall enable the event port *port_id* from > > > + * receiving events from the specified event queue *queue_id* > > > + * > > > + * An event queue may link to one or more event ports. > > > + * The number of links can be established from an event queue to event port is > > > + * implementation defined. > > > + * > > > + * Event queue(s) to event port link establishment can be changed at runtime > > > + * without re-configuring the device to support scaling and to reduce the > > > + * latency of critical work by establishing the link with more event ports > > > + * at runtime. > > > > I think this might need to be clarified. The device doesn't need to be > > reconfigured, but does it need to be stopped? In SW implementation, this > > affects how much we have to make things thread-safe. At minimum I think > > we should limit this to having only one thread call the function at a > > time, but we may allow enqueue dequeue ops from the data plane to run > > in parallel. > > Cavium implementation can change it at runtime without re-configuring or stopping > the device to support runtime load balancing from the application perspective. > > AFAIK, link establishment is _NOT_ fast path API. But the application > can invoke it from worker thread whenever there is a need for re-wiring > the queue to port connection for better explicit load balancing. IMO, A > software implementation with lock is fine here as we don't use this in > fastpath. > > Thoughts? > > I agree that it's obviously not fast-path. Therefore I suggest that we document that this API should be safe to call while the data path is in operation, but that it should not be called by multiple cores simultaneously i.e. single-writer, multi-reader safe, but not multi-writer safe. Does that seem reasonable to you? /Bruce