
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-dc
corrigiu isso na versão 2.1.3 com este commit em 26/03/2024:
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.