Eu tenho um Alienware Aurora R7, rodando o Arch Linux. No desligamento, o kernel entra em pane, com algo parecido com isso na mensagem de pânico (omitindo os timestamps):
BUG: Unable to handle kernel NULL pointer dereference at (null)
IP: i2c_dw_isr+0x3ef/0x6d0
PGD 0 P4D 0
Oops: 0000 [#1] PREEMPT SMP PTI
De várias fontes ( 1 , 2 ), isso parece estar relacionado ao módulo i2c-designware-core
, e a solução é colocá-lo na lista negra . No entanto, com kernels recentes (parece ser 4,10 e acima), isso não parece ser construído como um módulo:
# uname -srv
Linux 4.15.2-2-ARCH #1 SMP PREEMPT Thu Feb 8 18:54:52 UTC 2018
# zgrep DESIGNWARE /proc/config.gz
CONFIG_I2C_DESIGNWARE_CORE=y
CONFIG_I2C_DESIGNWARE_PLATFORM=y
CONFIG_I2C_DESIGNWARE_SLAVE=y
CONFIG_I2C_DESIGNWARE_PCI=m
CONFIG_I2C_DESIGNWARE_BAYTRAIL=y
CONFIG_SPI_DESIGNWARE=m
CONFIG_SND_DESIGNWARE_I2S=m
CONFIG_SND_DESIGNWARE_PCM=y
Por isso, recorri ao reinício do kernel em pânico:
# cat /proc/cmdline
root=UUID=e5018f7e-5838-4a47-b146-fc1614673356 rw initrd=/intel-ucode.img initrd=/initramfs-linux.img panic=10 sysrq_always_enabled=1 printk.devkmsg=on
(Os caminhos ímpares no /proc/cmdline
são porque eu inicializo diretamente do UEFI, com entradas criadas usando efibootmgr
. Os caminhos estão enraizados em /boot
, onde meu ESP está montado.)
Isso parece ser algo para touchpads, mas eu não tenho um touchpad e não recebo um. O que posso fazer para desativar essa coisa? Eu tenho que construir um kernel personalizado ?
Como linux-lts
também é mais recente que 4.10, (4.14, atualmente), parece não haver uma maneira fácil de instalar um kernel mais antigo, em que a lista negra pode, presumivelmente, funcionar.
Usar nolapic
como um parâmetro do kernel resolve o problema de pânico de desligamento, mas faz com que o sistema congele alguns minutos após a inicialização, então não posso usá-lo.