This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

Linux: AM57x USB camera VPE error

Other Parts Discussed in Thread: AM5728

Tool/software: Linux

hi all:

hardware env: am5728, logitech usb webcam 270, HDMI monitor with 1080

software env: ti-processor-sdk-linux-am57xx-evm-03.01.00.06

boot from nfs, kernel build from sdk 3.01(patch with this topic e2e.ti.com/.../2023362

dts use beagle-x15

run the gst command:

gst-launch-1.0 v4l2src device=/dev/video1 num-buffers=1000 io-mode=4 ! 'video/x-raw, format=(string)YUY2, width=(int)1280, height=(int)720' ! queue !  vpe ! queue ! kmssink

log from dmesg:

[ 735.664284] contiguous chunk is too small 4096/1843200 b
[ 903.616336] contiguous chunk is too small 4096/1843200 b
[ 1003.872194] contiguous chunk is too small 4096/1843200 b

log from gst:

0:00:03.986349826 1187 0x143ec0 DEBUG v4l2allocator gstv4l2allocator.c:1310:gst_v4l2_allocator_dqbuf:<v4l2src0:pool:src:allocator> driver pretends buffer is queued even if dequeue succeeded
0:00:03.986413429 1187 0x143ec0 DEBUG v4l2bufferpool gstv4l2bufferpool.c:1704:gst_v4l2_buffer_pool_process:<v4l2src0:pool:src> process buffer 0xb49fecb4
0:00:03.986486792 1187 0x143ec0 DEBUG v4l2src gstv4l2src.c:774:gst_v4l2src_create:<v4l2src0> ts: 0:16:41.711131000 now 0:16:43.851901055 delay 0:00:02.140770055
0:00:03.986549581 1187 0x143ec0 INFO v4l2src gstv4l2src.c:810:gst_v4l2src_create:<v4l2src0> sync to 0:00:00.133333333 out ts 0:00:01.498335565
0:00:03.986711760 1187 0x143ec0 DEBUG v4l2bufferpool gstv4l2bufferpool.c:1301:gst_v4l2_buffer_pool_acquire_buffer:<v4l2src0:pool:src> acquire
0:00:04.004511072 1187 0x143ef0 DEBUG v4l2bufferpool gstv4l2bufferpool.c:1379:gst_v4l2_buffer_pool_release_buffer:<v4l2src0:pool:src> release buffer 0x179850
0:00:04.145967956 1187 0x143ec0 DEBUG v4l2allocator gstv4l2allocator.c:1310:gst_v4l2_allocator_dqbuf:<v4l2src0:pool:src:allocator> driver pretends buffer is queued even if dequeue succeeded
0:00:04.146038554 1187 0x143ec0 DEBUG v4l2bufferpool gstv4l2bufferpool.c:1704:gst_v4l2_buffer_pool_process:<v4l2src0:pool:src> process buffer 0xb49fecb4
0:00:04.146095650 1187 0x143ec0 DEBUG v4l2src gstv4l2src.c:774:gst_v4l2src_create:<v4l2src0> ts: 0:16:43.851720000 now 0:16:44.011511214 delay 0:00:00.159791214
0:00:04.146149330 1187 0x143ec0 INFO v4l2src gstv4l2src.c:810:gst_v4l2src_create:<v4l2src0> sync to 0:00:00.266666666 out ts 0:00:03.638925216
0:00:04.146230988 1187 0x143ec0 DEBUG v4l2bufferpool gstv4l2bufferpool.c:1379:gst_v4l2_buffer_pool_release_buffer:<v4l2src0:pool:src> release buffer 0x1798f0
ERROR: from element /GstPipeline:pipeline0/GstV4l2Src:v4l2src0: Internal data flow error.
Additional debug info:
../../../../gstreamer-1.6.3/libs/gst/base/gstbasesrc.c(2943): gst_base_src_loop (): /GstPipeline:pipeline0/GstV4l2Src:v4l2src0:
streaming task paused, reason error (-5)
0:00:04.147025127 1187 0x143440 DEBUG v4l2bufferpool gstv4l2bufferpool.c:926:gst_v4l2_buffer_pool_flush_start:<v4l2src0:pool:src> start flushing
0:00:04.164697396 1187 0x143440 DEBUG v4l2bufferpool gstv4l2bufferpool.c:874:gst_v4l2_buffer_pool_stop:<v4l2src0:pool:src> stopping pool
0:00:04.176815087 1187 0x143440 DEBUG v4l2bufferpool gstv4l2bufferpool.c:658:gst_v4l2_buffer_pool_streamoff:<v4l2src0:pool:src> Stopped streaming
0:00:04.177013540 1187 0x143440 DEBUG v4l2allocator gstv4l2allocator.c:757:gst_v4l2_allocator_stop:<v4l2src0:pool:src:allocator> stop allocator
0:00:04.177766362 1187 0x143440 DEBUG v4l2 gstv4l2object.c:3545:gst_v4l2_object_stop:<v4l2src0> stopping
0:00:04.177894218 1187 0x143440 DEBUG v4l2 gstv4l2object.c:3553:gst_v4l2_object_stop:<v4l2src0> deactivating pool
0:00:04.178691935 1187 0x143440 DEBUG v4l2 v4l2_calls.c:710:gst_v4l2_close:<v4l2src0> Trying to close /dev/video1
0:00:04.178933983 1187 0x143440 DEBUG v4l2 v4l2_calls.c:459:gst_v4l2_empty_lists:<v4l2src0> deleting enumerations

run command capturevpedisplay:

capturevpedisplay 800 600 yuyv 1920 1080 yuyv 0 0 -s 32:1920x1080

and the output  log is 

vpe:/dev/video0 open success!!!
vip open success!!!
using 1 connectors, 1920x1080 display, multiplanar: 1
vip: G_FMT(start): width = 800, height = 600, 4cc = YUYV
vpe i/p: G_FMT: width = 800, height = 600, 4cc = YUYV
vpe o/p: G_FMT: width = 1920, height = 1080, 4cc = YUYV
vip: QBUF failed: Bad address, index = 0

dmesg is 

[ 21.219734] usbcore: registered new interface driver uvcvideo
[ 21.226079] USB Video Class driver (1.1.1)
[ 22.624684] usb 1-1: set resolution quirk: cval->res = 384
[ 22.631824] usbcore: registered new interface driver snd-usb-audio
[ 23.904950] PVR_K: UM DDK-(3699939) and KM DDK-(3699939) match. [ OK ]
[ 30.044643] omap_hwmod: mmu1_dsp2: _wait_target_disable failed
[ 30.058195] omap_hwmod: mmu0_dsp2: _wait_target_disable failed
[ 30.074735] omap_hwmod: mmu1_dsp1: _wait_target_disable failed
[ 30.088879] omap_hwmod: mmu0_dsp1: _wait_target_disable failed
[ 75.553784] usb 1-1: reset high-speed USB device number 2 using xhci-hcd
[ 685.040821] contiguous chunk is too small 4096/1843200 b
[ 735.664284] contiguous chunk is too small 4096/1843200 b
[ 903.616336] contiguous chunk is too small 4096/1843200 b
[ 1003.872194] contiguous chunk is too small 4096/1843200 b

would someone help me to solve this problem?? I try many methods but can't solve it. 

thank you very much.

  • The software team have been notified. Please expect answer next week, as the person involved is out of office now.
  • Biser Gatchev-XID said:
    The software team have been notified. Please expect answer next week, as the person involved is out of office now.

    hi Biser Gatchev-XID

    is somebody can help me to solve this problem,please...

  • Hello,

    Please provide more information regarding the resolution, format, etc what your video source provides.
    Is this custom board or it is EVM?
    Did you verify that the patch from this is applied:
    e2e.ti.com/.../2023362
    Do you observe the same problem with the latest PSDK?
    Please try yavta and let me know the result(check the wiki page below)
    processors.wiki.ti.com/.../Linux_Core_VIP_User's_Guide

    BR
    Margarita
  • Board is custom board.

    my usb camera is Logitech C270, max resolution is 720P.

    Driver Info (not using libv4l2):
    Driver name : uvcvideo
    Card type : UVC Camera (046d:0825)
    Bus info : usb-xhci-hcd.1.auto-1.2
    Driver version: 4.4.19
    Capabilities : 0x84200001
    Video Capture
    Streaming
    Extended Pix Format
    Device Capabilities
    Device Caps : 0x04200001
    Video Capture
    Streaming
    Extended Pix Format
    Priority: 2
    Video input : 0 (Camera 1: ok)
    Format Video Capture:
    Width/Height : 1280/720
    Pixel Format : 'YUYV'
    Field : None
    Bytes per Line : 2560
    Size Image : 1843200
    Colorspace : sRGB
    Transfer Function : Default
    YCbCr Encoding : Default
    Quantization : Default
    Flags :
    Crop Capability Video Capture:
    Bounds : Left 0, Top 0, Width 1280, Height 720
    Default : Left 0, Top 0, Width 1280, Height 720
    Pixel Aspect: 1/1
    Selection: crop_default, Left 0, Top 0, Width 1280, Height 720
    Selection: crop_bounds, Left 0, Top 0, Width 1280, Height 720
    Streaming Parameters Video Capture:
    Capabilities : timeperframe
    Frames per second: 5.000 (5/1)
    Read buffers : 0
    brightness (int) : min=0 max=255 step=1 default=128 value=128
    contrast (int) : min=0 max=255 step=1 default=32 value=32
    saturation (int) : min=0 max=255 step=1 default=32 value=32
    white_balance_temperature_auto (bool) : default=1 value=1
    gain (int) : min=0 max=255 step=1 default=64 value=1
    power_line_frequency (menu) : min=0 max=2 default=2 value=2
    white_balance_temperature (int) : min=0 max=10000 step=10 default=4000 value=1070 flags=inactive
    sharpness (int) : min=0 max=255 step=1 default=24 value=24
    backlight_compensation (int) : min=0 max=1 step=1 default=0 value=0
    exposure_auto (menu) : min=0 max=3 default=3 value=3
    exposure_absolute (int) : min=1 max=10000 step=1 default=166 value=656 flags=inactive
    exposure_auto_priority (bool) : default=0 value=1

    run dmabuftest command:

    root@am57xx-evm:~# /etc/init.d/weston stop
    Stopping Weston
    root@am57xx-evm:~# dmabuftest -s 32:1920x1080 -c 1280x720@YUYV -d /dev/video1
    Opening Display..
    using 1 connectors, 1920x1080 display, multiplanar: 1
    Opening V4L2..
    Exported buffer fd = 6

    Exported buffer fd = 8

    Exported buffer fd = 10

    Exported buffer fd = 12

    Exported buffer fd = 14

    Exported buffer fd = 16

    ERROR:v4l2_qbuf:453: VIDIOC_QBUF failed: Bad address (-1)
    ERROR:v4l2_qbuf:453: VIDIOC_QBUF failed: Bad address (-1)
    ERROR:v4l2_qbuf:453: VIDIOC_QBUF failed: Bad address (-1)
    ERROR:v4l2_qbuf:453: VIDIOC_QBUF failed: Bad address (-1)
    ERROR:v4l2_qbuf:453: VIDIOC_QBUF failed: Bad address (-1)
    ERROR:v4l2_qbuf:453: VIDIOC_QBUF failed: Bad address (-1)
    ^C
    root@am57xx-evm:~#

    run the yavta command:

    root@am57xx-evm:~# yavta -c60 -fYUYV -Fvout_800x600_yuyv.yuv -s800x600 /dev/video1
    Device /dev/video1 opened.
    Device `UVC Camera (046d:0825)' on `usb-xhci-hcd.1.auto-1.2' is a video output (without mplanes) device.
    Video format set: YUYV (56595559) 800x600 (stride 1600) field none buffer size 960000
    Video format: YUYV (56595559) 800x600 (stride 1600) field none buffer size 960000
    8 buffers requested.
    length: 960000 offset: 0 timestamp type/source: mono/SoE
    Buffer 0/0 mapped at address 0xb6cf0000.
    length: 960000 offset: 962560 timestamp type/source: mono/SoE
    Buffer 1/0 mapped at address 0xb6c05000.
    length: 960000 offset: 1925120 timestamp type/source: mono/SoE
    Buffer 2/0 mapped at address 0xb6b1a000.
    length: 960000 offset: 2887680 timestamp type/source: mono/SoE
    Buffer 3/0 mapped at address 0xb6a2f000.
    length: 960000 offset: 3850240 timestamp type/source: mono/SoE
    Buffer 4/0 mapped at address 0xb6944000.
    length: 960000 offset: 4812800 timestamp type/source: mono/SoE
    Buffer 5/0 mapped at address 0xb6859000.
    length: 960000 offset: 5775360 timestamp type/source: mono/SoE
    Buffer 6/0 mapped at address 0xb676e000.
    length: 960000 offset: 6737920 timestamp type/source: mono/SoE
    Buffer 7/0 mapped at address 0xb6683000.
    0 (0) [-] none 0 960000 B 420400.323247 420402.167961 257.599 fps ts mono/SoE
    1 (1) [-] none 1 960000 B 420402.167877 420402.256366 0.542 fps ts mono/SoE
    2 (2) [-] none 2 960000 B 420402.219548 420402.352272 19.353 fps ts mono/SoE
    3 (3) [-] none 3 960000 B 420402.295442 420402.443858 13.176 fps ts mono/SoE
    4 (4) [-] none 4 960000 B 420402.359940 420402.536680 15.504 fps ts mono/SoE
    5 (5) [-] none 5 960000 B 420402.427604 420402.627869 14.779 fps ts mono/SoE
    6 (6) [-] none 6 960000 B 420402.495376 420402.716435 14.755 fps ts mono/SoE
    7 (7) [-] none 7 960000 B 420402.559827 420402.807169 15.516 fps ts mono/SoE
    8 (0) [-] none 8 960000 B 420402.627566 420402.899485 14.763 fps ts mono/SoE
    9 (1) [-] none 9 960000 B 420402.695334 420402.992167 14.756 fps ts mono/SoE
    10 (2) [-] none 10 960000 B 420402.759792 420403.082928 15.514 fps ts mono/SoE
    11 (3) [-] none 11 960000 B 420402.827524 420403.173098 14.764 fps ts mono/SoE

     

  • hi Gashova:
    also, use sdk 4.02, the log is same as 3.01 with usb patch.
  • Hello,

    Could you run this command:
    gst-launch-1.0 v4l2src device=/dev/video1 num-buffers=1000 io-mode=4 ! 'video/x-raw, format=(string)YUY2, width=(int)1280, height=(int)720' ! queue ! vpe num-input-buffers=8 ! queue ! fakesink --gst-debug=2
    and post the output.

    BR
    Margarita
  • hi Margarita Gashova

    use SDK 4.02, run as NFS

    the output is:

    root@am57xx-evm:~#
    root@am57xx-evm:~# uname -a
    Linux am57xx-evm 4.9.59-ga75d8e9305 #2 SMP PREEMPT Sat Dec 23 10:02:24 EST 2017 armv7l GNU/Linux
    root@am57xx-evm:~#
    root@am57xx-evm:~#
    root@am57xx-evm:~# gst-launch-1.0 v4l2src device=/dev/video1 num-buffers=1000 io-mode=4 ! 'video/x-raw, format=(string)YUY2, width=(int)1280, height=(int)720' ! queue ! vpe num-input-buffers=8 ! queue ! fakesink --gst-debug=2
    Setting pipeline to PAUSED ...
    Pipeline is live and does not need PREROLL ...
    Setting pipeline to PLAYING ...
    New clock: GstSystemClock
    0:00:10.115138231 1728 0x1d2030 WARN vpe gstvpebufferpool.c:466:gst_vpe_buffer_pool_import: Allocating a new input buffer index: 0/128, 0
    0:00:10.135273436 1728 0x1d2030 ERROR vpe gstvpebufferpool.c:380:gst_vpe_buffer_pool_queue: vpebufferpool: QBUF failed: Bad address, index = 31
    0:00:10.135562983 1728 0x212430 WARN bufferpool gstbufferpool.c:300:do_alloc_buffer:<vpebufferpool1> alloc function failed
    0:00:10.145840262 1728 0x212430 WARN bufferpool gstbufferpool.c:300:do_alloc_buffer:<vpebufferpool1> alloc function failed
    0:00:10.156085822 1728 0x212430 WARN bufferpool gstbufferpool.c:300:do_alloc_buffer:<vpebufferpool1> alloc function failed
    0:00:10.166913566 1728 0x212430 WARN bufferpool gstbufferpool.c:300:do_alloc_buffer:<vpebufferpool1> alloc function failed
    0:00:10.177144486 1728 0x212430 WARN bufferpool gstbufferpool.c:300:do_alloc_buffer:<vpebufferpool1> alloc function failed
    0:00:10.187368900 1728 0x212430 WARN bufferpool gstbufferpool.c:300:do_alloc_buffer:<vpebufferpool1> alloc function failed
    0:00:10.197596729 1728 0x212430 WARN bufferpool gstbufferpool.c:300:do_alloc_buffer:<vpebufferpool1> alloc function failed
    0:00:10.207819516 1728 0x212430 WARN bufferpool gstbufferpool.c:300:do_alloc_buffer:<vpebufferpool1> alloc function failed
    0:00:10.218055641 1728 0x212430 WARN bufferpool gstbufferpool.c:300:do_alloc_buffer:<vpebufferpool1> alloc function failed
    0:00:10.229077772 1728 0x212430 WARN bufferpool gstbufferpool.c:300:do_alloc_buffer:<vpebufferpool1> alloc function failed
    0:00:10.239305926 1728 0x212430 WARN bufferpool gstbufferpool.c:300:do_alloc_buffer:<vpebufferpool1> alloc function failed
    0:00:10.249530828 1728 0x212430 WARN bufferpool gstbufferpool.c:300:do_alloc_buffer:<vpebufferpool1> alloc function failed
    0:00:10.250368886 1728 0x219750 WARN basesrc gstbasesrc.c:2948:gst_base_src_loop:<v4l2src0> error: Internal data flow error.
    0:00:10.250448756 1728 0x219750 WARN basesrc gstbasesrc.c:2948:gst_base_src_loop:<v4l2src0> error: streaming task paused, reason error (-5)
    0:00:10.253408476 1728 0x219750 WARN queue gstqueue.c:992:gst_queue_handle_sink_event:<queue0> error: Internal data flow error.
    ERROR: from element /GstPipeline:pipeline0/GstV4l2Src:v4l2src0: Internal data flow error.
    0:00:10.253618478 1728 0x219750 WARN queue gstqueue.c:992:gst_queue_handle_sink_event:<queue0> error: streaming task paused, reason error (-5)
    Additional debug info:
    ../../../../gstreamer-1.8.3/libs/gst/base/gstbasesrc.c(2948): gst_base_src_loop (): /GstPipeline:pipeline0/GstV4l2Src:v4l2src0:
    streaming task paused, reason error (-5)
    Execution ended after 0:00:04.354055548
    Setting pipeline to PAUSED ...
    Setting pipeline to READY ...
    Setting pipeline to NULL ...
    Freeing pipeline ...
    root@am57xx-evm:~#

  • Hello,

    Could you try to increase cma in bootargs.
    You could set cma=64MiB in uEnv.txt file and verify when the board is booting this value is accepted.
    You could also check this chapter of the user guide:
    processors.wiki.ti.com/.../Linux_Core_VIP_User's_Guide
    and share the log files.

    BR
    Margarita
  • Hello,

    I’m assuming you were able to resolve your issue so I will close this thread.
    If not, just post a reply below or please open a new thread if this is locked.

    BR
    Margarita
  • thank you very much to help me solve this problem.

    sorry for forget mark
  • Hello,

    I am glad that this issue is solved.
    If you have further questions/issues please open a new thread.

    BR
    Margarita