La instalación de dkms v4l2loopback-dc/2.1.2 falla

La instalación de dkms v4l2loopback-dc/2.1.2 falla

Mientras actualizo mis paquetes de Archlinux con _ packman -Syu, veo que dkms no puede instalar los 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...

En el archivo de registro (traducido):

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

¿Es un error dentro del código fuente de v4l2loopback o son dependencias incorrectas? Gracias

Respuesta1

Esto se debe a la eliminación final de strlcpy()(considerado inseguro) en Linux 6.8.x después de que todos los usuarios del kernel cambiaron a strscpy(). Por lo general, los usuarios "externos" (módulos del kernel fuera del árbol) pueden demorarse un poco en dichos cambios.

cámara droidev4l2loopback-dcsolucionó este problema en la versión 2.1.3 con esta confirmación el 26 de marzo de 2024:

Versión 2.1.3

Utilice strscpy en lugar de strlcpy.
Linux 6.8 ha eliminado strlcpy.

Entonces tendrás que esperar que Archlinux elija la versión 2.1.3 o aplique laparchetú mismo.

información relacionada