buddy系统用于衡量碎片化程度的两个值--extfrag_index和unusable_index

本文探讨了Linux内核buddy系统中衡量碎片程度的extfrag_index和unusable_index。通过对extfrag和unusable文件系统的初始化,利用.open、.show回调函数以及walk_zones_in_node进行遍历计算,分别计算出两个指标,并通过extfrag_show_print和unusable_show_print进行输出。其中,unusable_index计算会考虑node_state,而extfrag_index则不包含此判断。
摘要由CSDN通过智能技术生成

创建extfrag_index和unusable_index(用于衡量buddy系统每个order的碎片化程度)extfrag以块出发,unusable以页出发。首先在sys/kernel/debug/目录下创建一个extfrag文件夹,在这个文件夹下创建两个文件,一个extfrag_index,一个unusable_index。通过函数extfrag_debug_init():

static int __init extfrag_debug_init(void)
{
   
	struct dentry *extfrag_debug_root;
	//在debug下创建一个dir,返回的是创建了目录,之后创建文件在这个目录下,可以看到下面两个创建文件的均是在extfrag_debug_root。
	extfrag_debug_root = debugfs_create_dir("extfrag", NULL);
	if (!extfrag_debug_root)
		return -ENOMEM;
	//创建这两个文件时后面都加了一个结构体的引用,这两个结构体中是成员和对应的函数,代表文件.标识就引用那个标识所对应的函数
	//如file.open,就是调用extfrag_open函数
	if (!debugfs_create_file("unusable_index", 0444,
			extfrag_debug_root, NULL, &unusable_file_ops))
		goto fail;

	if (!debugfs_create_file("extfrag_index", 0444,
			extfrag_debug_root, NULL, &extfrag_file_ops))
		goto fail;

	return 0;
fail:
	debugfs_remove_recursive(extfrag_debug_root);
	return -ENOMEM;
}

两个结构体如下:

static const struct file_operations extfrag_file_ops = {
   
	.open		= extfrag_open,
	.read		= seq_read,
	.llseek		= seq_lseek,
	.release	= seq_release,
};
static const struct file_operations unusable_file_ops = {
   
	.open		= unusable_open,
	.read		= seq_read,
	.llseek		= seq_lseek,
	.release	= seq_release,
};

结构体中后三个是创建文件系统带的,只有.open是添加的,.open对应的是extfrag_open和unusable_open两个函数

static int extfrag_open(struct inode *inode, struct file *file)
{
   
	return seq_open(file, &extfrag_op);
}

                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值