[07:57] <hverkuil> sailus: can you review the "Media Controller compliance fixes" patch series? Esp. 10 and 12-15 which do not have your Ack yet. Patch 5 doesn't have an Ack either, but that one is controversial. But see my reasoning in the cover letter.
[08:30] <hverkuil> gnurou: ping
[08:30] <gnurou> hverkuil: pong
[08:31] <hverkuil> sorry, something just came up. Give me a minute and I'll be back.
[08:32] <hverkuil> OK, back.
[08:35] <hverkuil> I looked closer at the data structures, and I now understand my confusion: in v4 the link between media_entity and the request data has been removed. Apparently after a discussion with sailus? Was that on irc? Do you know when that was?
[08:36] <hverkuil> I don't think I agree with this change, but I'd better first read the discussion.
[08:37] <gnurou> wow, that was some time ago
[08:37] <gnurou> IIUC basically sailus argument was that we may want to control things that are finer grain than media_entity
[08:38] <gnurou> and on my end, I still don't see the point of forcing the media framework for simple things like codec
[08:39] <gnurou> hence the creation of media_request_entity (which can also be embedded into media_entity to provide exactly the same behavior as before)
[08:40] <gnurou> what do you think is wrong with it?
[08:40] <gnurou> (beyond the arguably confusing name)
[08:44] <hverkuil> We are basically duplicating information. All v4l device nodes are backed by a media_entity. All you need to do is to select MEDIA_CONTROLLER and you have it. There is no need for enum media_request_entity_type (already contained in media_entity), no need for struct v4l2_request_entity (use container_of to go from the media_entity to the video_device), everything is handled in the same way.
[08:45] <hverkuil> There is no downside to a codec creating a media device node. The only question is whether to require apps to use the media device node to create a request, or to make a 'shortcut' ioctl in V4L2 for codecs. However, that's a completely separate matter.
[08:46] <hverkuil> Frankly, I think ALL media drivers should create a media device node. That was always the plan, but it never materialized (time, money)
[08:47] <hverkuil> Since all interactions with media drivers happen through device nodes, and all device nodes are backed by a media_entity, I don't see how you can get smaller grained request data than in a media_entity.
[08:48] <gnurou> yeah, you cannot perform on ioctl on something smaller than a media_entity anyway
[08:48] <hverkuil> actually, "all device nodes are backed by one or more media_entity's"
[08:49] <gnurou> ... or more?
[08:49] <gnurou> not that this would be a problem with request, since ultimately it is the driver that does the upcast
[08:50] <hverkuil> Sure. A typical PCI capture board can have multiple i2c devices internally, but only one /dev/videoX device node. The i2c device nodes are typically not exposed as v4l-subdevX device nodes for such boards.
[08:50] <gnurou> going back to media_entity would not be challenging with the current design - I just felt bad about pulling the MC for trivial drivers, and having user-space open the media node just for creating requests
[08:51] <gnurou> but ultimately I trust your judgment on that
[08:51] <hverkuil> Adding a media device node to a  codec driver is trivial, so that's not the issue. The question is if we support a V4L2 shortcut ioctl for codecs or not. That's unrelated to integrating this with media_entity.
[08:52] <gnurou> true
[08:52] <hverkuil> And I haven't made a decision on that yet.
[08:52] <hverkuil> (i.e. the shortcut ioctl)
[08:52] <gnurou> adding the media node adds code to the driver though
[08:53] <hverkuil> I'd just keep that ioctl in for now (as a separate patch), and this will probably be decided very late in the process.
[08:53] <gnurou> yup, that's not a problem, especially if it is just a link to the media ioctl
[08:53] <hverkuil> Only very little code.
[08:56] <hverkuil> BTW, I'll post a patch adding media support to vivid. I did that some time ago, but never posted it. It will be useful for adding request support to vivid. Just fold it into your patch series.
[08:57] <gnurou> looks like it will be necessary even :)
[08:59] <hverkuil> hmm, where did I store that vivid patch?
[08:59] <hverkuil> I have too many VMs/computers
[09:07] <hverkuil> Hmm, it might have been deleted accidentally :-(
[10:45] <sailus> gnurou: Ping?
[12:16] <hverkuil> padovan: any idea when you'll have a v8 of your fence series ready?
[12:17] <hverkuil> You're not waiting for feedback from us? At least, I don't think that's the case.
[12:22] *** prabhakarlad has left 
[12:43] <sailus> hverkuil: About G_CHIP_INFO for subdevs --- do you think this is relevant still?
[12:44] <sailus> On top of what I said about [GS]_REGISTER, debugfs isn't actually a drop-in replacement for this. It'd be very nice if it was though: the need for this isn't limited to media hardware.
[12:51] <hverkuil> Yes, I still think it is relevant. Especially for video receivers this is in my experience very useful to have. And I'm not going to add all sorts of debugfs code when 13 lines of core code do the same thing.
[12:51] <padovan> hverkuil: best case scenario, this friday, otherwise next week. I haven't worked on it in the last few days, many things got in the way :(
[12:51] <padovan> hverkuil: I'm not waiting for any feedback atm
[12:52] <hverkuil> padovan: OK, no problem! I was just curious. It would be really nice if we can finish this for 4.17.
[16:39] *** benjiG has left 
[21:12] *** Elladan has quit IRC (Read error: Connection reset by peer)