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~~~~~~~~~~~~~