BUG() 和 BUG_ON()

BUG()

BUG() 是一个无条件触发内核错误的宏:

c 复制代码
BUG();  // 无条件触发内核错误

当执行到 BUG() 时,内核会:

  • 触发一个非法指令异常
  • 生成内核 oops 信息
  • 可能导致内核 panic(取决于配置)

BUG_ON(condition)

BUG_ON() 是一个条件判断宏:

c 复制代码
BUG_ON(condition);  // 如果条件为真,触发内核错误

等价于:

c 复制代码
if (condition)
    BUG();

使用场景示例

c 复制代码
// 检查指针是否为空
void my_function(struct device *dev)
{
    BUG_ON(dev == NULL);  // 如果dev为空,触发BUG
    
    // 正常的处理逻辑
    dev->ops->start(dev);
}

// 检查不可能发生的情况
int calculate_offset(int size)
{
    BUG_ON(size < 0);  // 大小不应该为负数
    
    return size * 2;
}

与 panic() 的区别

行为 使用场景
BUG()/BUG_ON() 触发 oops,可能继续运行 代码逻辑错误,不应该发生的情况
panic() 立即停止系统 系统无法继续运行的严重错误

实际效果

当触发 BUG 时,你会看到类似输出:

复制代码
kernel BUG at drivers/xxx/yyy.c:123!
Oops: 0000 [#1] SMP
CPU: 0 PID: 1234 Comm: process_name Tainted: G
... (堆栈跟踪信息)

开发建议

  1. 用于调试:主要用于开发阶段发现逻辑错误
  2. 不要滥用:生产环境中应尽量避免触发
相关推荐
Johny_Zhao15 小时前
OpenClaw安装部署教程
linux·人工智能·ai·云计算·系统运维·openclaw
chlk1232 天前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑2 天前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件2 天前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
深紫色的三北六号3 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash3 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI3 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行4 天前
Linux和window共享文件夹
linux
木心月转码ing4 天前
WSL+Cpp开发环境配置
linux
崔小汤呀5 天前
最全的docker安装笔记,包含CentOS和Ubuntu
linux·后端