AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / unix / Perguntas / 512759
Accepted
kagmole
kagmole
Asked: 2019-04-17 04:25:37 +0800 CST2019-04-17 04:25:37 +0800 CST 2019-04-17 04:25:37 +0800 CST

Vários /dev/video para um dispositivo físico

  • 772

Primeiro algumas especificações: meu computador é um HP EliteBook 8460p. Ele vem com uma webcam Chicony HP HD integrada.

Meu problema é que muitos aplicativos (bem, pelo menos Skype e guvcview) estão exibindo várias linhas para a mesma webcam; na verdade, se eu fizer isso ls -l /dev | grep video, recebo o seguinte:

crw-rw----  1 root video      29,   0 Apr 16 08:13 fb0
crw-rw----  1 root video     243,   0 Apr 16 08:13 media0
crw-rw----+ 1 root video      81,   0 Apr 16 08:13 video0
crw-rw----+ 1 root video      81,   1 Apr 16 08:13 video1

Tenho 2 /dev/video[n]com apenas uma webcam (integrada); O Skype funcionará corretamente com /dev/video0, mas não com /dev/video1. O mesmo para guvcview.

Se eu conectar outra webcam USB, por exemplo, uma da Logitech, recebo o seguinte dmesg:

[21222.638802] usb 2-2: new high-speed USB device number 20 using xhci_hcd
[21222.970684] usb 2-2: New USB device found, idVendor=046d, idProduct=08c2, bcdDevice= 0.05
[21222.970755] usb 2-2: New USB device strings: Mfr=0, Product=0, SerialNumber=0
[21222.972518] uvcvideo: Found UVC 1.00 device <unnamed> (046d:08c2)
[21226.044535] uvcvideo 2-2:1.0: Entity type for entity Extension 4 was not initialized!
[21226.044538] uvcvideo 2-2:1.0: Entity type for entity Extension 8 was not initialized!
[21226.044540] uvcvideo 2-2:1.0: Entity type for entity Extension 10 was not initialized!
[21226.044541] uvcvideo 2-2:1.0: Entity type for entity Extension 9 was not initialized!
[21226.044543] uvcvideo 2-2:1.0: Entity type for entity Extension 3 was not initialized!
[21226.044545] uvcvideo 2-2:1.0: Entity type for entity Processing 2 was not initialized!
[21226.044547] uvcvideo 2-2:1.0: Entity type for entity Camera 1 was not initialized!
[21226.044746] input: UVC Camera (046d:08c2) as /devices/pci0000:00/0000:00:1c.7/0000:25:00.0/usb2/2-2/2-2:1.0/input/input35
[21226.137559] usb 2-2: Warning! Unlikely big volume range (=3072), cval->res is probably wrong.
[21226.137569] usb 2-2: [5] FU [Mic Capture Volume] ch = 1, val = 4608/7680/1

E o seguinte com ls -l /dev/ | grep video:

crw-rw----  1 root video      29,   0 Apr 16 08:13 fb0
crw-rw----  1 root video     243,   0 Apr 16 08:13 media0
crw-rw----  1 root video     243,   1 Apr 16 14:06 media1
crw-rw----+ 1 root video      81,   0 Apr 16 08:13 video0
crw-rw----+ 1 root video      81,   1 Apr 16 08:13 video1
crw-rw----+ 1 root video      81,   2 Apr 16 14:06 video2
crw-rw----+ 1 root video      81,   3 Apr 16 14:06 video3

3 novas entradas: /dev/media1, /dev/video2e /dev/video3.

Até encontrei uma webcam Sony (CEVCECM) que soma até 4 novos dispositivos. Os dmesgregistros:

[21927.665747] usb 2-2: new high-speed USB device number 23 using xhci_hcd
[21927.817330] usb 2-2: New USB device found, idVendor=05e3, idProduct=0608, bcdDevice= 9.01
[21927.817339] usb 2-2: New USB device strings: Mfr=0, Product=1, SerialNumber=0
[21927.817343] usb 2-2: Product: USB2.0 Hub
[21927.824119] hub 2-2:1.0: USB hub found
[21927.824814] hub 2-2:1.0: 4 ports detected
[21928.113733] usb 2-2.4: new high-speed USB device number 24 using xhci_hcd
[21928.223184] usb 2-2.4: New USB device found, idVendor=054c, idProduct=097b, bcdDevice=21.12
[21928.223192] usb 2-2.4: New USB device strings: Mfr=1, Product=2, SerialNumber=3
[21928.223197] usb 2-2.4: Product: CEVCECM
[21928.223201] usb 2-2.4: Manufacturer: Sony
[21928.223206] usb 2-2.4: SerialNumber: DHZD10412EUHK1
[21928.227506] uvcvideo: Found UVC 1.00 device CEVCECM (054c:097b)
[21928.242592] uvcvideo: Unable to create debugfs 2-24 directory.
[21928.242780] uvcvideo 2-2.4:1.0: Entity type for entity Extension 7 was not initialized!
[21928.242783] uvcvideo 2-2.4:1.0: Entity type for entity Extension 3 was not initialized!
[21928.242785] uvcvideo 2-2.4:1.0: Entity type for entity Processing 2 was not initialized!
[21928.242787] uvcvideo 2-2.4:1.0: Entity type for entity Camera 1 was not initialized!
[21928.242877] input: CEVCECM: CEVCECM as /devices/pci0000:00/0000:00:1c.7/0000:25:00.0/usb2/2-2/2-2.4/2-2.4:1.0/input/input38

