初始化
lowmemorykiller定义在lowmemorykiller.c中,其初始化代码如下(非关键代码已忽略,后续皆如此):
static int __init lowmem_init(void)
{
//注册task_free_notifier的事件通知
task_free_register(&task_nb);
//在shrinker_list中注册缓存收缩函数
register_shrinker(&lowmem_shrinker);
return 0;
}
static void __exit lowmem_exit(void)
{
unregister_shrinker(&lowmem_shrinker);
task_free_unregister(&task_nb);
}
module_init(lowmem_init);
module_exit(lowmem_exit);
代码比较简洁,就做了两件事,一是注册task_free_notifier的回调函数,二是注册缓存收缩函数,在shrink_slab的时候会调用到shrinker_list链表中的每个缓存收缩函数。
task_free实在task_struct释放的时候发生的,lowmemkiller接收到task_free通知后,只是检查了一下是否与自己有关,没什么太大作用,如下:
static struct notifier_block task_nb = {
.notifier_call = task_notify_func,
};
static int
task_notify_func(struct notifier_block *self, unsigned long val, void *data)
{
struct task_struct *task = data;
if (task == lowmem_deathpending)
lowmem_deathpending = NULL;
return NOTIFY_DONE;
}
register_shrinker代码如下:
void register_shrinker(struct shrinker *shrinker)
{
atomic_long_set(&shrinker->nr_in_batch, 0);
down_write(&shrinker_rwsem);
//在shrinker_list通知链上注册当前shrinker
list_add_tail(&shrinker->list, &shrinker_list);
up_write(&shrinker_rwsem);
}