[02:23] *** awalls has left 
[09:16] <pinchartl> hverkuil: ping
[09:23] <hverkuil> pinchartl: pong (lunch in 10 min though)
[09:24] <pinchartl> I'll try to make it quick then
[09:25] <pinchartl> should ENUM_FMT be mandatory on video nodes that capture metadata ?
[09:25] <pinchartl> there are three cases
[09:25] <sailus_> Yes, lunch in 10 minutes.
[09:25] <sailus_> I agree.
[09:25] <pinchartl> - dedicated video nodes for metadata, with a single format supported (i.e. S_FMT is an alias for G_FMT)
[09:25] <pinchartl> ENUM_FMT is redundant, but it could be easier for applications to rely on the ioctl always being implemented
[09:26] <pinchartl> - video nodes that can capture multiple data types in a non-MC driver
[09:26] <pinchartl> ENUM_FMT is needed there
[09:26] <pinchartl> - video nodes that can capture multiple data types in an MC driver
[09:26] <pinchartl> it's the media bus that matters there, ENUM_FMT is ill-defined (and not implemented for video formats either, in the OMAP3 ISP driver for instance)
[09:27] <pinchartl> the VSP driver falls in the first category, that's the one for which I'd like to agree on an answer
[09:27] <pinchartl> it would be good to agree on the third category at some point too
[09:27] <hverkuil> If you can DMA data to memory, then you need ENUM_FMT, even if there is only one supported format.
[09:28] <hverkuil> I'm not sure what you mean with "implemented for video formats either, in the OMAP3 ISP driver for instance"
[09:28] <pinchartl> not that I disagree, but what's the rationale for that, when only one format is supported ?
[09:28] <hverkuil> is that a typo and do you mean metadata formats?
[09:29] <hverkuil> consistency.
[09:29] <pinchartl> sailus: are you fine with that ?
[09:29] <sailus> I thought of the same actually.
[09:30] <sailus> It's good for consistency.
[09:30] <sailus> So yes.
[09:30] <pinchartl> ok, fine with me
[09:30] <pinchartl> lyakh: any comment ?
[09:30] <pinchartl> hverkuil: regarding the third case, I'm talking about drivers that implement video nodes that just capture whatever the previous subdev in the pipeline provides
[09:30] * lyakh reading
[09:31] <pinchartl> with the pipeline being controlled from userspace using MC and pad-level subdev ioctls
[09:31] <hverkuil> I think the spec actually requires it, but I'm not 100% certain if it is stated explicitly somewhere.
[09:31] <pinchartl> in that case the video node code doesn't know about all possible formats that could be captured, so implementing ENUM_FMT in a meaningful way isn't really possible
[09:31] <sailus> pinchartl: Unless we make that dependent on the media bus code.
[09:32] <pinchartl> that's related to the "limited V4L2 profile" that we discussed years ago
[09:32] <sailus> Currently it isn't but there are a few reserved fields.
[09:32] <sailus> AFARI.
[09:32] <sailus> Need to go, lunch.
[09:32] <sailus> Have fun! :-)
[09:32] <pinchartl> sailus: yes, we could make ENUM_FMT return only the format(s) corresponding to the active media bus format, but I'm not sure how useful that would be
[09:33] <pinchartl> and it would be ill-defined without clarifications to the spec
[09:33] <lyakh> if we specify ENUM_FMT as compulsory ATM, I wouldn't make an exception for metadata-only nodes
[09:33] <hverkuil> pinchartl: G_FMT does return a valid pixfmt?
[09:33] <lyakh> if that was the "comment" question
[09:33] <hverkuil> based on the current pipeline configuration?
[09:34] <hverkuil> I'm OK if ENUM_FMT would return just a single pixfmt, which changes whenever the incoming mediabus format changes.
[09:34] <hverkuil> But you do need to report a pixelformat.
[09:35] <hverkuil> lunch. back in 30 min.
[09:35] <pinchartl> hverkuil: currently G_FMT is decoupled from the media bus format
[09:35] <pinchartl> we need to agree on how the format ioctls should behave with MC-based drivers
[09:36] <pinchartl> but that's decoupled from the first metadata use case I described above
[09:36] <pinchartl> so I have an answer to my question for the VSP driver :-)
[09:37] <pinchartl> lyakh: the question was whether, in the non-MC case, ENUM_FMT should be optional on metadata video nodes that support a single format
[09:37] <pinchartl> and I think we all agree that it shouldn't
[09:37] <pinchartl> so I'll implement it
[09:38] <lyakh> in the MC case another option would be to enum all possible output formats, even if some of them aren't available with the current pipeline configuration
[09:38] <lyakh> and in general to get them the pipeline has to be reconfigured
[09:39] <pinchartl> I think we need to discuss the MC case in details
[09:39] <pinchartl> there are several options
[09:39] <pinchartl> and we need to figure out what is both possible to implement in drivers and useful for userspace
[09:40] <lyakh> but then if the user attempts an S_FMT for one of the formats, that isn't available with the current pipeline config, obviously, that won't work
[09:41] <pinchartl> S_FMT need to be defined as well, in at least the OMAP3 ISP driver we accept any format and then verify the pipeline configuration at STREAMON time only
[09:44] <lyakh> OTOH, if we want to force the user to go with MC, we could define all ENUM_* ioctl()s on video nodes as "what's possible with the current pipeline." I actually think that would be more logical
[09:45] <pinchartl> that's an option, I need to check whether it will work properly with the CREATE_BUF use cases I have
[09:49] <lyakh> we really need libv4l with plugins for non-trivial MC cases...
[09:53] <pinchartl> yes we really do
[10:15] <hverkuil> In general you cannot map mediabus to pixfmt in a generic way. It depends on the DMA engine what it will do (and probably even on endianness issues).
[10:16] <hverkuil> But doesn't the DMA engine block also have a list of supported mediabus formats?
[10:50] <lyakh> hverkuil: it might have one, but it won't necessarily know which of those formats, that it supports, the whole pipeline can provide in various its configurations
[11:00] <hverkuil> But if it supports mediabus formats a, b and c (and exposes that with enum_mbus_code), then it also knows how these mbus formats are mapped to pixfmt values.
[11:01] <hverkuil> The MC configures the pipeline, selects format b, and the dma driver can then have ENUM_FMT enumerate the pixfmts that are valid for mbus format b.
[11:02] <lyakh> right, I also think, that that's the most logical approach
[11:38] <pinchartl> the problem with that approach is that you need to modify the active configuration to enumerate formats
[11:38] <pinchartl> it would be nice to enumerate the pixel formats for a media bus format without modifying the active configuration
[11:48] <hverkuil> One option would be to use a reserved field and put in the mbus code: if it is non-zero, then only enumerate pixfmts valid for that mbus code.
[11:48] <hverkuil> If it is 0, then it has the default behavior of enumerating based on the current mbus code (or configuration)
[11:52] <pinchartl> I've been thinking about something like that
[11:53] <pinchartl> but in that case I'm wondering whether we shouldn't revamp the enumeration ioctl completely and return all information in one go. there was no good excuse to do so until now, maybe this would be a good one :-)
[12:18] *** oskie has left 
[12:47] <hverkuil> pinchartl: thanks for reviewing. It's all copy-and-paste and just trying to get the damn thing to work. Which it why it is an RFC patch series :-)
[12:48] <hverkuil> And yes, that sleep is needed even if there is no reset signal. Without it it won't start.
[12:49] <hverkuil> (to be precise: I get i2c errors)
[12:50] <pinchartl> is the power down gpio wired up on your board ?
[12:56] <pinchartl> hverkuil: feel free to review v2 of the metadata patch series :-)
[12:57] <hverkuil> pinchartl: I have two ov7670 sensor boards: one needs reset/pwdn, the other doesn't.
[12:57] <hverkuil> I've tested with both.
[12:58] <pinchartl> so on the one that has no GPIO connected to either reset or pwdn, you still need the delay ?
[12:58] <hverkuil> yes, I do.
[12:59] <hverkuil> I think it comes up too quickly and needs a bit more time to settle.
[12:59] <hverkuil> It's likely the time between the sensor receiving 3.3V and the i2c bus being probed that is the issue.
[13:04] <larsc> is that with a static supply? Or is the power turned on by the driver?
[13:05] <hverkuil> it's turned on by another driver, if I understand it correctly. Some power management block.
[13:05] <hverkuil> This is a arduino compatible device with lots of pins.
[13:07] <larsc> maybe you need to synchronize the power-on to the driver probe
[13:17] <hverkuil> I leave that to other interested parties.
[13:17] <hverkuil> When I started on this it didn't work at all :-)
[13:18] <hverkuil> All I want to do is to get atmel-isi out of soc-camera.
[20:51] *** awalls has left