E os arquivos de dispositivo resultantes com ls -l /dev | grep video:

crw-rw----  1 root video      29,   0 Apr 16 08:13 fb0
crw-rw----  1 root video     243,   0 Apr 16 08:13 media0
crw-rw----  1 root video     243,   1 Apr 16 14:18 media1
crw-rw----+ 1 root video      81,   0 Apr 16 08:13 video0
crw-rw----+ 1 root video      81,   1 Apr 16 08:13 video1
crw-rw----+ 1 root video      81,   2 Apr 16 14:18 video2
crw-rw----+ 1 root video      81,   3 Apr 16 14:18 video3
crw-rw----+ 1 root video      81,   4 Apr 16 14:18 video4
crw-rw----+ 1 root video      81,   5 Apr 16 14:18 video5

5 novas entradas: /dev/media1e /dev/video2para /dev/video5.

Eu sinto que os arquivos corretos a serem usados ​​são os /dev/media[n]únicos, mas o Skype e o guvcview de alguma forma não conseguem fazê-lo e fazem fallback para o arquivo /dev/video[n].

Eu não tenho esse problema com o Webcamoid, por exemplo.

Se alguém tiver uma ideia, eu aceito. Enquanto isso vou continuar a investigação...

--- Editado em 14-05-2019 ---

Obteve algumas informações interessantes usando v4l2-ctl --device=/dev/video* --all. Para a webcam Chicony HP HD, seus 2 arquivos de dispositivo têm recursos de dispositivo diferentes:

# Devices capabilities for /dev/video0
Video Capture
Streaming
Extended Pix Format

# Devices capabilities for /dev/video1
Metadata Capture
Streaming
Extended Pix Format

Obtenho resultados semelhantes para as webcams USB. Então, afinal, talvez o que o Skype e o guvcview não consigam fazer seja apenas listar os dispositivos de vídeo que suportam a Video Capturecapacidade do dispositivo.

video devices
  • 2 2 respostas
  • 16356 Views

2 respostas

  • Voted
  1. Best Answer
    James Henstridge
    2019-09-08T19:39:48+08:002019-09-08T19:39:48+08:00

    O segundo dispositivo fornece metadados sobre os dados de vídeo do primeiro dispositivo. Os novos dispositivos foram introduzidos por este patch:

    https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=088ead25524583e2200aa99111bea2f66a86545a

    Mais informações sobre a interface de metadados V4L podem ser encontradas aqui:

    https://linuxtv.org/downloads/v4l-dvb-apis/uapi/v4l/dev-meta.html

    Para dispositivos de classe de vídeo USB comuns, isso geralmente apenas fornece informações de carimbo de data e hora mais precisas . Para câmeras como a linha RealSense da Intel, forneça uma gama mais ampla de dados sobre como a imagem foi capturada .

    Presumivelmente, esses dados foram divididos em um nó de dispositivo separado porque não podiam ser entregues facilmente no nó de dispositivo primário de maneira compatível. No entanto, é um pouco trabalhoso, pois (a) aplicativos que não se preocupam com esses metadados agora precisam filtrar os dispositivos extras e (b) aplicativos que se preocupam com os metadados precisam de uma maneira de unir os dois dispositivos .

    • 24
  2. hubert
    2020-04-23T09:53:42+08:002020-04-23T09:53:42+08:00

    Realmente irritante, mas acabou de encontrar uma solução: deixe o udev atribuir links simbólicos para nós de dispositivo apenas para as câmeras "reais", não para os metadados. Eles são idênticos (?) ao udev, ou seja,

    udevadm info -n /dev/video0é o "mesmo" que udevadm info -n /dev/video1, mas eles obtêm um ATTR{index} diferente. Então, para minhas 2 câmeras, acabei com o seguinte /etc/udev/rules.d/99-cam.rules:

    SUBSYSTEM=="video4linux", ATTRS{idVendor}=="eb1a", ATTRS{idProduct}=="299f", ATTR{index}=="0", MODE="0664", GROUP="video", SYMLINK+="cams/cam1"
    
    SUBSYSTEM=="video4linux", ATTRS{idVendor}=="1908", ATTRS{idProduct}=="2311", ATTR{index}=="0", MODE="0664", GROUP="video", SYMLINK+="cams/cam2"
    

    Depois disso é só usar /dev/cams/camXna sua aplicação ao invés do/dev/videoY

    • 6

relate perguntas

  • Reproduzindo pdf com animações incorporadas

  • H.264/MPEG-4 de quadros PNG: como fazer e como ajustar a compressão

  • Usar /dev/ramX como seus dispositivos especiais correspondentes?

  • Como escrever em um dispositivo especial de caractere?

  • Gire a webcam e a tela (modo retrato)

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve