O VirtualBox não inicia após a atualização do kernel

15

Ontem recebi uma atualização do kernel e após a reinicialização, o VirtualBox parou de funcionar.

Aqui estão as informações do meu sistema (após a atualização do kernel):

matteo@workstation:~$ cat /etc/lsb-release 
DISTRIB_ID=Ubuntu
DISTRIB_RELEASE=16.04
DISTRIB_CODENAME=xenial
DISTRIB_DESCRIPTION="Ubuntu 16.04.3 LTS"
matteo@workstation:~$ uname -a
Linux workstation 4.4.0-116-generic #140-Ubuntu SMP Mon Feb 12 21:23:04 UTC 2018 x86_64 x86_64 x86_64 GNU/Linux

Eu instalei o VirtualBox há muito tempo com

sudo apt install linux-headers-$(uname -r)
sudo apt install virtualbox-dkms virtualbox virtualbox-qt

usado diariamente e nunca teve problemas com as atualizações do kernel. O erro que recebo agora é

matteo@workstation:~$ sudo modprobe vboxdrv
modprobe: ERROR: could not insert 'vboxdrv': Exec format error
matteo@workstation:~$ dmesg | tail -n 1
[ 1413.167311] vboxdrv: version magic '4.4.0-116-generic SMP mod_unload modversions ' should be '4.4.0-116-generic SMP mod_unload modversions retpoline '

Encontrei uma postagem no fórum com esta mensagem de erro aqui de três dias atrás, infelizmente sem resolução. Por isso, tentei remover os pacotes do VirtualBox do repositório Ubuntu e instalar a versão 5.2 mais recente usando este procedimento . No entanto, mesmo após a reinicialização da máquina, o erro permanece.

O que posso fazer neste caso?

amadurecer
fonte
Isso também está acontecendo com outros módulos (por exemplo, bugs.launchpad.net/ubuntu/+source/xorg/+bug/1750937 e answers.launchpad.net/ubuntu/+question/664826 )
ricab
2
Uma solução alternativa no momento é carregar o kernel anterior (4.4.0-112) no grub.
Ricab
Para aqueles que se perguntam como executar a sugestão do @ricab: simplesmente segure shiftdurante a inicialização, selecione "Opções avançadas para Ubuntu" e selecione uma versão mais antiga do kernel no menu, conforme explicado aqui . Posso confirmar que minha versão anterior do kernel (4.4.0-112) não tem o problema descrito na pergunta, portanto, essa é uma solução viável até que uma solução seja lançada.
matpen
No 16.04 é a Escchave.
D.Bugger
@ D.Bugger no meu 16.04 shiftfunciona. Não é o meu caso, mas já li que algumas pessoas fazem com que funcione apenas com "turno à direita" ou "turno à esquerda".
matpen

Respostas:

9

Eu estava enfrentando o mesmo problema. Após a atualização do kernel, minha versão do gcc estava aparecendo como 5.4.1. O downgrade dessa versão para a 5.4.0 me ajudou a ter o retpoline para o módulo do kernel do vboxdrv.

As etapas a seguir neste link me ajudaram a resolver meu problema:

sudo apt-get install ppa-purge
sudo ppa-purge ppa:ubuntu-toolchain-r/test
#Select gcc version 5 using update-alternatives manually
sudo update-alternatives --config gcc

Após estas etapas, o gcc --version deve ser (Ubuntu 5.4.0-6ubuntu1 ~ 16.04.9) 5.4.0 20160609

Em seguida, limpe todos os novos cabeçalhos linux (4.4.0-116)

sudo apt-get purge linux-headers-4.4.0-116 linux-headers-4.4.0-116-generic linux-image-4.4.0-116-generic linux-image-extra-4.4.0-116-generic linux-signed-image-4.4.0-116-generic

Novamente instale-os

sudo apt-get install linux-generic linux-signed-generic

Em seguida, reinstale o virtualbox, instalei o mais recente virtualbox-5.2 desta vez, mas a versão padrão do virtualbox 5.0 também deve funcionar bem.

sudo apt-get purge virtualbox-dkms virtualbox virtualbox-qt
sudo apt-get install virtualbox-5.2

E temos suporte a retpoline no módulo mais recente

anirudh@AHDRMD34579:~$ modinfo vboxdrv 
filename:       /lib/modules/4.4.0-116-generic/misc/vboxdrv.ko
version:        5.2.6 r120293 (0x00290000)
license:        GPL
description:    Oracle VM VirtualBox Support Driver
author:         Oracle Corporation
srcversion:     4880B21EFF1B605D6402982
depends:        
vermagic:       4.4.0-116-generic SMP mod_unload modversions retpoline 
parm:           force_async_tsc:force the asynchronous TSC mode (int)
Anirudh Gupta
fonte
Excelente trabalho me ajudou depois de seis meses sem acesso a minhas máquinas
George Udosen
QUERO DAR-LHE TODOS OS PONTOS DO MUNDO !!!!! :-) Mas só posso te votar uma vez, infelizmente.
shawty
4

O problema relacionado listado no comentário do @ricab foi atribuído a um problema com o novo kernel, exigindo um certo nível de versão do gcc para compilar com êxito os módulos do kernel.

No meu sistema, a atualização do gcc foi enviada APÓS a atualização do kernel, causando falha nas recompilações.

Depois que a causa raiz foi descoberta, consegui consertar o sistema desinstalando e reinstalando o novo kernel. Isso corrigiu meus drivers gráficos, mas tive que emitir um problema sudo /sbin/vboxconfigpara corrigir o virtualbox após a inicialização no novo kernel.

Meu sistema é 14.04, portanto, não posso aconselhá-lo sobre a versão correta do gcc para o seu sistema 16.04, mas isso é discutido em https://bugs.launchpad.net/ubuntu/+source/xorg/+bug/1750937

Mármore orgânico
fonte
Obrigado pelo link. Infelizmente, não parece funcionar no meu caso para o Xenail (e não estou sozinho ). Não recebi nenhuma atualização do gcc recentemente, mas já estou ligado gcc 5.4.1e até tentei gcc 7.2.0.
matpen
@ jfs certo, no entanto eu preciso do ppa gcc, então não posso testar agora.
matpen
-1

Eu também tive esse problema recentemente e postei uma pergunta aqui sobre ele. Eu fiz algumas escavações e este é realmente um problema conhecido.

O relatório de erros está no meu link.

De repente, o Virtualbox parou de funcionar

Eu acho que o consenso geral é inicializar no kernel 4.4 até que o problema seja corrigido. (É certamente a solução mais fácil para mim.)

chapeleiro
fonte
11
Se sua resposta for essencialmente uma referência a outra pergunta, seria melhor sinalizá- la como uma duplicata da outra depois que você ganhar 15 reputação . Se você tem reputação, não se esqueça de votar nas respostas que você achou úteis!
David Foerster
Entendido. Vai fazer.
Hatterman