调试篇一之动态调节

本文介绍了如何在Linux环境中动态调整调试日志级别,通过宏定义BIT和枚举print_reason来设置不同类型的日志打印。示例中展示了如何使用module_param_named将smbchg_debug_mask参数用于控制调试输出,并通过pr_smb宏决定是否根据debug_mask打印info或debug日志。
摘要由CSDN通过智能技术生成

#define BIT(nr)            (1UL << (nr))

 

enum print_reason {

PR_REGISTER    = BIT(0),

PR_INTERRUPT    = BIT(1),

PR_STATUS    = BIT(2),

PR_DUMP        = BIT(3),

PR_PM        = BIT(4),

PR_MISC        = BIT(5),

PR_WIPOWER    = BIT(6),

};

 

staticint smbchg_debug_mask= 46;

module_param_named(

debug_mask, smbchg_debug_mask,int, S_IRUSR | S_IWUSR);

 

#define pr_smb(reason, fmt,...)                \

do {                           \

if (smbchg_debug_mask& (reason))        \

pr_info(fmt, ##__VA_ARGS__);       \

else                        \

pr_debug(fmt, ##__VA_ARGS__);       \

} while (0)

 

pr_smb(PR_REGISTER, "addr =0x%x writing 0x%x\n", base, reg);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值