一般我们在runtime的时候通过BUG_ON 来检查运行时的错误
BUG_ON((reg & 0x3) != 0);
例如上例汇总reg & 0x3 应该要等于0,如果不等于0就会出发BUG_ON
#ifndef HAVE_ARCH_BUG
#define BUG() do { \
printk("BUG: failure at %s:%d/%s()!\n", __FILE__, __LINE__, __func__); \
panic("BUG!"); \
} while (0)
#endif
#ifndef HAVE_ARCH_BUG_ON
#define BUG_ON(condition) do { if (unlikely(condition)) BUG(); } while (0)
#endif
例如这里就会打印出文件file/line/func 后调用panic,但这个都是在runtime 时检测运行参数的不对
如果想在编译时就把有的错误检查出来,例如:
BUILD_BUG_ON(sizeof(skb->queue_mapping) != sizeof(qdisc_skb_cb(skb)->slave_dev_queue_mapping));
如果这两个类型不一致的话,就会处罚编译时的错误
#ifndef __OPTIMIZE__
#define BUILD_BUG_ON(condition) ((void)sizeof(char[1 - 2*!!(condition)]))
#else
#define BUILD_BUG_ON(condition) \
BUILD_BUG_ON_MSG(condition, "BUILD_BUG_ON failed: " #condition)
#endif
如果定义了__OPTIMIZE__的话,就会打印BUILD_BUG_ON failed之类的log,最后的#condition就是字符化,例如本例就是
“BUILD_BUG_ON failed: sizeof(skb->queue_mapping) != sizeof(qdisc_skb_cb(skb)->slave_dev_queue_mapping)”
BUG_ON((reg & 0x3) != 0);
例如上例汇总reg & 0x3 应该要等于0,如果不等于0就会出发BUG_ON
#ifndef HAVE_ARCH_BUG
#define BUG() do { \
printk("BUG: failure at %s:%d/%s()!\n", __FILE__, __LINE__, __func__); \
panic("BUG!"); \
} while (0)
#endif
#ifndef HAVE_ARCH_BUG_ON
#define BUG_ON(condition) do { if (unlikely(condition)) BUG(); } while (0)
#endif
例如这里就会打印出文件file/line/func 后调用panic,但这个都是在runtime 时检测运行参数的不对
如果想在编译时就把有的错误检查出来,例如:
BUILD_BUG_ON(sizeof(skb->queue_mapping) != sizeof(qdisc_skb_cb(skb)->slave_dev_queue_mapping));
如果这两个类型不一致的话,就会处罚编译时的错误
#ifndef __OPTIMIZE__
#define BUILD_BUG_ON(condition) ((void)sizeof(char[1 - 2*!!(condition)]))
#else
#define BUILD_BUG_ON(condition) \
BUILD_BUG_ON_MSG(condition, "BUILD_BUG_ON failed: " #condition)
#endif
如果定义了__OPTIMIZE__的话,就会打印BUILD_BUG_ON failed之类的log,最后的#condition就是字符化,例如本例就是
“BUILD_BUG_ON failed: sizeof(skb->queue_mapping) != sizeof(qdisc_skb_cb(skb)->slave_dev_queue_mapping)”