From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from dpdk.org (dpdk.org [92.243.14.124]) by inbox.dpdk.org (Postfix) with ESMTP id 9D45EA053A; Tue, 4 Aug 2020 19:18:33 +0200 (CEST) Received: from [92.243.14.124] (localhost [127.0.0.1]) by dpdk.org (Postfix) with ESMTP id 9573729D2; Tue, 4 Aug 2020 19:18:32 +0200 (CEST) Received: from mail-io1-f65.google.com (mail-io1-f65.google.com [209.85.166.65]) by dpdk.org (Postfix) with ESMTP id 3A713255 for ; Tue, 4 Aug 2020 19:18:31 +0200 (CEST) Received: by mail-io1-f65.google.com with SMTP id v6so27757622iow.11 for ; Tue, 04 Aug 2020 10:18:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=SmJm1XoK7LrqO+c9N5ikJMIaFOQYZ1e1MuocWgI/IWc=; b=a3RWhuArBarQK3mOqMtMqaqjvhEzzpDgTxjK5p8Huq0CBqpvepppW4smIuRX9W9+5t +w4VEdhHE2nDzvgh+6GkUZcSWJd7OF3morB1FiZGw3l1n+TEm2DgedVvlfwV5ytVt4Hk u+4r8Y0GXBF/P0FSgDZQz7+STpYa1strp65l/JLA/7C+gmLDxqFEYxWj8Kd/Xurx0jy6 glUY2ka1zgP3QXSbP3U+wbBrJefarK98JLNtrYmAj2Te5RztlJGMXaN0D7BOJ9vI6POP Cf86CSWNrQXDH1aFjFQ2Y44QYO9+6mLnHULoUbbXP3ABu6WQnim8eiEb9ldJt8/BOUU4 VClA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=SmJm1XoK7LrqO+c9N5ikJMIaFOQYZ1e1MuocWgI/IWc=; b=hMgzgWvFWY7CDKeTBIF+13RoPsog4kLJluY/jeRGK5v8d6OIgTfN1+DSojvJhsPVph pc6ZiiLy7XgKI0Nztbd5Ob89r1vMHdRt/jdzF8LZcwY0Q38oLMjoy1Svag3wj27jZ4RE fNOuxyYpt0d6rxWTfUx7A2tW0OWsmvlmtp3+NpV38gGp/U5B15Ek6MKQ/4PzWzPk59ok JVmeH+qwPzfFAZ6MqKWkFvPNopfkW0QZh1/xB21vEl0+IXCYus+cW6wJmIJ/pY80z3BM hyiy/ZVgZbRnjOJAM6A/1/7HrTdg1P5K+tBNgQhPf17ZgHlZsasouINI853auKFcFyFF fQbQ== X-Gm-Message-State: AOAM532PaKihJP5MlZ7973MbUns3bwVp7Z2qb+eDcCDeABkmjfZWGh0w 3HvX3f76l1QHwkuwLeHJKMXFYCBjVO+PuLiUMoQ= X-Google-Smtp-Source: ABdhPJyI+yAXsD1feUSfSv8bwEMY3XSZUiaY9Ae2ZC5m9eePlfcTrZq4Xw/Wy3XxSlYrQ4fO8tS/ggCGrjaYRUzVJT4= X-Received: by 2002:a05:6638:1313:: with SMTP id r19mr6931069jad.60.1596561508955; Tue, 04 Aug 2020 10:18:28 -0700 (PDT) MIME-Version: 1.0 References: <20200802105137.1666-1-pbhagavatula@marvell.com> <20200803072903.1209-1-pbhagavatula@marvell.com> <20200804104153.GA1464@bricha3-MOBL.ger.corp.intel.com> <20200804142451.GA1704@bricha3-MOBL.ger.corp.intel.com> <20200804162410.GD1704@bricha3-MOBL.ger.corp.intel.com> In-Reply-To: <20200804162410.GD1704@bricha3-MOBL.ger.corp.intel.com> From: Jerin Jacob Date: Tue, 4 Aug 2020 22:48:12 +0530 Message-ID: To: Bruce Richardson Cc: Pavan Nikhilesh , Jerin Jacob , Ray Kinsella , Neil Horman , John McNamara , Marko Kovacevic , dpdk-dev , Thomas Monjalon , David Marchand Content-Type: text/plain; charset="UTF-8" Subject: Re: [dpdk-dev] [PATCH v2] doc: add reserve fields to eventdev public structures 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: , Errors-To: dev-bounces@dpdk.org Sender: "dev" On Tue, Aug 4, 2020 at 9:54 PM Bruce Richardson wrote: > > On Tue, Aug 04, 2020 at 09:33:14PM +0530, Jerin Jacob wrote: > > On Tue, Aug 4, 2020 at 7:55 PM Bruce Richardson > > wrote: > > > > > > On Tue, Aug 04, 2020 at 05:07:12PM +0530, Jerin Jacob wrote: > > > > On Tue, Aug 4, 2020 at 4:12 PM Bruce Richardson > > > > wrote: > > > > > > > > > > On Mon, Aug 03, 2020 at 12:59:03PM +0530, pbhagavatula@marvell.com wrote: > > > > > > From: Pavan Nikhilesh > > > > > > > > > > > > Add 64 byte padding at the end of event device public structure to allow > > > > > > future extensions. > > > > > > > > > > > > Signed-off-by: Pavan Nikhilesh > > > > > > Acked-by: Jerin Jacob > > > > > > --- > > > > > > v2 Changes: > > > > > > - Modify commit title. > > > > > > - Add patch reference to doc. > > > > > > > > > > > > doc/guides/rel_notes/deprecation.rst | 11 +++++++++++ > > > > > > 1 file changed, 11 insertions(+) > > > > > > > > > > > > diff --git a/doc/guides/rel_notes/deprecation.rst b/doc/guides/rel_notes/deprecation.rst > > > > > > index ea4cfa7a4..ec5db68e9 100644 > > > > > > --- a/doc/guides/rel_notes/deprecation.rst > > > > > > +++ b/doc/guides/rel_notes/deprecation.rst > > > > > > @@ -151,3 +151,14 @@ Deprecation Notices > > > > > > Python 2 support will be completely removed in 20.11. > > > > > > In 20.08, explicit deprecation warnings will be displayed when running > > > > > > scripts with Python 2. > > > > > > + > > > > > > +* eventdev: A 64 byte padding is added at the end of the following structures > > > > > > + in event device library to support future extensions: > > > > > > + ``rte_event_crypto_adapter_conf``, ``rte_event_eth_rx_adapter_conf``, > > > > > > + ``rte_event_eth_rx_adapter_queue_conf``, ``rte_event_eth_tx_adapter_conf``, > > > > > > + ``rte_event_timer_adapter_conf``, ``rte_event_timer_adapter_info``, > > > > > > + ``rte_event_dev_info``, ``rte_event_dev_config``, ``rte_event_queue_conf``, > > > > > > + ``rte_event_port_conf``, ``rte_event_timer_adapter``, > > > > > > + ``rte_event_timer_adapter_data``. > > > > > > + Reference: > > > > > > + http://patches.dpdk.org/project/dpdk/list/?series=10728&archive=both&state=* > > > > > > -- > > > > > > > > > > I don't like this idea of adding lots of padding to the ends of these > > > > > structures. For some structures, such as the public arrays for devices it > > > > > may be necessary, but for all the conf structures passed as parameters to > > > > > functions I think we can do better. Since these structures are passed by > > > > > the user to various functions, function versioning can be used to ensure > > > > > that the correct function in eventdev is always called. From there to the > > > > > individual PMDs, we can implement ABI compatibility by either: > > > > > 1. including the length of the struct as a parameter to the driver. (This is > > > > > a bit similar to my proposal for rawdev [1]) > > > > > 2. including the ABI version as a parameter to the driver. > > > > > > > > But, Will the above solution work if the application is dependent on > > > > struct size? > > > > i.e change of s1 size will change offset of s3 i.e > > > > app_sepecific_struct_s3. Right? > > > > i.e DPDK version should not change the offset of s3. Right? > > > > > > > > example, > > > > struct app_struct { > > > > struct dpdk_public_struct_s1 s1; > > > > struct dpdk_public_struct_s2 s2; > > > > struct app_sepecific_struct_s3 s3; > > > > } > > > > > > > Not sure what exactly you mean here. The actual offsets and sizes of the > > > structs will obviously change as you change the struct, but the end > > > compiled app has no idea of structs, all it knows of is offsets, which is > > > why you provide ABI compatible versions of the functions which use "legacy" > > > copies of the structs to ensure correct offsets. It's pretty much standard > > > practice for ABI versioning. > > > > Currently, We have only function versioning(not structure versioning). > > Are you suggesting having structure versioning? > > Will it complicate the code in terms of readability and supporting multiple > > structure versions aginst its support functions. > > > > We don't, and can't version structures, only functions are versioned. > Even if we do what you suggest and add a block of 64-bytes expansion room > at the end of the structures, how is the function you are calling expected > to know what the structure actually contains? For example, if you add a > field to the end, and reduce the padding by 8 bytes, your structure is > still the same size, and how does the called function know whether X or X+8 > bytes are valid in it. Basically, you still need to version all > functions using the structure, just as if you didn't bother extending the > struct. Yes. We need function versioning for sure if we change the behavior of the function. Is function version + reserved field enough to decode the correct value from the reserved filed from the structure. My concern is, Let say, we are making the change in structure a->b and function c->d assisted with it. In the reserved filed case: - struct a remains same(we will adding the fields in reserved filed) - the function will have c and d version and both using struct a In another scheme: - The application needs to change where versioned function(c or d) need to give associate structure manually. Right? If it is manually, it will be huge change in application. Right? How an application can express the correct structure mapping? Will it it be like rte_substrem_v21(struct rte_subsystem_conf_v21 *config)? vs rte_substrem_v21(struct rte_subsystem_conf *config)? where rte_subsystem_conf has reserved filed. > > > > > > > The real complication arises because the actual eventdev driver functions > > > are not called directly with the linker resolving symbol versioning. > > > Instead they are called using function pointers from the code. This is why > > > one needs to add in the additional parameter to the driver APIs so that the > > > ABI info - be it struct size or version - can be passed from the versioned > > > eventdev library function through to the driver. > > > > If I understand it correctly, it is easy for rawdev subsystem as > > config structure as _opaque_. > > But in the case for ethdev, cryptodev, eventdev, config structure are > > not opaque. > > > > Well, actually it's more complicated for rawdev because the structures are > opaque, so the value passed could be anything. With eventdev, they will > ever only be one or two possible values, so you just need enough info to > distinguish if it's the structure from version X, or the structure from > version Y you are passing. > > > If we take structure versioning, Is n't call for adding structure > > version change to > > functions that's been associated with(Kind of M x N case to make a > > structure change. Here M means > > offending structure to make change and N means function associated > > with structure) > > > Yes, to version any structure you basically do a new version of every > function using it, or using the changed fields. However, adding padding is > not going to remove that need. See above. > > Regards, > /Bruce