自己做物流网站,济南商城网站开发,重庆排名优化整站优化,招聘wordpress前言#xff1a;
deepin-anything#xff1a;最初是为了满足快速索引文件列表。 kprobe#xff1a;内核探针#xff0c;可在内核调用函数前#xff0c;埋点执行自定义逻辑。 pt_args#xff1a;内核探针注册接口参数2,用于获取映射的寄存器值结构体。
内核侧模块 vfs_m…前言
deepin-anything最初是为了满足快速索引文件列表。 kprobe内核探针可在内核调用函数前埋点执行自定义逻辑。 pt_args内核探针注册接口参数2,用于获取映射的寄存器值结构体。
内核侧模块 vfs_monitor
文件列表项
├── arg_extractor.c 对应架构 pt_args 结构参数获取接口文件
├── arg_extractor.h
├── event.c 缓存VFS事件操作接口文件
├── event.h
├── event_merge.c VFS事件合并操作接口屏蔽原生linux Event对最终结果影响del(X) new(X) remove del(X)
├── event_merge.h
├── Makefile
├── module.c 内核模块入口
├── vfs_change_consts.h 文件actions映射枚举
├── vfs_fsnotify.c vfs文件变动逻辑处理主文件
├── vfs_fsnotify.h
├── vfs_genl.c vfs_evnet入口操作文件
├── vfs_genl.h
├── vfs_kgenl.h
├── vfs_kretprobes.c kprobe操作文件
└── vfs_kretprobes.h module.c vfs_changed_func vfs_notify_dentry_event; //来自 vfs_genl.c 文件变动事件操作入口ret init_vfs_genl();if (ret)goto init_vfs_genl_fail;#ifdef CONFIG_FSNOTIFY_BROADCASTret init_vfs_fsnotify(get_event_merge_entry(vfs_changed_func)); // 重定向vfs_notify_dentry_event函数指针if (ret)goto init_event_source_fail;
#elseret init_vfs_kretprobes(get_event_merge_entry(vfs_changed_func)); // 重定向vfs_notify_dentry_event函数指针if (ret)goto init_event_source_fail;
#endifget_event_merge_entry 获取事件合并入口函数来自 vfs_kretprobes.c
void *get_event_merge_entry(void *vfs_changed_func)
{vfs_changed_entry vfs_changed_func;return do_event_merge;
}init_vfs_fsnotify
static struct kretprobe *vfs_krps[] {do_mount_krp, sys_umount_krp, vfs_create_krp,vfs_unlink_krp, vfs_mkdir_krp, vfs_rmdir_krp, vfs_symlink_krp, vfs_link_krp,vfs_rename_krp, security_inode_create_krp
}; //所有的kprobe结构int init_vfs_kretprobes(void *vfs_changed_func)
{int ret;ret init_mnt_ns();if (ret)return ret;vfs_changed_entry vfs_changed_func;ret register_kretprobes(vfs_krps, sizeof(vfs_krps) / sizeof(void *)); // 注册kprobe流程if (ret 0) {mpr_info(register_kretprobes failed, returned %d\n, ret);return ret;}mpr_info(register_kretprobes %ld ok\n, sizeof(vfs_krps) / sizeof(void *));return 0;
}kprobe结构来自 vfs_kretprobes.h
#define _DECL_CMN_KRP(fn, symbol) static struct kretprobe fn##_krp {\.entry_handler on_##fn##_ent,\.handler on_##fn##_ret,\.data_size sizeof(struct fn##_args),\.maxactive 64,\.kp.symbol_name #symbol,\};#define DECL_CMN_KRP(fn) _DECL_CMN_KRP(fn, fn)该部分定义 kprobe 结构体应用于注册探针。即do_mount_krp 埋点 path_mount 如下
#if LINUX_VERSION_CODE KERNEL_VERSION(5, 9, 0)
DECL_CMN_KRP(do_mount);
#else
_DECL_CMN_KRP(do_mount, path_mount); // do_mount_krp 埋点 函数为 path_mount
#endif#if LINUX_VERSION_CODE KERNEL_VERSION(4, 17, 0)
DECL_CMN_KRP(sys_umount);
#elif LINUX_VERSION_CODE KERNEL_VERSION(5, 9, 0) // 内核版本标识
_DECL_CMN_KRP(sys_umount, ksys_umount); // sys_umount_krp 埋点函数为 ksys_umount
#else
_DECL_CMN_KRP(sys_umount, path_umount);
#endif该部分定义kprobe的函数入口与kprobe操作函数
#define DECL_VFS_KRP(fn, act, de_i) static int on_##fn##_ent(struct kretprobe_instance *ri, struct pt_regs *regs)\{\return common_vfs_ent((struct vfs_event **)(ri-data), (struct dentry *)get_arg(regs, de_i));\}\\static int on_##fn##_ret(struct kretprobe_instance *ri, struct pt_regs *regs)\{\return common_vfs_ret((struct vfs_event **)(ri-data), regs, act);\}\\static struct kretprobe fn##_krp {\.entry_handler on_##fn##_ent,\.handler on_##fn##_ret,\.data_size sizeof(struct vfs_event *),\.maxactive 64,\.kp.symbol_name #fn,\};宏调用如下
DECL_VFS_KRP(vfs_create, ACT_NEW_FILE, 3); // 参数1为埋点符号参数2文件操作参数3获取参数寄存器 return regs-dx;
DECL_VFS_KRP(vfs_unlink, ACT_DEL_FILE, 3);
DECL_VFS_KRP(vfs_mkdir, ACT_NEW_FOLDER, 3);
DECL_VFS_KRP(vfs_rmdir, ACT_DEL_FOLDER, 3);
DECL_VFS_KRP(vfs_symlink, ACT_NEW_SYMLINK, 3);
DECL_VFS_KRP(security_inode_create, ACT_NEW_FILE, 2); // return regs-si;vfs_changed_entry 函数绑定到 do_event_mergeinit_vfs_kretprobes函数中
vfs_changed_entry vfs_changed_func;