当 I2C Designware 未构建为模块时,如何禁用 I2C Designware 支持?

当 I2C Designware 未构建为模块时,如何禁用 I2C Designware 支持?

我有一台 Alienware Aurora R7,运行 Arch Linux。关闭时,内核会发生恐慌,恐慌消息中会出现类似以下内容(省略时间戳):

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

来自各种来源(1,2),这似乎与模块有关i2c-designware-core,解决方法是将其列入黑名单。然而,对于最近的内核(似乎是 4.10 及更高版本),这似乎没有构建为模块:

# 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

所以我采取了让内核在恐慌时重新启动的方法:

# 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

( 中的奇怪路径/proc/cmdline是因为我直接从 UEFI 启动,并使用 . 创建的条目efibootmgr。路径的根目录为/boot,我的 ESP 就安装在此处。)

这似乎是触摸板的东西,但我没有触摸板,也不会买。我该怎么做才能禁用这个东西?我一定要吗构建自定义内核

由于linux-lts它也比 4.10(目前为 4.14)更新,因此似乎也没有一种简单的方法来安装较旧的内核,而黑名单可能会起作用。


用作nolapic内核参数解决了关机恐慌问题,但它会导致系统在启动后冻结几分钟,因此我无法使用它。

答案1

在阅读内核源代码后,我发现了一个我们需要列入黑名单的函数!

谢谢斯蒂芬·基特关于 的提示initcall_blacklist

添加initcall_blacklist=dw_i2c_init_driver到内核命令行。这对我在内核 4.15.0 上有效。

对于任何其他能找到这个答案的人。您可以通过编辑来做到这一点/etc/default/grub

  1. 在终端中运行:sudo -H gedit /etc/default/grub
  2. 将黑名单字符串附加到GRUB_CMDLINE_LINUX_DEFAULT: GRUB_CMDLINE_LINUX_DEFAULT="… initcall_blacklist=dw_i2c_init_driver"
  3. 保存文件,关闭编辑器。
  4. 在终端中运行:sudo update-grub
  5. 重启并测试!

答案2

添加initcall_blacklist=i2c_dw_init_master到内核命令行应该会阻止 Designware 驱动程序在引导期间初始化,并完全避免该问题。

内核参数的非常简短的描述initcall_blacklist,和补丁周围的线了解更多有用的背景信息。

答案3

尝试了各种关闭方法,似乎将 Linux 引导到poweroff使用systemd.unit=poweroff.target内核参数的目标可以正常关闭。

因此,当我等待更好的解决方案时,我添加了一个简单关闭的启动项。这很容易GRUB(大概还有其他引导加载程序),但我无法找到一种方法让 UEFI 本身简单地关闭。而且 Alienware 的 UEFI 实现似乎不支持同一文件的多个条目,因此我最终复制vmlinuz-linux并添加了副本的条目:

cp /boot/vmlinuz-linux /boot/vmlinuz-shutdown
cp /boot/initramfs-linux.img /boot/initramfs-shutdown.img
kernel_opts="root=UUID=e5018f7e-5838-4a47-b146-fc1614673356 ro initrd=/initramfs-shutdown.img systemd.unit=poweroff.target"
efibootmgr --disk /dev/nvme0n1 --part 1 --create --gpt --label "Shutdown" --loader /vmlinuz-shutdown --unicode "$kernel_opts"

这里的磁盘和分区选项特定于我的系统。此处创建的启动条目已编号0001,因此需要一个off脚本来进行干净的关闭:

#! /bin/sh
sudo efibootmgr -n 0001
reboot

可能有一种更简单的方法来设置 UEFI 关闭目标。

相关内容