instalação do dkms v4l2loopback-dc/2.1.2 falha

instalação do dkms v4l2loopback-dc/2.1.2 falha

Ao atualizar meus pacotes Archlinux com _ packman -Syu, vejo que o dkms falha ao instalar módulos:

(11/23) Install DKMS modules
==> dkms install --no-depmod v4l2loopback-dc/2.1.2 -k 6.8.5-arch1-1
Error! Bad return status for module build on kernel: 6.8.5-arch1-1 (x86_64)
Consult /var/lib/dkms/v4l2loopback-dc/2.1.2/build/make.log for more information.
==> WARNING: `dkms install --no-depmod v4l2loopback-dc/2.1.2 -k 6.8.5-arch1-1' exited 10
==> dkms install --no-depmod v4l2loopback/0.13.1 -k 6.8.5-arch1-1
==> depmod 6.8.5-arch1-1
(12/23) Updating TeXLive filename database...

No arquivo de log (traduzido):

DKMS make.log for v4l2loopback-dc-2.1.2 for kernel 6.8.5-arch1-1 (x86_64)
Tue 16 Apr 2024 07:56:42 +03
make -C /lib/modules/6.8.5-arch1-1/build M=/var/lib/dkms/v4l2loopback-dc/2.1.2/build modules
make[1]: enter directory "/usr/lib/modules/6.8.5-arch1-1/build"
   CC [M] /var/lib/dkms/v4l2loopback-dc/2.1.2/build/v4l2loopback-dc.o
/var/lib/dkms/v4l2loopback-dc/2.1.2/build/v4l2loopback-dc.c: In the "vidioc_querycap" function:
/var/lib/dkms/v4l2loopback-dc/2.1.2/build/v4l2loopback-dc.c:622:3: error: implicit function declaration 'strlcpy'; did you mean "strscpy"? [-Werror=implicit-function-declaration]
   622 | strlcpy(cap->driver, "Droidcam", sizeof(cap->driver));
       | ^~~~~~~
       | strscpy
cc1: some warnings are considered errors
make[3]: *** [scripts/Makefile.build:243: /var/lib/dkms/v4l2loopback-dc/2.1.2/build/v4l2loopback-dc.o] Error 1
make[2]: *** [/usr/lib/modules/6.8.5-arch1-1/build/Makefile:1921: /var/lib/dkms/v4l2loopback-dc/2.1.2/build] Error 2
make[1]: *** [Makefile:240: __sub-make] Error 2
make[1]: exit from the directory "/usr/lib/modules/6.8.5-arch1-1/build"
make: *** [Makefile:8: all] Error 2

É um bug dentro do código-fonte do v4l2loopback ou são dependências erradas? Obrigado

Responder1

Isso é causado pela remoção final de strlcpy()(considerado inseguro) no Linux 6.8.x depois que todos os usuários do kernel mudaram para o strscpy(). Normalmente, usuários "externos" (módulos de kernel fora da árvore) podem demorar um pouco para tais mudanças.

Droidcam'sv4l2loopback-dccorrigiu isso na versão 2.1.3 com este commit em 26/03/2024:

Versão 2.1.3

Use strscpy em vez de strlcpy.
Linux 6.8 removeu strlcpy.

Então você terá que esperar que o Archlinux escolha a versão 2.1.3 ou aplicar ocorreçãovocê mesmo.

informação relacionada