All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Yang, Zhiyong" <zhiyong.yang@intel.com>
To: "Yang, Zhiyong" <zhiyong.yang@intel.com>,
	Thomas Monjalon <thomas@monjalon.net>,
	"Yigit, Ferruh" <ferruh.yigit@intel.com>
Cc: "dev@dpdk.org" <dev@dpdk.org>, Matan Azrad <matan@mellanox.com>,
	"Iremonger, Bernard" <bernard.iremonger@intel.com>,
	"Yao, Lei A" <lei.a.yao@intel.com>,
	"maxime.coquelin@redhat.com" <maxime.coquelin@redhat.com>,
	"Bie, Tiwei" <tiwei.bie@intel.com>,
	"stable@dpdk.org" <stable@dpdk.org>,
	"Van Haaren, Harry" <harry.van.haaren@intel.com>
Subject: Re: [PATCH v2] app/testpmd: fix pmd_test_exit function for vdevs
Date: Wed, 23 May 2018 11:37:10 +0000	[thread overview]
Message-ID: <E182254E98A5DA4EB1E657AC7CB9BD2A8B0D796F@BGSMSX101.gar.corp.intel.com> (raw)
In-Reply-To: <E182254E98A5DA4EB1E657AC7CB9BD2A8B0D739B@BGSMSX101.gar.corp.intel.com>



> -----Original Message-----
> From: dev [mailto:dev-bounces@dpdk.org] On Behalf Of Yang, Zhiyong
> Sent: Wednesday, May 23, 2018 9:52 AM
> To: Thomas Monjalon <thomas@monjalon.net>; Yigit, Ferruh
> <ferruh.yigit@intel.com>
> Cc: dev@dpdk.org; Matan Azrad <matan@mellanox.com>; Iremonger, Bernard
> <bernard.iremonger@intel.com>; Yao, Lei A <lei.a.yao@intel.com>;
> maxime.coquelin@redhat.com; Bie, Tiwei <tiwei.bie@intel.com>;
> stable@dpdk.org; Van Haaren, Harry <harry.van.haaren@intel.com>
> Subject: Re: [dpdk-dev] [PATCH v2] app/testpmd: fix pmd_test_exit function for
> vdevs
> 
> Hi Thomas,
> 
> > -----Original Message-----
> > From: Thomas Monjalon [mailto:thomas@monjalon.net]
> > Sent: Wednesday, May 23, 2018 3:49 AM
> > To: Yigit, Ferruh <ferruh.yigit@intel.com>
> > Cc: Yang, Zhiyong <zhiyong.yang@intel.com>; dev@dpdk.org; Matan Azrad
> > <matan@mellanox.com>; Iremonger, Bernard
> > <bernard.iremonger@intel.com>; Yao, Lei A <lei.a.yao@intel.com>;
> > maxime.coquelin@redhat.com; Bie, Tiwei <tiwei.bie@intel.com>;
> > stable@dpdk.org; Van Haaren, Harry <harry.van.haaren@intel.com>
> > Subject: Re: [dpdk-dev] [PATCH v2] app/testpmd: fix pmd_test_exit
> > function for vdevs
> >
> > 22/05/2018 20:38, Ferruh Yigit:
> > > On 5/22/2018 2:12 PM, Thomas Monjalon wrote:
> > > > Any update to improve this workaround?
> > > >
> > > > 21/05/2018 18:38, Thomas Monjalon:
> > > >> 21/05/2018 18:32, Ferruh Yigit:
> > > >>> On 5/21/2018 11:54 AM, Thomas Monjalon wrote:
> > > >>>> 19/05/2018 16:19, Thomas Monjalon:
> > > >>>>> 18/05/2018 18:29, Ferruh Yigit:
> > > >>>>>> On 5/18/2018 4:55 PM, Matan Azrad wrote:
> > > >>>>>>> Hi all
> > > >>>>>>>
> > > >>>>>>> While this patch also applied I don't understand it.
> > > >>>>>>> Is it mandatory for each PMD to free all its resources in
> dev_close()?
> > > >>>>>>> Or it should be done by the rte_device remove function?
> > > >>>>>>>
> > > >>>>>>> If the resource cleanup should be done by the remove
> > > >>>>>>> function I think it should be called for all the devices (pci, vdev,
> etc).
> > > >>>>>>>
> > > >>>>>>> Is there an exit function for EAL to clean rte_eal_init()?
> > > >>>>>>> If no, looks
> > like we need it...
> > > >>>>>>
> > > >>>>>> Hi Matan,
> > > >>>>>>
> > > >>>>>> I believe there is a gap in resource cleanup.
> > > >>>>>> dev_close() it not for resource cleanup, it should be in PMD
> > > >>>>>> remove() functions, and PMDs have it. The problem is remove
> > > >>>>>> path is
> > not called in application exit.
> > > >>>>>>
> > > >>>>>> As far as I know there is no simple API to clean the
> > > >>>>>> resources, having it may help application to do the cleanup.
> > > >>>>>>
> > > >>>>>> I have seen the rte_eal_cleanup() API by Harry, that can be
> > > >>>>>> extended to cover PMD resource cleanup if there is enough
> > motivation for it.
> > > >>>>>
> > > >>>>> Yes, EAL resources should be removed by the function
> > rte_eal_cleanup().
> > > >>>>> And ethdev ports must be removed by rte_eth_dev_close().
> > > >>>>
> > > >>>> This patch is relying on rte_eth_dev_detach() to remove the EAL
> device.
> > > >>>> It should be done in rte_eal_cleanup().
> > > >>>>
> > > >>>> I am concerned that this patch is workarounding a miss in
> > > >>>> rte_eal_cleanup, and takes a different action only for vdev. It
> > > >>>> is a bad
> > example.
> > > >>>
> > > >>> Indeed it does workaround, but it is needed to fix a defect in virtio-user.
> > > >>
> > > >> The defect is still in virtio-user after this patch.
> > > >> To make this workaround acceptable, you need:
> > > >> 	1/ add the virtio-user known issue in release notes
> 
> I don't think it is a bug for virtio-user. Just no proper implemented API can free
> the virtio-user resources  allocated by probe method.
> Socket file is just one example,  other resources are freed in the remove
> method.  Testpmd was always missing the functionality.
> 
> > > >> 	2/ add a FIXME comment in testpmd code explaining the workaround
> > > >> 	3/ commit to work on rte_eal_cleanup() in 18.08

