From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mga05.intel.com (mga05.intel.com [192.55.52.43]) by dpdk.org (Postfix) with ESMTP id 7EF80282 for ; Mon, 13 Feb 2017 11:45:32 +0100 (CET) Received: from orsmga004.jf.intel.com ([10.7.209.38]) by fmsmga105.fm.intel.com with ESMTP; 13 Feb 2017 02:45:31 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.35,156,1484035200"; d="scan'208";a="58050911" Received: from bricha3-mobl3.ger.corp.intel.com ([10.237.221.61]) by orsmga004.jf.intel.com with SMTP; 13 Feb 2017 02:45:28 -0800 Received: by (sSMTP sendmail emulation); Mon, 13 Feb 2017 10:45:27 +0000 Date: Mon, 13 Feb 2017 10:45:27 +0000 From: Bruce Richardson To: Jerin Jacob Cc: "Van Haaren, Harry" , "dev@dpdk.org" , "Hunt, David" , "nipun.gupta@nxp.com" , "hemant.agrawal@nxp.com" , "Eads, Gage" Message-ID: <20170213104526.GC377356@bricha3-MOBL3.ger.corp.intel.com> References: <1484580885-148524-1-git-send-email-harry.van.haaren@intel.com> <1485879273-86228-1-git-send-email-harry.van.haaren@intel.com> <1485879273-86228-16-git-send-email-harry.van.haaren@intel.com> <20170208102306.GA19597@localhost.localdomain> <20170213102825.GA26613@localhost.localdomain> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20170213102825.GA26613@localhost.localdomain> 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 15/15] app/test: add unit tests for SW eventdev driver 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: Mon, 13 Feb 2017 10:45:33 -0000 On Mon, Feb 13, 2017 at 03:58:27PM +0530, Jerin Jacob wrote: > On Wed, Feb 08, 2017 at 10:44:11AM +0000, Van Haaren, Harry wrote: > > > -----Original Message----- > > > From: Jerin Jacob [mailto:jerin.jacob@caviumnetworks.com] > > > Sent: Wednesday, February 8, 2017 10:23 AM > > > To: Van Haaren, Harry > > > Cc: dev@dpdk.org; Richardson, Bruce ; Hunt, David > > > ; nipun.gupta@nxp.com; hemant.agrawal@nxp.com; Eads, Gage > > > > > > Subject: Re: [PATCH v2 15/15] app/test: add unit tests for SW eventdev driver > > > > > > > > > Thanks for SW driver specific test cases. It provided me a good insight > > > of expected application behavior from SW driver perspective and in turn it created > > > some challenge in portable applications. > > > > > > I would like highlight a main difference between the implementation and get a > > > consensus on how to abstract it? > > > > Thanks for taking the time to detail your thoughts - the examples certainly help to get a better picture of the whole. > > > > > > > > > > - Fairly large number of SA(kind of 2^16 to 2^20) can be processed in parallel > > > Something existing IPSec application has constraints on > > > http://dpdk.org/doc/guides-16.04/sample_app_ug/ipsec_secgw.html > > > > > > on_each_worker_cores() > > > while(1) > > > { > > > rte_event_dequeue_burst(ev,..) > > > if (!nr_events); > > > continue; > > > > > > /* STAGE 1 processing */ > > > if(ev.event_type == RTE_EVENT_TYPE_ETHDEV) { > > > sa = find_it_from_packet(ev.mbuf); > > > /* move to next stage2(ATOMIC) */ > > > ev.event_type = RTE_EVENT_TYPE_CPU; > > > ev.sub_event_type = 2; > > > ev.sched_type = RTE_SCHED_TYPE_ATOMIC; > > > ev.flow_id = sa; > > > ev.op = RTE_EVENT_OP_FORWARD; > > > rte_event_enqueue_burst(ev..); > > > > > > } else if(ev.event_type == RTE_EVENT_TYPE_CPU && ev.sub_event_type == 2) { /* stage 2 */ > > > > > > [HvH] In the case of software eventdev ev.queue_id is used instead of ev.sub_event_type - but this is the same lookup operation as mentioned above. I don't see a fundamental difference between these approaches? > > > Does that mean ev.sub_event_type can not be use for event pipelining. > Right? Looks like NXP HW has similar common behavior. If so, How about > abstracting with union(see below) to have portable application code? No, it can if so desired. It may be useful in cases where the queue ids do not directly correspond to the logical stage number, or perhaps when a packet need to go back to a previous pipeline stage and wants to record past history (e.g. after tunnel decap). > > Application will use "next_stage"(or similar name) to advance the stage, based on the > capability or configured mode(flow and/or queue based) underneath > implementation will move to next stage. > > I will send a patch with above details. What do you think? > > diff --git a/lib/librte_eventdev/rte_eventdev.h > b/lib/librte_eventdev/rte_eventdev.h > index c2f9310..040d70d 100644 > --- a/lib/librte_eventdev/rte_eventdev.h > +++ b/lib/librte_eventdev/rte_eventdev.h > @@ -907,17 +907,13 @@ struct rte_event { > uint64_t event; > /** Event attributes for dequeue or enqueue operation */ > struct { > - uint32_t flow_id:20; > + uint32_t flow_id:28; > /**< Targeted flow identifier for the enqueue and > * dequeue operation. > * The value must be in the range of > * [0, nb_event_queue_flows - 1] which > * previously supplied to > * rte_event_dev_configure(). > */ > - uint32_t sub_event_type:8; > - /**< Sub-event types based on the event source. > - * @see RTE_EVENT_TYPE_CPU > - */ > uint32_t event_type:4; > /**< Event type to classify the event source. > * @see RTE_EVENT_TYPE_ETHDEV, > * (RTE_EVENT_TYPE_*) > @@ -935,13 +931,16 @@ struct rte_event { > * associated with flow id on a given event > * queue > * for the enqueue and dequeue operation. > */ > - uint8_t queue_id; > - /**< Targeted event queue identifier for the enqueue or > - * dequeue operation. > - * The value must be in the range of > - * [0, nb_event_queues - 1] which previously supplied to > - * rte_event_dev_configure(). > - */ > + union { > + uint8_t queue_id; > + /**< Targeted event queue identifier for the enqueue or > + * dequeue operation. > + * The value must be in the range of > + * [0, nb_event_queues - 1] which previously supplied to > + * rte_event_dev_configure(). > + */ > + uint8_t next_stage; > + } > > I'm not sure about this. Wouldn't this break your use-case, since the queue_id and the next_stage have to be the same? I thought you always enqueued to the same queue, just with a different next_stage value. /Bruce