平均查找性能提高了715倍,Linux6.2合并华为贡献的代码
2022-12-14 14:29 | 来源:IT之家 | 编辑:苏婉蓉 | 阅读量:15611 |
2022-12-14 14:29 | 来源:IT之家 | 编辑:苏婉蓉 | 阅读量:15611 |
Linux 6.2今天合并了来自华为郑雷的代码,将核心内核功能的速度提高了715倍。
在合并代码模块的介绍中写道:得益于雷震的代码,Tux在kallsyms_lookup_name中的平均查找性能提升了715倍,我们的旧实现从O 升级到O ,同时仍然保持了/proc/kallsyms中的旧实现支持。
本站了解到kallsyms_lookup_name函数用于根据符号的名称查询符号的地址,可以用来查询内核符号表中的任意符号。
华为的雷震在之前的补丁中描述了kallsyms_lookup_name的优化:
目前,为了搜索一个符号,我们需要逐个扩展'kallsyms_names '中的符号,然后与扩展后的字符串进行比较这是o
如果我们像地址一样按升序排列名字,我们也可以使用二分搜索法而这个是o)
为了不改变/proc/ kallsyms的实现,表kallsyms_names仍然按照升序存储,与地址一一对应。
添加数组kallsyms_seqs_of_names,该数组以排序名称的序号为索引,对应的内容是排序地址的序号。
例如,假设数组kallsyms_seqs_of_names中NameX的索引为‘I’,kallsyms_seqs_of_names (i)的内容为‘k’,那么NameX对应的地址为kallsyms_addresses (k)kallsyms_names中的偏移量是get_symbol_offset (k)
请注意,内存使用将增加字节,接下来的两个补丁将减少(1 * kallsyms_num_syms)字节,并正确处理config _ LTO _ clang = y的情况
性能测试结果:
之前:
最小值=234,最大值=10364402,平均值=5206926
最小值=267,最大值=11168517,平均值=5207587
之后:
最小值=1016,最大值=90894,平均值=7272
最小值=1014,最大值=93470,平均值=7293
kalyms _ lookup _ name的平均查询性能提高了715倍这是kallsyms_lookup_name的重大改进,也是Linux 6.2的圣诞礼物
声明:本网转发此文章,旨在为读者提供更多信息资讯,所涉内容不构成投资、消费建议。文章事实如有疑问,请与有关方核实,文章观点非本网观点,仅供读者参考。