javier__: Hello! hi how do i include the v4l library in c? ? am i allowed to use v4l on every webcam? hello everyone anyone familiar with omap3-isp? I am working on a CCDC sensor driver and would love some general pointers in the approach :D noname: you might say that I'm familiar with it what do you mean by CCDC sensor driver ? haha i know you are familiar with it well, i have an omnivision sensor (ov7692) configured in 8 bit pararell mode my SoC is TI's OMAP3 running mainline 3.18 kernel not that bad my first goal is to set the sensor into the test mode (which it should output a rainbow) you need to write a subdev driver for the sensor yes that i have done however, i am getting lost in the size of the v4l/media-ctl framework the device is getting probed, and shows up as an entity when i do "media-ctl -v -p" first step, is everything probed correctly ? (omap3isp and sensor) ok that's a good start the omap3isp is assumed to work, because it works with an aptina sensor also using 8 bit pararell media-ctl reports a link between the ov7692 source pad and the CCDC sink pad ? yes it is a good start. I just need to cross the finish line yes indeed the ov7692 can be linked to CCDC's sink good so where's the issue ? :-) you need to configure the pipeline with media-ctl and then you can use any V4L2 application to capture video on a video node where CCDC is linked to a resizer/previewer well ,that's where i'm stuck at i use gst-launcher to open a udp stream i'm greeted with "system error: Broken pipe " I would start with a simpler command line test application such as yavta or v4l2-ctl you will likely be greeted with the same error message though which means that your pipeline configuration isn't valid how should i use v4l2-ctl to test its sanity? right, i suspected that much yavta -c10 -f YUYV -s 640x480 /dev/videoX (change the format, resolution and video node according to your needs) regarding pipeline validation you need to ensure that on every link the source format is identical to the sink format ok let me spend some time with yavta one thing that i see is a lot of -22 errors upon v4l2-ioctl calls? (the only exception if the sensor to CCDC link where the number of bits can be lower on the CCDC side, as there's a lane shifter there, but if your sensor outputs 8 bits you don't need that) where 22 transaltes to invalid argument -22 is -EINVAL, that's invalid parameter but start with yavta get capture working ok let me do that and then move to gstreamer i will report back :) one step at a time for sure thanks for the help and all the work you've done in v4l! you're welcome pinchartl, this is what i see - http://pastebin.com/KuZJhncv ie "Invalid argument (22)" is there verbose mode? i think i'd like to know which argument is failing can you paste the output of media-ctl -p ? hi why do my program stops working when i send the ioctl VIDIOC_DQBUF pinchartl: http://paste.ubuntu.com/14056502/ sorry, just got back from launch noname: hat have you launched? :-) what even lunch* lol typo for typo :-) noname: you've configured your pipeline as sensor -> CCDC -> preview -> resizer -> memory but you're trying to capture from the video node connected to the CCDC output instead of the one connected to the resizer output noname: media-ctl --print-dot > graph.dot dot -Tps < graph.dot > graph.ps pinchartl: the output looks more or less the same with /dev/video6 (the later on a machine with graphviz installed) here it is -http://pastebin.com/2s50TGbY noname: the resizer is configured to produce UYVY but you try to capture YUYV use -f UYVY thanks - no luck so far however http://pastebin.com/A09dJcpD mchehab: I'm sorry but I can't nack the mc rework in its current state for v4.5 it requires more work first of all I still need to review your additional fixes and then a rebase is needed it's 99% my driver, it would be nice to find out where in the driver i should focus on noname: just looking at the log I can't tell more pinchartl: ??? can't nack? you might want to add printks to the driver s/can't nack/can't ack/ :-) (I know that nobody complains when I don't nack patches) pinchartl: you had 7-9 months to review the patches if it needs rework, point exactly what's needed mchehab: you've been sending lots of fixes over the past few weeks and I can't review them all for v4.5 no, I didn't sent "lots of fixes"... just addressed the points you complained those patches are trivial that's what I mean by fixes pinchartl: Adding printks, that i can do. However, is there a way to pinpoint where in the framework/pipe i am getting "Invalid argument"? the result needs to be reviewed so, do it noname: start from the start streaming function isp-video.c mchehab: give me time I can't work on this full time pinchartl: great, thanks i will start from there! pinchartl: you had 7-9 patches... our goal after the MC workshop were to add them for 4.4 we delayed it already one Kernel version, just due to you we'll have to delay it again it's not ready if it is not ready, point what's missing the code doesn't have what it takes for such a core framework to be upstream I will and I'll also ask for a rebase with fixes squashed in the original patches piling fixes on top of breakages in a dev branch and pushing the result to mainline isn't how upstream development works as I said before, I won't squash the fixes with the original patches they you won't get my ack it took 3 days to do the last rebase because even a small change on a 89 patch series (on that time) caused lots of troubles it took a year to develop mc v1 it takes time to achieve quality pinchartl: the DVB patches were sent in Dec 2014 we're already 1 year late with those stuff due to you you should not impose overhead on everyone's else work because you lack the time to review patches 1 year is plenty of time to rebase :-) ? yes, I've doing rebases on this series this entire year I won't do any more rebase on it you would ask for a rebase if you received such a patch set from another developer that's how upstream development works pinchartl: if I was receiving this series from any developer, I would have it applied already I would never delay something for one year without a very good reason I do review 400-600 patches *per kernel version* the entire MC series is ~100-150 patches and has been reviewed over the last 7-9 months that's enough time for review compare the last version to the first version and tell me you should have merged it a year ago pinchartl: there weren't actually much changes at the DVB side I'll happily accept all the dvb changes, it's the mc and v4l2 apis I care about from a MC 0.1 API point of view, there were almost no changes pinchartl: no, you were the one who nacked the DVB changes and forced me to spend one year on it now, it is time to closure it it needs more work I'll nack a pull request in the current state if I have to where? be objective I'll tell you as soon as I can review your recent fixes well, then review it and point where as I've said, I will but v4.5 is not reasonable I'm sorry but you had enough time to review. I won't wait for another year for you to review them. how have I exactly had enough time to review patches that were sent a couple of days ago ? it was sent a couple of days ago because you delayed ~7 months on your review. They all addresses the points that you mentioned I have no more comment to make on this topic for today :movew -t 0: opps oops* pinchartl: I tracked down the failure point. It is because I don't have g_ext_ctrls ("no pixel rate control in subdev "). The error message comes from "isp_video_check_external_subdevs" function in ispvideo.c today's lesson is thus "read your kernel log" :-) Before I implement g_ext_ctrls in my driver, I realized "isp_video_check_external_subdevs" function simply returns 0 when "Memory-to-memory pipelines have no external subdev." pinchartl: hahahahahahahah ya... i was just getting lost in all the errors flying by me :D So I guess my question is, how do i tell if i'm dealing with memory-to-memory pipelines? you're capturing from the sensor so it's not a memory to memory pipeline I see. So I need these ctrls thanks! 'ÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄÄplööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööööhhhhhhhhjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjj jjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjbg5t66666666666666666666666666666666666kmjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjj~ikkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk kkkkkkkkkkkkkkkkkk5r4tttttttttttttttttttt~~~~~~~~~~~~~