From: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
To: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Cc: "Linux Media Mailing List" <linux-media@vger.kernel.org>,
"Mauro Carvalho Chehab" <mchehab@infradead.org>,
"Jaroslav Kysela" <perex@perex.cz>,
"Takashi Iwai" <tiwai@suse.com>,
"Shuah Khan" <shuahkh@osg.samsung.com>,
"Hans Verkuil" <hans.verkuil@cisco.com>,
"Javier Martinez Canillas" <javier@osg.samsung.com>,
"Rafael Lourenço de Lima Chehab" <chehabrafael@gmail.com>,
alsa-devel@alsa-project.org
Subject: Re: [PATCH v2] [media] media-device: use kref for media_device instance
Date: Mon, 21 Mar 2016 08:58:05 -0300 [thread overview]
Message-ID: <20160321085805.5e8c4634@recife.lan> (raw)
In-Reply-To: <3052381.o5ho2okSRi@avalon>
Em Mon, 21 Mar 2016 13:10:33 +0200
Laurent Pinchart <laurent.pinchart@ideasonboard.com> escreveu:
> Hi Mauro,
>
> Thank you for the patch.
>
> On Friday 18 Mar 2016 21:42:16 Mauro Carvalho Chehab wrote:
> > Now that the media_device can be used by multiple drivers,
> > via devres, we need to be sure that it will be dropped only
> > when all drivers stop using it.
>
> I've discussed this with Shuah previously and I'm surprised to see that the
> problem hasn't been fixed : using devres for this purpose is just plain wrong.
I didn't follow your discussions with Shuah. I'm pretty sure I didn't
see any such reply to the /22 patch series.
For sure there are other approaches, although I wouldn't say that this
approach is plain wrong. It was actually suggested by Greg KH at the
USB summit, back in 2011:
https://lkml.org/lkml/2011/8/21/61
It works fine in the cases like the ones Shuah is currently addressing:
USB devices that have multiple interfaces handled by independent drivers.
Going further, right now, as far as I'm aware of, there are only two use
cases for a driver-independent media_device struct in the media subsystem
(on the upstream Kernel):
- USB devices with USB Audio Class: au0828 and em28xx drivers,
plus snd-usb-audio;
- bt878/bt879 PCI devices, where the DVB driver is independent
from the V4L2 one (affects bt87x and bttv drivers).
The devres approach fits well for both use cases.
Ok, there are a plenty of OOT SoC drivers that might benefit of some
other solution, but we should care about them only if/when they got
upstreamed.
> The empty media_device_release_devres() function should have given you a hint.
>
> What we need instead is a list of media devices indexed by struct device (for
> this use case) or by struct device_node (for DT use cases). It will both
> simplify the code and get rid of the devres abuse.
Yeah, Shuah's approach should be changed to a different one, in order to
work for DT use cases. It would be good to have a real DT use case for us
to validate the solution, before we start implementing something in the
wild.
Still, it would very likely need a kref there, in order to destroy the
media controller struct only after all drivers stop using it.
> Shuah, if I recall correctly you worked on implementing such a solution after
> our last discussion on the topic. Could you please update us on the status ?
I saw a Shuah's email proposing to discuss this at the media summit.
> In the mean time, let's hold off on this patch, and merge a proper solution
> instead.
Well, we should send a fix for the current issues for Kernel 4.6.
As the number of drivers that would be using this internal API is small
(right now, only 2 drivers), replacing devres by some other strategy
in the future should be easy.
Regards,
Mauro
next prev parent reply other threads:[~2016-03-21 11:58 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-03-19 0:42 [PATCH v2] [media] media-device: use kref for media_device instance Mauro Carvalho Chehab
2016-03-19 2:32 ` Shuah Khan
2016-03-21 11:10 ` Laurent Pinchart
2016-03-21 11:58 ` Mauro Carvalho Chehab [this message]
2016-03-21 13:52 ` Shuah Khan
2016-03-21 13:42 ` Shuah Khan
2016-03-23 9:15 ` Laurent Pinchart
2016-03-22 20:09 ` Shuah Khan
2016-03-23 16:57 ` Laurent Pinchart
2016-03-23 17:35 ` Mauro Carvalho Chehab
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=20160321085805.5e8c4634@recife.lan \
--to=mchehab@osg.samsung.com \
--cc=alsa-devel@alsa-project.org \
--cc=chehabrafael@gmail.com \
--cc=hans.verkuil@cisco.com \
--cc=javier@osg.samsung.com \
--cc=laurent.pinchart@ideasonboard.com \
--cc=linux-media@vger.kernel.org \
--cc=mchehab@infradead.org \
--cc=perex@perex.cz \
--cc=shuahkh@osg.samsung.com \
--cc=tiwai@suse.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).