Do you mean to work on rte_eal_cleanup() for all drivers or for virtio user only?

> > >
> > > I have submitted following patch [1], can it cover 2/ for the v18.05-rc5?
> > >
> > > [1]
> > > https://dpdk.org/dev/patchwork/patch/40350/
> >
> > Yes, it covers item 2/. Thanks
> >
> >
> 
> rte_eal_cleanup() is a proper API,  which is needed to clean up resources.
> 
> Thanks
> Zhiyong

  reply	other threads:[~2018-05-23 11:37 UTC|newest]

Thread overview: 21+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-05-18  9:59 [PATCH v2] app/testpmd: fix pmd_test_exit function for vdevs zhiyong.yang
2018-05-18  4:52 ` Yao, Lei A
2018-05-18 10:18   ` Iremonger, Bernard
2018-05-18 10:21     ` Ferruh Yigit
2018-05-18 10:48     ` Ferruh Yigit
2018-05-18 15:55       ` Matan Azrad
2018-05-18 16:29         ` Ferruh Yigit
2018-05-19 14:19           ` Thomas Monjalon
2018-05-21 10:54             ` Thomas Monjalon
2018-05-21 16:32               ` Ferruh Yigit
2018-05-21 16:38                 ` Thomas Monjalon
2018-05-22 13:12                   ` Thomas Monjalon
2018-05-22 18:38                     ` Ferruh Yigit
2018-05-22 19:48                       ` Thomas Monjalon
2018-05-23  1:52                         ` Yang, Zhiyong
2018-05-23 11:37                           ` Yang, Zhiyong [this message]
2018-05-23 11:58                             ` Thomas Monjalon
2018-05-21 16:37             ` Ferruh Yigit
2018-05-21 16:40               ` Thomas Monjalon
2018-05-21 16:44                 ` Ferruh Yigit
2018-05-21 19:12                   ` Thomas Monjalon

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=E182254E98A5DA4EB1E657AC7CB9BD2A8B0D796F@BGSMSX101.gar.corp.intel.com \
    --to=zhiyong.yang@intel.com \
    --cc=bernard.iremonger@intel.com \
    --cc=dev@dpdk.org \
    --cc=ferruh.yigit@intel.com \
    --cc=harry.van.haaren@intel.com \
    --cc=lei.a.yao@intel.com \
    --cc=matan@mellanox.com \
    --cc=maxime.coquelin@redhat.com \
    --cc=stable@dpdk.org \
    --cc=thomas@monjalon.net \
    --cc=tiwei.bie@intel.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.