<!-- Some styling for better description lists --><style type='text/css'>dt { font-weight: bold;float: left;display:inline;margin-right: 1em} dd { display:block; margin-left: 2em}</style>

   svarbanov: <u>hverkuil</u>: ping
   hverkuil: <u>svarbanov</u>: pong
   svarbanov: <u>hverkuil</u>: do you have a chance to think more on m2m scheduling issue ?
   <br> <u>hverkuil</u>: IMO v4l2_m2m_try_run() should be skipped in cases when the we can have multiple m2m_ctx running on the same time
   hverkuil: I have a question: this scheduling issue is also present in the v3 patch series, right? It has nothing to do with my request that the v4l2_m2m_ioctl_ helpers are used?
   svarbanov: <u>hverkuil</u>: in v3 I do not use m2m API's so there is no scheduling issue there
   hverkuil: Ah, now I see it. You're not using v4l2-mem2mem.h at all.
   svarbanov: <u>hverkuil</u>: yes, correct. I have WIP driver which is using m2m APIs now, and it is almost working
   <br> <u>hverkuil</u>: and this WIP also include few extensions to the m2m API
   hverkuil: You probably have a line similar to this in the probe(): dev-&gt;m2m_dev = v4l2_m2m_init(&amp;m2m_ops);
   <br> right?
   svarbanov: <u>hverkuil</u>: correct
   hverkuil: What I was thinking is that I believe you can do that in the open() instead: so each filehandle has its own m2m_dev, and since there is only one m2m_dev per context there is also effectively no scheduling.
   svarbanov: <u>hverkuil</u>: yes, I have tried this and it obviously works but I think that this is not correct usage of m2m API
   hverkuil: I may be missing something, but I don't offhand see a reason why it wouldn't work.
   <br> <u>svarbanov</u>: why wouldn't it be correct usage of the m2m API?
   svarbanov: <u>hverkuil</u>: because most of drivers create m2m device in probe, i.e only one m2m_dev per device video node :)
   hverkuil: <u>svarbanov</u>: so?
   <br> In your case the fw does the scheduling, so creating a m2m_dev per instance makes sense here.
   svarbanov: <u>hverkuil</u>: ok, if you are agree with that I will do it that way
   hverkuil: Let's see how it looks in the code.
   svarbanov: <u>hverkuil</u>: ok, then patchset v4 will use m2m API, plus the m2m extensions for removing buffers from ctx queue lists
   hverkuil: Good. Please add comments describing why m2m_dev is per instance.
   svarbanov: ok, I will
   <br> <u>hverkuil</u>: thanks!
   hverkuil: no problem, it's an interesting variation of m2m devices :-)
   svarbanov: <u>hverkuil</u>: yeah, this driver is pure software wrapper of the firmware interface, there is no hardware bits, registers ... nothing :)
   <br> <u>hverkuil</u>: I'm not happy because the whole beauty of the hardware is inside firmware code :(
   pinchartl: <u>hverkuil</u>: what does v4l2-mem bring to drivers when there's no scheduling to be handled in software ?
   sailus: <u>neg</u>: Hej!
   shuah: <u>sailus</u>: we probably have to discuss how to go forward with our patch series. Do you mind rebasing on top of media dev allocator api and use that allocation in your series
   <br> I am planning to upload my series to my kernel.org git repo and also start working on applying your series on top of mine and start testing
   <br> pinchartl ^^ your thoughts n this proposal
   <br> mchehab said he won't have time to review my patch series until after 4.10-rc1 - if we can agree on a plan, maybe we can start working towards 4.11 target
   mchehab: <u>shuah</u>: I said I *likely* won't have time
   shuah: <u>mchehab</u>: okay that is good news - there is a hope you just might - thanks
   mchehab: there are too much patches pending review
   <br> it would help if sub-maintainers could try to review their patches too
   <br> LinuxTV community                                                     : 260
   <br> Laurent Pinchart &lt;laurent.pinchart@ideasonboard.com&gt;                  : 247
   <br> Hans Verkuil &lt;hansverk@cisco.com&gt;                                     : 111
   <br> Guennadi Liakhovetski &lt;g.liakhovetski@gmx.de&gt;                         : 71
   <br> Kamil Debski &lt;k.debski@samsung.com&gt;                                   : 27
   <br> that's the current patch counts per reviewers, plus the ones not classified
   <br> last week, there was +450 patches to handle
   <br> at the "LinuxTX community" unclassified patchset
   ***: awalls1 has left
   shuah: <u>mchehab</u>: right - we are already ay 4.9-rc6 - even so, we have to com up with an action plan for these patch series sailus pinchartl - thoughts
   mchehab: yep. I'll freeze patch merge this week
   <br> (except for serious fixups)
   shuah: one request for you is please consider taking devres cleanup patch - we never used these interfaces ever. It is an indepedent cleanup patch in my opinion
   mchehab: I prefer applying it together with the media allocator patch series, as it makes easier to review
   <br> as I want to verify that the things that were considered there were somehow addressed by your new approach
   <br> also, there's no need to rush in that code removal
   shuah: okay
   mchehab: doing it altogether seems optimal, IMHO
   sailus: <u>shuah</u>: Let's address the existing issues in the media device allocator patches first.
   <br> I'm not too happy it's making the object lifetime issues worse than what they currently are.
   <br> The current bugs should be fixed first and then the framework can be extended, rather than extending it first and then try to figure out how it can be fixed...
   shuah: <u>sailus</u>: I am not clear on how media dev allocator api is making lifetimne issues worse - do you mean the 3 fixes that went earlier or the patch you reviewed
   <br> I did address your review comments and sent new version out
   <br> ah I see your second comment now - so sounds like you would like to see media dev allocator api based on top of your RFC series - did I understand that correctly?
   <br> pinchartl, sailus. mchehab: we are kind of at a stalemate guys - can we decide on a going formward path?
   <br> options:
   <br> 1. add media dev allocator api and get the snd_usb_audio work done and then get Sakari's RFC series in (this requires changes to drivers etc.)
   <br> 2. Other way round RFC series first and then media dev allocator and snd_usb_aduio. I am getting pressure from Audio folks for this work ro be wrapped up
   <br> Let's get to some action plan  that is workable
   mchehab: sailus need to send a non-RFC patchset
   <br> as I said several times, patches should be incremental, and not reverting some previous fixes
   <br> <u>shuah</u>: was you able to reproduce the issues sailus pointed on your tests?
   pinchartl: <u>shuah</u>: I'd prefer if we merged Sakari's patches first
   <br> (I think he's currently driving back home)
   <br> <u>mchehab</u>: Sakari told me he was planning to send a non-RFC version after receiving Hans' review
   mchehab: <u>pinchartl</u>: well, he need first to submit such patch series
   shuah: That is a very long pole in the tent - as you can see with driver changed and so on
   <br> <u>mchehab</u>: I think one problem he is seeing is use-after-free on video dev if device is removed while streaming
   mchehab: I'll only start reviewing his series when it becomes something mergeable
   shuah: let me ask the question anyway, can we merge media dev allocator api and snd_usb_audio first?
   mchehab: <u>shuah</u>: were you able to reproduce it?
   shuah: no I haven't been able yet - I am going to try again - I ran several bind_unbind loops with 3 applications running
   pinchartl: <u>mchehab</u>: please don't be stubborn. you can review at least patches from 4 onwards
   mchehab: <u>pinchartl</u>: patches 1 to 3 are regressions
   pinchartl: <u>shuah</u>: it's easy to reproduce. open the video device, start streaming, unbind it, stop streaming, close it
   <br> <u>mchehab</u>: ignore them for now
   <br> <u>shuah</u>: at least with omap3isp
   mchehab: how can I identify if the remaining patches aren't causing regressions, if the entire series start with regressions?
   pinchartl: I expect other devices to be similarly affected
   <br> <u>mchehab</u>: you don't need to perform an in-depth review at this time
   <br> what would be useful to move this forward is your opinion on the approach and the end result
   shuah: <u>pinchartl</u>: okay I can try it on em28xx and au0828 amd see what happens
   pinchartl: to see if you at least agree on the direction
   mchehab: this is the kind of series that requires in-depth and tests to review
   pinchartl: <u>shuah</u>: do you have access to any platform device ? I expect USB device to be similarly affected, but I haven't checked that myself
   shuah: <u>pinchartl</u>: for what its worth Sakari's series won't be complete until all the drivers are changed and tested
   pinchartl: <u>mchehab</u>: so was your MC rework series, and you repeatidly refused to squash fixes into the earlier patches that introduced issues. those were regressions too
   mchehab: no, nothing of these is related to MC rework
   shuah: au0828 is a complex case with snd_usb_audio in the mix
   mchehab: those bugs are there since day zero
   pinchartl: I'm telling you you merged a patch series in which you introduced regressions and then fixed them up in latter patches
   <br> so you've done exactly what you're saying shouldn't be done here
   mchehab: <u>pinchartl</u>: shit happens, but no regressions were introduced by purpose
   pinchartl: yes they were
   <br> we've pointed out regressions
   mchehab: I rebased it countless times, every time someone pointed regressions
   pinchartl: and you added patches on top instead of reworking the series
   <br> and at some point you stopped rebasing
   <br> so it was a deliberate decision
   mchehab: only when people stopped reviewing
   pinchartl: no fake excuse please
   mchehab: I did a rebase at the very last moment before applying it
   pinchartl: let's get these problems fixed
   mchehab: anyway, the discussion here is unrelated
   pinchartl: if you're committed to getting the MC mess fixed, please review the patches
   <br> otherwise please let us work
   shuah: <u>pinchartl</u>: I assume you didn't try the video streaming issue with media dev allocator api? Is it possible for you send me the dmesg for the issue
   pinchartl: <u>shuah</u>: no I haven't
   mchehab: I will review, as soon as it is ready for review
   pinchartl: and I think Sakari posted an oops report trigerred by the sequence I just described
   javier__: <u>shuah</u>: if the problem is reproducible with platform drivers, I guess you can use either exynos-gsc or exynos-mfc to test
   shuah: <u>javier__</u>: possibly
   <br> <u>pinchartl</u>: is this related to media controller or does it happen even when driver doesn't use media controller
   pinchartl: <u>shuah</u>: it's related to MC
   <br> I'm trying to find the oops report
   mchehab: <u>shuah</u>: if you apply Sakari's patch series, can you reproduce its bug on em28xx?
   shuah: <u>mchehab</u>: that is something that needs to be tested - haven't tried that
   <br> <u>pinchartl</u>: will you have time to reproduce the problem with media dev allocator api?
   javier__: <u>shuah</u>: ah, I misunderstood. If is related to MC, then you can't use those exynos platform drivers
   shuah: right
   pinchartl: <u>mchehab</u>: see the last e-mail in the "Re: [RFC v3 00/21] Make use of kref in media device, grab references as needed" thread
   shuah: okay here is what I am going to - I will try to reproduce the problw Sarai reported with media dev allocator api first since I have that ready to go
   <br> Testing with Sakari's sries will require changes to em28xx before we can test
   <br> we can decide based on the results
   pinchartl: <u>shuah</u>: I've just reproduced the issue with the Renesas VSP1
   <br> with the sequence I've described
   <br> I'll send you the oops report
   <br> and will try your patch series
   shuah: <u>pinchartl</u>: you will need to make changes to the driver to use media dev allocator api before you can run the test - I am sure I am stating the obvious :)
   mchehab: <u>pinchartl</u>: are you using devm_* on vsp1 driver?
   shuah: thanks for the oops - I will compare it with my test on au0828
   pinchartl: <u>shuah</u>: v4 of the series and v5 of 1/3 ?
   shuah: correct
   pinchartl: well I only need 1/3
   shuah: you probably just need that one patch media dev allocator v5 - the other two patches are driver changes
   <br> right 1/3 v5
   mchehab: as sailus answered: "around 95% of the changes are related to removing the user of devm_()"
   pinchartl: <u>shuah</u>: there's no non-USB API in v5...
   shuah: <u>pinchartl</u>: yes you are right - okay you won't be able to test it with the same driver
   pinchartl: support for non-USB devices is kind of a critical feature :-)
   shuah: <u>pinchartl</u>: yes my plan to add that - I don't have a device to test non-USB case at the moment
   pinchartl: I can test a v6 that will add support for non-USB devices with the VSP, but I'm afraid that v5 isn't usable for me
   shuah: I understand - I am assuming not supporting non-USB won't be a show stopper for now
   <br> <u>pinchartl</u>: The oops you sent, is that 4.9-rc4 or 4.9-rc4+patches
   pinchartl: it's 2bfc04d64db66fa62021a988740e8028f018b9c3
   <br> the HEAD of the media tree master branch when I last pulled it
   <br> (it's been updated since)
   <br> (with a single patch that touches an lirc driver only)
   ***: benjiG has left
   shuah: pinchartl, mchehab: I can't reproduce th problem on 4.9-rc5 on au0828 - jus 4.9-rc5 with no additional changes
   <br> I did unbind on au0828 while vlc is streaming - no issues
   <br> I did test with media dev allocator api as well - same results.
   pinchartl: <u>shuah</u>: I assume au0828 doesn't use media_entity_pipeline_start()/media_entity_pipeline_stop() ?
   shuah: yes it does
   pinchartl: it uses the non-locking versions
   shuah: I can generate the graph for you while vlc is treaming
   pinchartl: but I'm not sure that makes a difference
   <br> I don't know why it doesn't crash with that driver
   shuah: that might make a difference with mutex_lock_nested() in your oops
   pinchartl: yes but you lock the same mutex in the function that calls media_entity_pipeline_stop()
   shuah: I first tested with media dev allocator api and then went back to 4.9-rc5 stock
   pinchartl: so I don't think that's the problem
   shuah: right - that is not it - it is bahaving like do_exit path references a resource that is gone - similar to what we used to see with media device cdev exit path
   mchehab: pinchartl, shuah: au0828 doesn't use devm_()
   <br> vsp1 and omap3 does
   shuah: correct - using devm causes all sorts of problems - so I think this is what happens - devm resources get treleased in device_release() path before v4l2_release() is called
   <br> <u>pinchartl</u>: devm is very problematic
   mchehab: after reading and answering the long 00/21 reply from Sakari (with I missed somehow), I'm almost sure that the problems with omap3 are either due to devm_*() or due to some dev_foo() print after driver unregister
   pinchartl: <u>shuah</u>: no kidding. I've been trying to raise awareness of devm's issues for more than a year
   shuah: <u>pinchartl</u>: yes thanks to you I learned a lot
   pinchartl: <u>mchehab</u>: no they're not. devm isn't the culprit there. without devm we would have to call kfree too early as media_device has no release callback
   shuah: I debugged the a similar issue when I had au0828 and snd_usb_audio using devres interfaces I added to media controller api
   <br> <u>pinchartl</u>: either way we have to figure out what is this problem first though
   <br> btw adding printks could make this problem disappear
   pinchartl: <u>shuah</u>: Sakari has already debugged the issue, and the result is the patch series that we're discussing
   shuah: yeah I understand - if it is a driver specific issue and can't be reproduced on other drivers, then we have to look closely instead of changing media-core
   mchehab: <u>pinchartl</u>: you could either override dev.release() or to add a callback inside media_devnode_release() to call a driver specific callback
   <br> e. g. instead of:
   <br> devnode-&gt;dev.release = media_devnode_release;
   <br> devnode-&gt;dev.release = my_device_release;
   <br> and inside my_device_release, call media_devnode_release
   <br> on the drivers that require to release other things
   pinchartl: <u>mchehab</u>: I think we should stop discussing this now
   mchehab: agreed... I still have 244 patches to review
   pinchartl: <u>hverkuil</u>: you don't pick up patches for staging/media/davinci/vpfe, do you ?
   hverkuil: <u>pinchartl</u>: they are automatically delegated to you, so no, I generally don't pick them up.
   pinchartl: <u>hverkuil</u>: I'll pick them up. I usually don't get CC'ed so I miss them
   <br> is there anyone still maintaining the davinci platform ?
   javier__: <u>pinchartl</u>: I see that Sekhar Nori (nsekhar) maintains the platform bits
   <br> not sure about the media platform driver
   pinchartl: davinci is still not multiplatform :-/
   headless: <u>pinchartl</u>: Sekhar Nori
   <br> he's on #armlinux (but /away now)
   pinchartl: I hope he has plans to move davinci to DT :-)
   headless: <u>pinchartl</u>: only DA850 supports DT, I doubt that the real DaVincis will ever be converted
   <br> or even DA830
   <br> there's ongoing effort to convert the USB drivers to DT
   <br> like OHCI and MUSB glue
   pinchartl: <u>mchehab</u>: 63 patches left (out of 247), I'll call it a night