在Linux内核中,dev_err()
是用于输出设备驱动程序错误信息的宏
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/dev_err.h>
dev_err()
宏输出错误信息。它通常需要一个设备对象(struct device *
)作为参数,以及一个格式字符串,后面可以跟任意数量的参数。例如:static int my_driver_init(struct device *dev)
{
int ret = 0;
// ... 初始化代码 ...
if (ret < 0) {
dev_err(dev, "初始化失败,错误代码:%d\n", ret);
return ret;
}
// ... 其他初始化代码 ...
return 0;
}
在这个例子中,如果初始化失败,dev_err()
宏将输出一条错误信息,包括设备对象和错误代码。
dev_err()
宏的另一个版本,它接受一个额外的struct printk_rate_limit *
参数。例如:static int my_driver_init(struct device *dev)
{
int ret = 0;
struct printk_rate_limit *rate_limit = NULL;
// ... 初始化代码 ...
if (ret < 0) {
rate_limit = &my_driver_rate_limit; // 设置日志速率限制
dev_err(dev, "初始化失败,错误代码:%d\n", ret);
printk_ratelimit(rate_limit); // 输出日志
return ret;
}
// ... 其他初始化代码 ...
return 0;
}
在这个例子中,我们设置了日志速率限制,然后使用printk_ratelimit()
函数输出错误信息。
总之,要在Linux内核中通过dev_err()
输出错误信息,你需要包含必要的头文件,然后使用dev_err()
宏,并提供一个设备对象和一个格式字符串。如果需要,还可以设置日志速率限制。