From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from NAM03-BY2-obe.outbound.protection.outlook.com (mail-by2nam03on0068.outbound.protection.outlook.com [104.47.42.68]) by dpdk.org (Postfix) with ESMTP id A71C511D4 for ; Mon, 13 Feb 2017 12:21:41 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=CAVIUMNETWORKS.onmicrosoft.com; s=selector1-cavium-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=Fxv3irtiHAPWjO72tDb7LVGB26o345Bvqmat5g8+pBU=; b=l3U8ZdUxKrzK6HW7jyf++uyKr36M9jVjE/yUsAEHWyKpRv2OeQRhHmfkXZWMq52ZSoYA2pDAjSTQ3qR7h5sYLquKiFHBazd8Bl0/emt9XDe77NbxfK6gAxH8M9r+qylI/Vt2k24fpFJiNyjDsBDXjK5dWJxbS1wDopdKacvePJU= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=Jerin.Jacob@cavium.com; Received: from localhost.localdomain (122.167.151.246) by BN3PR0701MB1720.namprd07.prod.outlook.com (10.163.39.19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P384) id 15.1.888.16; Mon, 13 Feb 2017 11:21:35 +0000 Date: Mon, 13 Feb 2017 16:51:22 +0530 From: Jerin Jacob To: Bruce Richardson Cc: "Van Haaren, Harry" , "dev@dpdk.org" , "Hunt, David" , "nipun.gupta@nxp.com" , "hemant.agrawal@nxp.com" , "Eads, Gage" Message-ID: <20170213112120.GB26613@localhost.localdomain> 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> <20170213104526.GC377356@bricha3-MOBL3.ger.corp.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20170213104526.GC377356@bricha3-MOBL3.ger.corp.intel.com> User-Agent: Mutt/1.7.1 (2016-10-04) X-Originating-IP: [122.167.151.246] X-ClientProxiedBy: PN1PR01CA0090.INDPRD01.PROD.OUTLOOK.COM (10.174.144.158) To BN3PR0701MB1720.namprd07.prod.outlook.com (10.163.39.19) X-MS-Office365-Filtering-Correlation-Id: 5b9bbcef-0f65-452d-3890-08d454027a3a X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(22001); SRVR:BN3PR0701MB1720; X-Microsoft-Exchange-Diagnostics: 1; BN3PR0701MB1720; 3:Z6zsOW2wjspbiBIuMXqdCkQqEC0nSiuKB++VaoHmvnzSJlCZB4jzjZiT2caxvp8N/bMQMbDpvuxA1D09Fmu7uPZDBkTB/im2v1UBhLZ90dpWIkPcm0yQzerf/6uY5fcQIJd3ermA/005NwBeBRlJlpfVXaSkzASdCYy2lEYJwnL/cRKocTXEaTOwlJxNYa4wIhoHvqMHTwGsQ4iZU11C0JF65mZ2aHVZYNqgGII9nxbibD3lYTbUk56gb8wW5zulHjnP9fjyhMVjqdfCToczeQ==; 25:zwneVQOqhBRAuyuNRS1iSg1/ILnaln2TnSknbtxLrjPjnDsTzn27A/X3mb89hEAst4UzhCYq1k+AkDfxYqlpAzf+bxir/v+i/LMpqwi738FNVJI6TsIdXZkjdSDhwyIlPOXaVy5T7Rgdr7YlxqrOGFIQ2aRQwILN7wZMrqfxUcelkXvYY4k37e1kBlFK0B+XMKY9TfQIFqdyqHfvi7P3bRX/pmNv6lYvO8WEj/bI0F7F5ymUlmxfhGUJRyFXY2gFrw30+Oi+ruz1o23PcHyGJd3NaeY07n/bjuyzs7Wib52tY676aLSZ6Ym6EOupJKiP0qcnzuGKLaH6ThQ8xKTi3Dn51CDn29bJnwZQI/B8S5JKDPPdGQZZnUMxdO/ZV79g0JrSBwrWfAkhoqRfEomeuofzj7fFjHM/4DahM+OdId6ZP6spQw5r6IwP/Zi9yjOX2zzD3HqkEjtZJbHXXtCm+g== X-Microsoft-Exchange-Diagnostics: 1; BN3PR0701MB1720; 31:Ir6Ch7AqBAqFvumOCtQf9yyaIFQRWZ3+/t72xsjQwqc9DsFoCyx8MKwJWFyMoMlgbzgIJgBHd6/E2JfUZHLUfrnq7ayameNqd3Bx0O7EwQURSIKuXKhHsq8zrNKmO6ojcP52E11+J2PWdcq9J9n5TVX+nkCdGUKnD1Omg0kNlwJ6Kc2ZysnzYzTO9kahStKxy7KIoPV9SV9yFB/sdN2lPrhDkMtDLMTEAvyOY+jwElqePbSE0m9fewZez7z8IwioCnZvm5ykDJnWA+wNYFPEcg==; 20:PPzcdSfCIcRnbY/90Nea8NN8rQXIYZweZ4FcXLMxxOK6Ee35+aeu7DyrUwG+kJHD6HSZBv8zjXLP6FNoVr6jr3SqJtibPT1vkg9mQ2gJVaqJeExg4Zdudp3zHc6L6JRYrbgVrPz73OIQRjhhIRH2LaUQMNJWuHCPh3fRYOh+SAuHHBZ7v+RJ0LIqayYYejZH3yeEtLUxO5dJbBCc+5fPwRBL9YzrjA5w5Ih2oUPyFC+0zk1YOghc9qZeBgDHxkBzaMjuvsqgkqAQFOVZFPU1KgsXFfRRdLh5WCiOub7a6karfvyyvLzrDoZlSs+rYOoodvaQgrU1v3PWCHjnxFh/8GzELBOEcCVejAUBeGMXk13WlfSrQrNO+5alDV/bdOnVZrOWA048dGJH74Z4bdMF1JRFPX2SIm7ZvdJYbDojIZr2nLgGUfkPAgv0/tOmy9nEvgV4DzDh46yUYM9APNxritlA3p7l/owuBdx4qPgS1cqyvvuB52KJnEBS4PdM9zMQiPta5b/i9UzyVKl8iC0iKDFNUSu1LwgPFYcIWvMC2z1ZNdbNXDVAO4FSU/zwGwdqkCssVyw28yJ1JpwcBpCeZFvDUsIkYZZC8ESU1E7aJVs= X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(185117386973197)(100405760836317)(155532106045638)(228905959029699); X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(6040375)(601004)(2401047)(8121501046)(5005006)(3002001)(10201501046)(6041248)(20161123555025)(20161123558025)(20161123564025)(20161123562025)(20161123560025)(6072148); SRVR:BN3PR0701MB1720; BCL:0; PCL:0; RULEID:; SRVR:BN3PR0701MB1720; X-Microsoft-Exchange-Diagnostics: 1; BN3PR0701MB1720; 4:5WUYV/ODz2LXwsMX1JhV6USRlbdge1FROLnZOhsTLuSUBiqSa/+J5n7R5Qsq0QxrjWcUlb4y/MxuuYzPE27j4tG1Y92b6izvoMzw5ENnpl4RGUsegzVenoqxna5x0lvt64AUTm2pDMUTponBYBrp8tOTPFYfS6ZiREouNq3Pui22P2sqV1o4uwnXuGwv59msyPQhmO0BO5hzw4N57q1hG3VUZpAWspoaFYcX244JE84GzPaKwcqVoTOFL+nY125O52m8mPIIb6d9Q+76f7Pt7d2GQ9ZUkCuaTwlhZ9dn/jirTnO57S4a9Sp491yUxntqyO3TbdvETT6Y908Vh0ez0YAWe87zBrhn9O5/tvgrsXB7O3kfO5dfyC20MIlNvolIXrHOrCgKEJndLr3baJeelrdtjQj6fnD8Jc0vL4xq9mddsKoAci5KH9XIxeVWr7Np29G4VHkh7cZbt1gux0IWSnpZFHqLRGv6CtB2QBT9dd+QL44hE5jgwKQq8UuK1Ax5NkOkqYstrY5S1Kc3HpyB1rGjalplRNlITvZ2Hs7NEY66eEgPMoY+cPjfM/RJQpAu8cYJ+aeA4JdrAiJ6kbsyOF+9/8Emv0sH6yNRV+seVihCLYCcHfI78aezUcaix24eCqtCCz7wne9e41hRRLne6SkVSFlBceON5Nldu3QYPnQrJCsA3EZoogKBPDAP/MIscwaNHPPwA80N2toPSb4cHW7ZAyBhKmXHb+ADCyfIeJ0LGaIYsFV/1FhSkVhvG20s X-Forefront-PRVS: 02176E2458 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10009020)(4630300001)(6069001)(6009001)(7916002)(39450400003)(13464003)(24454002)(76104003)(377454003)(189002)(199003)(53376002)(97736004)(189998001)(4001350100001)(101416001)(54356999)(50986999)(76176999)(66066001)(47776003)(42186005)(105586002)(106356001)(8676002)(6246003)(93886004)(33656002)(81166006)(81156014)(50466002)(5660300001)(68736007)(9686003)(61506002)(8656002)(4326007)(6306002)(54906002)(55016002)(6916009)(229853002)(6666003)(7736002)(2950100002)(92566002)(42882006)(966004)(38730400002)(110136004)(25786008)(83506001)(6506006)(2906002)(53936002)(305945005)(3846002)(1076002)(6116002)(23726003)(7099028)(18370500001); DIR:OUT; SFP:1101; SCL:1; SRVR:BN3PR0701MB1720; H:localhost.localdomain; FPR:; SPF:None; PTR:InfoNoRecords; MX:1; A:1; LANG:en; Received-SPF: None (protection.outlook.com: cavium.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; BN3PR0701MB1720; 23:aNYd2l6+C7lFhQFxwQvc3+Wi/5JvuIOE6RDzAx0?= =?us-ascii?Q?qAky5KU0JwbLVAmUpKB+I1kPmCXpna2M44d9c8Dd1jOYDIT8N+D48UDvm8Gn?= =?us-ascii?Q?9KRWm9PgMWEWNFWn7KgoS3U1sy1Nm+fHbFfYcqA/CSPrD6AigFyTduFpHOyp?= =?us-ascii?Q?/RHcVJbJwvL+qDLDpGN8SDuqKj05mwxIEnnmgGNPbSFOKmKBa42Orup9Fcgf?= =?us-ascii?Q?6ID+zRoE+oEzpW7bKQk6ULNqOYiOWI077zIQvhsAKyl+8q7lM0lzIbaD+sy7?= =?us-ascii?Q?I7N10Bt+SSiojOHiIPHO6kw9OrvacmazS9kXoWbcdkhMqu58WnMmcQZVoNjA?= =?us-ascii?Q?xJTliHhv5ceTI6Pro+FTj2nFGseKc1Gk/ZPCFeNShyhFi5YF5eQZYl/RtXNq?= =?us-ascii?Q?jjtD7PV76nZeQ3py/ab3DF2pJ5gzgaoU513rAUW80uLvxJbcVburtNWr8pwA?= =?us-ascii?Q?8bMMuPetUWjfXVpolOju7pW1ZDUIw852COc917a/z5wWWyMKoWc+KC4jw4/t?= =?us-ascii?Q?EJ1C6g7ZC54ObRY0N0GFC0tWa7O8BjjVUOJG/t1qEZjTo0Zgge615pumYbT8?= =?us-ascii?Q?OtRa1cm1ODGaFLyd3pwWuSFrwZbxAaneRUHXSgHaZUzF7GaRlxy8ZfNSkUpW?= =?us-ascii?Q?c4VD43ftaX4wGyqEuVH87740ECXFRJAJF6Dv2c6IstMIPLeRSGZGD1DTPgiY?= =?us-ascii?Q?10rzUs2WGZoBPRC3ycSt4JDR37Dt8tq6jWcbBtBn4soFnOEIwrmfG+NQNgzN?= =?us-ascii?Q?Rh1UIyOVPM/+oET292HWA6gn3vjfIomxqkAb8pQsKmr0f9isHwHQiUPhuttz?= =?us-ascii?Q?ds4jZ4i/Mf9OUPY/XhDikivUwkDXIAymhOnVk8RERROl5el8k5VGeneRUAQu?= =?us-ascii?Q?reyqWX/zTSZ7+zzgy9zFs0S+3MInjlTHNja/Rkw2cqh7hUbohESkaL51CjYw?= =?us-ascii?Q?bqc4sPGPmBnfWNykEHInWcV1Fvrljw7z140kRGVnoIlPoo6U+Jtf4gckY5xd?= =?us-ascii?Q?My99w19v56TrCu1Av6BKtZIalj2wJl38oOIaeJSxoRmlFtgClWjaEi1j++DK?= =?us-ascii?Q?Hy07p4l00KWRB4QrkLA2oLMnI1tgyYBQtzDcVQvj3q9QGQnQsy8vztWKS4Hu?= =?us-ascii?Q?wUSLag7KSqsAh/TwZBFVKGmXCMfnEQ5BNLLNtaL4TWgeXdARgBnq5Hyqq4cW?= =?us-ascii?Q?kgdT+mZZIx9nkM7L48D6SgY+KBQcpZAQyMJUdH8zaOXJdUx1K6DC4Ef/fRcw?= =?us-ascii?Q?lXUkkxHstL/ZvlyY9TCdlX/F2l4cS7zwyFq9HZJOkGcWx7VAtgjBaG8NljIw?= =?us-ascii?Q?cbiSt+OKpKmkF7XLSj0HasZfgdLlrOD7ixaPasdVnXvm7r7SeDLI8s8F7CKW?= =?us-ascii?Q?xv4PhAXnKTlGfJI6rh96xSnq7DO3qeu8gkfVSZwOR+VNJ95rDX6grt5HEK5L?= =?us-ascii?Q?5deKLJVT51NBhmVgXrB9tdggH4rpYNSA=3D?= X-Microsoft-Exchange-Diagnostics: 1; BN3PR0701MB1720; 6:HuNE8vjEioLe1Gs/AMp1LVFrVlJsTB3EJMeOWpc46hm1SrfRR8WGLZPASkhYtLx/xL957jEQDhN0LaBvWxUxFd/k/1zGQlXMJXiIBDSX2J8gtdma3HG44rYVJrDY1Q3IQ9MiLdoQaieTLwqRk6DHR+UsnHTJDKK/oU1Sbbr3A+7jv39b6Y/Dxuyu0DqwvnH03TbztH4Yuxpg5GtRMzViDMzo80anTsicVlhzmxiZ+sBUNwvZt1Qusa3VW/my27eAN1BxqmaXt1tof+SYVUzcpit46zF3zXlTC/oBKge0ur416LT6+M0um4H/KY1nLFLEbua5dlif08tWnUi+vEkgX/+PNy0zcFgUYWjhARSpXgDjn1wRTVFAUZOTlXnSW4OQYtbgw5VbPKZ9o/6Ui5lVSg==; 5:Lu0xuCqOXv7YFB1TFdK2C7/eUMKV6+mBRmOMGWWbLsV/LQJ/w7erOd1sN4x0TafRA4+1zIkLcn8p0gsCMJYiGOyOFml/HciSyRm6/ZFVjG/kGQYKrl324gYlH2lwdRXwtpeRhOKNGtgtX6CsFdFGvA==; 24:VaQCg1l4MWlkAxWCDyG1jVrDyqSQSE6VPh7wyee9THOMGJTOhcx0dLawGSYaQVvivjh2kqfSzQHVzjTI9Vjs6wF4g76NzVej5MT+QO+9Wio= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1; BN3PR0701MB1720; 7:Wd4ZfnwetZJSS/FtO6Spo2uz9sc0AR34VBD7KdxomCp2+Mp3ncnYn+YpcBHCJ6oAZ6ZaW+X8EEgr54wMuByjsmrSLe/9b43xMzOawH0+byBoh4Qn9/VC6VacwdLyodegNYnVE7XzCZqk82LzxJr23aKdHr7SuO5xNx36UtxX/rE8M7H+yX/czNEhUHqlaO9MhsDzn1dMNCJpX45DyytgTafFuQNW2e4QKCZlI1Ut/MrSD5bzscZLvRpxl5tMWEcy1gkccTcG+3TJ3aERD7pbcRub1RrxqCR8Bwy6AdrbmH9nGwMD6A/7gFHOz9MIEegcZXh5RMzsLx2TnZzZZmT3Neo9A/FIws/2yuqSCPUiefoWXePNZPtfRe7vNs21nTFhcCNbJqA1s8H42e+c6obr7L1yfWxLBYoLCWVUColtLF0LiAszOlPV0MUycvZGB+XBQ3Sbwb25Xw9g2IbItFp1vq86ISaQ9txxRJptQlspVI9RjIayTQImyZrKqBfqvLhGLSetE3WGD79x8Lq83xpq6A== X-OriginatorOrg: caviumnetworks.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 13 Feb 2017 11:21:35.3752 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-Transport-CrossTenantHeadersStamped: BN3PR0701MB1720 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 11:21:42 -0000 On Mon, Feb 13, 2017 at 10:45:27AM +0000, Bruce Richardson wrote: > 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). OK. Then we are good. No change is required. One question though, In what basics application choose to the specific mode?(I guess, "Going back to previous" use case also can be done though queue id based scheme). In our case, The sub_event_type based one gives more of "runtime to completion" support a packet does not go through different queues. > > > > > 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. I thought to create mode in configuration stage as mutually exclusive. i.e. If device configured as sub_event_type based pipelining use next_stage as sub_event_type else queue_id. > > /Bruce >