[Cin] ms2130 HDMI-USB3 UHD capture card - not quite as expected?
Andrew Randrianasulu
randrianasulu at gmail.com
Sat Feb 25 21:30:31 CET 2023
сб, 25 февр. 2023 г., 23:25 Terje J. Hanssen <terjejhanssen at gmail.com>:
>
>
> Den 25.02.2023 19:27, skrev Andrew Randrianasulu:
>
>
>
> сб, 25 февр. 2023 г., 21:19 Terje J. Hanssen via Cin <
> cin at lists.cinelerra-gg.org>:
>
>> So I have received the ms2130 HDMI-USB3 capture card.
>> The A/D AV converter & SV-HDMI/adapter is not received so far, and I have
>> not avialable my HDV camcorder (on service) to output HDMI video stream
>> with.
>>
>> Yet, I have initially run some verification tests on the ms2130 HDMI-USB3
>> UHD capture card alone, for what they are worth.
>>
>> As "UHD" (and/or USB3) is mostly generic used to identify this card
>> (while ms2130 almost not), the some output is piped and stripped with grep
>> "UHD".
>>
>> ----------------
>>
>> dmesg | grep UHD
>> [ 2.798210] usb 2-5: Product: USB3.0 UHD
>> [ 2.827772] hid-generic 0003:345F:2130.0005: hiddev97,hidraw4: USB HID
>> v1.10 Device [MACROSILICON USB3.0 UHD] on usb-0000:00:14.0-5/input4
>> [ 4.805554] usb 2-5: Found UVC 1.00 device USB3.0 UHD (345f:2130)
>>
>>
>> udevadm info /dev/video* | egrep 'DEVNAME|ID_V4L_PRODUCT'
>> E: DEVNAME=/dev/video0
>> E: ID_V4L_PRODUCT=USB 2.0 Camera: HD 720P Webcam
>> E: DEVNAME=/dev/video1
>> E: ID_V4L_PRODUCT=USB 2.0 Camera: HD 720P Webcam
>> E: DEVNAME=/dev/video2
>> E: ID_V4L_PRODUCT=USB3.0 UHD: USB3.0 UHD
>> E: DEVNAME=/dev/video3
>> E: ID_V4L_PRODUCT=USB3.0 UHD: USB3.0 UHD
>>
>>
>> udevadm info /dev/video* | egrep UHD
>> S: v4l/by-id/usb-MACROSILICON_USB3.0_UHD_20210623-video-index0
>> E: ID_V4L_PRODUCT=USB3.0 UHD: USB3.0 UHD
>> E: ID_MODEL=USB3.0_UHD
>> E: ID_MODEL_ENC=USB3.0\x20UHD
>> E: ID_SERIAL=MACROSILICON_USB3.0_UHD_20210623
>> E:
>> DEVLINKS=/dev/v4l/by-id/usb-MACROSILICON_USB3.0_UHD_20210623-video-index0
>> /dev/v4l/by-path/pci-0000:00:14.0-usb-0:5:1.0-video-index0
>> S: v4l/by-id/usb-MACROSILICON_USB3.0_UHD_20210623-video-index1
>> E: ID_V4L_PRODUCT=USB3.0 UHD: USB3.0 UHD
>> E: ID_MODEL=USB3.0_UHD
>> E: ID_MODEL_ENC=USB3.0\x20UHD
>> E: ID_SERIAL=MACROSILICON_USB3.0_UHD_20210623
>> E: DEVLINKS=/dev/v4l/by-path/pci-0000:00:14.0-usb-0:5:1.0-video-index1
>> /dev/v4l/by-id/usb-MACROSILICON_USB3.0_UHD_20210623-video-index1
>>
>>
>> lsusb | grep UHD
>> Bus 002 Device 004: ID 345f:2130 MACROSILICON USB3.0 UHD
>>
>> cat /proc/asound/cards | grep UHD
>> 2 [UHD ]: USB-Audio - USB3.0 UHD
>> MACROSILICON USB3.0 UHD at usb-0000:00:14.0-5,
>> super speed
>>
>> ll /dev/video*
>> crw-rw----+ 1 root video 81, 0 feb. 25 14:15 /dev/video0
>> crw-rw----+ 1 root video 81, 1 feb. 25 14:15 /dev/video1
>> crw-rw----+ 1 root video 81, 2 feb. 25 14:15 /dev/video2
>> crw-rw----+ 1 root video 81, 3 feb. 25 14:15 /dev/video3
>>
>> ---------------------
>>
>> v4l2-ctl --list-devices
>> USB 2.0 Camera: HD 720P Webcam (usb-0000:00:14.0-11):
>> /dev/video0
>> /dev/video1
>>
>> USB3.0 UHD: USB3.0 UHD (usb-0000:00:14.0-5):
>> /dev/video2
>> /dev/video3
>>
>> -----------
>>
>> v4l2-ctl --list-formats-ext
>> ioctl: VIDIOC_ENUM_FMT
>> Index : 0
>> Type : Video Capture
>> Pixel Format: 'YUYV'
>> Name : YUYV 4:2:2
>> Size: Discrete 640x480
>> Interval: Discrete 0.030s (33.000 fps)
>> Interval: Discrete 0.067s (15.000 fps)
>> Size: Discrete 1280x720
>> Interval: Discrete 0.100s (10.000 fps)
>> Size: Discrete 640x360
>> Interval: Discrete 0.030s (33.000 fps)
>> Interval: Discrete 0.067s (15.000 fps)
>> ................
>> Index : 1
>> Type : Video Capture
>> Pixel Format: 'MJPG' (compressed)
>> Name : Motion-JPEG
>> Size: Discrete 640x480
>> Interval: Discrete 0.030s (33.000 fps)
>> Interval: Discrete 0.067s (15.000 fps)
>> Size: Discrete 1280x720
>> Interval: Discrete 0.030s (33.000 fps)
>> Interval: Discrete 0.067s (15.000 fps)
>> Size: Discrete 640x360
>> Interval: Discrete 0.030s (33.000 fps)
>> Interval: Discrete 0.067s (15.000 fps)
>> ......................
>>
>>
>>
>> As the above doesn't list any 1920x1080 resolution, I wonder if it list
>> just format for the usb2 webcam and not for ms2130 capture card?
>>
>
>
> Yeah, looking at how webcam listed first it makes sense. Try to instruct
> v4l2-ctl to use another device? (my guess it will be "-d" switch but I can
> be wrong! Manyal or "--help" output is better guide ..)
>
>
> Be aware that "v4l2-ctl --list-formats-ext" was the same (I think) as used
> for the previous ms2109 Hama card, and I thought formats for all connected
> devices were listed then.
> Obviously there is a default (or first device) used, when no device is
> specified, so thank you for the tip.
>
> By help of google and "superuser" I found out that actually both "-D -d
> /dev/video2" are needed to get both frame sizes and fps listed:
>
> v4l2-ctl -D -d /dev/video2 --list-formats-ext
> Driver Info (not using libv4l2):
> Driver name : uvcvideo
> Card type : USB3.0 UHD: USB3.0 UHD
> Bus info : usb-0000:00:14.0-5
> Driver version: 5.14.21
> Capabilities : 0x84A00001
> Video Capture
> Metadata Capture
> Streaming
> Extended Pix Format
> Device Capabilities
> Device Caps : 0x04200001
> Video Capture
> Streaming
> Extended Pix Format
> ioctl: VIDIOC_ENUM_FMT
> Index : 0
> Type : Video Capture
> Pixel Format: 'YUYV'
> Name : YUYV 4:2:2
> Size: Discrete 1920x1080
> Interval: Discrete 0.017s (60.000 fps)
> Interval: Discrete 0.020s (50.000 fps)
> Interval: Discrete 0.033s (30.000 fps)
> Interval: Discrete 0.050s (20.000 fps)
> Interval: Discrete 0.100s (10.000 fps)
> ............
>
> Size: Discrete 1280x720
> Interval: Discrete 0.017s (60.000 fps)
> Interval: Discrete 0.020s (50.000 fps)
> Interval: Discrete 0.033s (30.000 fps)
> Interval: Discrete 0.050s (20.000 fps)
> Interval: Discrete 0.100s (10.000 fps)
> ...............
>
> Size: Discrete 720x576
> Interval: Discrete 0.017s (60.000 fps)
> Interval: Discrete 0.020s (50.000 fps)
> Interval: Discrete 0.033s (30.000 fps)
> Interval: Discrete 0.050s (20.000 fps)
> Interval: Discrete 0.100s (10.000 fps)
> ................
>
>
>
>
> -------------------------------------
>>
>> Try also ffplay to list supported formats for a video4linux2 device:
>>
>> ffplay -hide_banner -f v4l2 -list_formats all /dev/video2
>> [video4linux2,v4l2 @ 0x7f8280000cc0] Raw : yuyv422 :
>> YUYV 4:2:2 : 1920x1080 1600x1200 1360x768 1280x1024 1280x960 1280x720
>> 1024x768 800x600 720x576 720x480 640x480
>> /dev/video2: Immediate exit requested
>> nan : 0.000 fd= 0 aq= 0KB vq= 0KB sq= 0B f=0/0
>>
>>
>
> this one at least list all formats but not their framerates ...
>
>>
>>
>>
>> ffplay -hide_banner -f v4l2 -list_formats all /dev/video3
>> [video4linux2,v4l2 @ 0x7f3bd0000cc0] ioctl(VIDIOC_G_INPUT): Inappropriate
>> ioctl for device
>> /dev/video3: Inappropriate ioctl for device
>>
>>
>> -------------
>>
>> I am not sure about what the following command really does, but it was
>> described to
>>
>> "Grab and record the input of a video4linux2 device, leave the frame rate
>> and size as previously set:"
>>
>> ffmpeg -hide_banner -f v4l2 -input_format yuyv422 -i /dev/video2
>> out_test.mpeg
>>
>> [video4linux2,v4l2 @ 0x55c22212cfc0] Dequeued v4l2 buffer contains
>> corrupted data (0 bytes).
>> Input #0, video4linux2,v4l2, from '/dev/video2':
>> Duration: N/A, start: 0.000000, bitrate: 1990656 kb/s
>> Stream #0:0: Video: rawvideo (YUY2 / 0x32595559), yuyv422, 1920x1080,
>> 1990656 kb/s, 60 fps, 60 tbr, 1000k tbn
>> Stream mapping:
>> Stream #0:0 -> #0:0 (rawvideo (native) -> mpeg1video (native))
>> Press [q] to stop, [?] for help
>> [video4linux2,v4l2 @ 0x55c22212cfc0] Dequeued v4l2 buffer contains
>> corrupted data (0 bytes).
>> Last message repeated 30 times
>> [mpeg @ 0x55c22214f800] VBV buffer size not set, using default size of
>> 230KB
>> If you want the mpeg file to be compliant to some specification
>> Like DVD, VCD or others, make sure you set the correct buffer size
>> Output #0, mpeg, to 'out_test.mpeg':
>> Metadata:
>> encoder : Lavf59.27.100
>> Stream #0:0: Video: mpeg1video, yuv420p(tv, progressive), 1920x1080,
>> q=2-31, 200 kb/s, 60 fps, 90k tbn
>> Metadata:
>> encoder : Lavc59.37.100 mpeg1video
>> Side data:
>> cpb: bitrate max/min/avg: 0/0/200000 buffer size: 0 vbv_delay: N/A
>> frame= 1628 fps= 60 q=2.0 Lsize= 4702kB time=03:13:19.68 bitrate=
>> 3.3kbits/s speed= 427x
>> video:4675kB audio:0kB subtitle:0kB other streams:0kB global headers:0kB
>> muxing overhead: 0.572162%
>> Exiting normally, received signal 2.
>>
>>
>
> try 30 fps instead of 60?
>
>
> Like this?
> But shouldn't a 422 and not a 420 output format be created?
>
it seems in some cases ffmpeg not geared towards preserving most
information, just picks up most commonly defined/first pixel format. Try
mpeg2video as output codec, and/or specify pixel format (pix_fmt)
more explicitly before output's filename? Also you can try 'copy' video
codec and meet absolutely enormous test file.
>
> ffmpeg -hide_banner -f v4l2 -input_format yuyv422 -video_size 1920x1080
> -framerate 30 -t 10 -i /dev/video2 out_1920x1024.mpeg
> [video4linux2,v4l2 @ 0x564d7d7c3040] Dequeued v4l2 buffer contains
> corrupted data (0 bytes).
> Input #0, video4linux2,v4l2, from '/dev/video2':
> Duration: N/A, start: 0.000000, bitrate: 995328 kb/s
> Stream #0:0: Video: rawvideo (YUY2 / 0x32595559), yuyv422, 1920x1080,
> 995328 kb/s, 30 fps, 30 tbr, 1000k tbn
> Stream mapping:
> Stream #0:0 -> #0:0 (rawvideo (native) -> mpeg1video (native))
> Press [q] to stop, [?] for help
> [video4linux2,v4l2 @ 0x564d7d7c3040] Dequeued v4l2 buffer contains
> corrupted data (0 bytes).
> Last message repeated 30 times
> [mpeg @ 0x564d7d7e5a80] VBV buffer size not set, using default size of
> 230KB
> If you want the mpeg file to be compliant to some specification
> Like DVD, VCD or others, make sure you set the correct buffer size
> Output #0, mpeg, to 'out_1920x1024.mpeg':
> Metadata:
> encoder : Lavf59.27.100
> Stream #0:0: Video: mpeg1video, yuv420p(tv, progressive), 1920x1080,
> q=2-31, 200 kb/s, 30 fps, 90k tbn
> Metadata:
> encoder : Lavc59.37.100 mpeg1video
> Side data:
> cpb: bitrate max/min/avg: 0/0/200000 buffer size: 0 vbv_delay: N/A
> frame= 301 fps= 30 q=1.6 Lsize= 896kB time=06:56:05.30 bitrate=
> 0.3kbits/s speed=2.47e+03x
> video:890kB audio:0kB subtitle:0kB other streams:0kB global headers:0kB
> muxing overhead: 0.710403%
>
> -----------
> ffprobe -hide_banner out_1920x1024.mpeg
> Input #0, mpeg, from 'out_1920x1024.mpeg':
> Duration: 00:00:10.03, start: 24955.333333, bitrate: 731 kb/s
> Stream #0:0[0x1e0]: Video: mpeg1video, yuv420p(tv), 1920x1080 [SAR 1:1
> DAR 16:9], 104857 kb/s, 30 fps, 30 tbr, 90k tbn
>
> ------------
> mediainfo out_1920x1024.mpeg
> General
> Complete name : out_1920x1024.mpeg
> Format : MPEG-PS
> File size : 896 KiB
> Duration : 10 s 33 ms
> Overall bit rate mode : Variable
> Overall bit rate : 732 kb/s
>
> Video
> ID : 224 (0xE0)
> Format : MPEG Video
> Format version : Version 1
> Format settings, BVOP : No
> Format settings, Matrix : Default
> Format settings, GOP : N=12
> Duration : 10 s 33 ms
> Bit rate mode : Variable
> Bit rate : 717 kb/s
> Width : 1 920 pixels
> Height : 1 080 pixels
> Display aspect ratio : 16:9
> Frame rate : 30.000 FPS
> Color space : YUV
> Chroma subsampling : 4:2:0
> Bit depth : 8 bits
> Scan type : Progressive
> Compression mode : Lossy
> Bits/(Pixel*Frame) : 0.012
> Time code of first frame : 00:00:00:00
> Time code source : Group of pictures header
> GOP, Open/Closed : Open
> GOP, Open/Closed of first frame : Closed
> Stream size : 878 KiB (98%)
>
>
>
>>
>>
>>
>> --
>> Cin mailing list
>> Cin at lists.cinelerra-gg.org
>> https://lists.cinelerra-gg.org/mailman/listinfo/cin
>>
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.cinelerra-gg.org/pipermail/cin/attachments/20230225/7526b050/attachment-0001.htm>
More information about the Cin
mailing list