AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 423797
Accepted
muru
muru
Asked: 2018-02-14 02:43:09 +0800 CST2018-02-14 02:43:09 +0800 CST 2018-02-14 02:43:09 +0800 CST

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

  • 772

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

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。路径植根于/bootESP 安装的位置。)

这似乎是触摸板的东西,但我没有触摸板,也不会得到。我能做些什么来禁用这个东西?我必须构建自定义内核吗?

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


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

linux arch-linux
  • 3 3 个回答
  • 8080 Views

3 个回答

  • Voted
  1. Best Answer
    Yurij
    2018-05-31T05:25:33+08:002018-05-31T05:25:33+08:00

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

    感谢Stephen Kitt的提示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. 重启并测试!
    • 14
  2. Stephen Kitt
    2018-02-14T03:00:24+08:002018-02-14T03:00:24+08:00

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

    请参阅内核参数以获得非常简短的描述initcall_blacklist,以及补丁周围的线程以获得更多有用的背景信息。

    • 7
  3. muru
    2018-02-14T06:56:35+08:002018-02-14T06:56:35+08:00

    尝试各种关闭方式,似乎poweroff使用内核参数将 Linux 引导到目标可以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 关闭目标。

    • 0

相关问题

  • 有没有办法让 ls 只显示某些目录的隐藏文件?

  • 使用键盘快捷键启动/停止 systemd 服务 [关闭]

  • 需要一些系统调用

  • astyle 不会更改源文件格式

  • 通过标签将根文件系统传递给linux内核

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve