平均查找性能提高了 715 倍,Linux 6.2 合并华为贡献的代码

日期:2022-12-14 来源:手游巴士 作者:佚名

12 月 14 日消息,Linux 6.2 今日合并了来自华为郑磊(Zhen Lei,音译)的代码,将核心内核功能的速度提高了 715 倍。

在合并代码模块介绍中写道:“得益于 Zhen Lei 的代码,Tux(Linux 的吉祥物,这里指 Linux)在 kallsyms_lookup_name () 平均查找性能提高了 715 倍,将我们的旧实现从 O (n) 升级到 O (log (n)),同时还保留了 / proc / kallsyms 上的旧实现支持”。

了解到,kallsyms_lookup_name () 函数用于根据一个符号的名称查询其地址,并可用于内核符号表内任何符号的查询。

华为的 Zhen Lei 在之前的补丁贴中描述了对 kallsyms_lookup_name 的优化:

目前,为了搜索一个符号,我们需要将 'kallsyms_names' 中的符号逐一展开,然后使用展开后的字符串进行比较。这是 O (n)。

如果我们像地址一样将名字按升序排序,我们也可以使用二进制搜索。而这就是 O (log (n))。

为了不改变“/proc/ kallsyms”的实现,表 kallsyms_names [] 仍然以升序与地址一一对应的方式存储。

增加数组 kallsyms_seqs_of_names [],它以排序后的名字的序列号为索引,对应的内容是排序后的地址的序列号。

例如,假设 NameX 在数组 kallsyms_seqs_of_names [] 中的索引是 'i',kallsyms_seqs_of_names [i] 的内容是 'k',那么 NameX 的对应地址是 kallsyms_addresses [k]。kallsyms_names [] 中的偏移是 get_symbol_offset (k)。

注意,内存使用量将增加 (4 * kallsyms_num_syms) 字节,接下来的两个补丁将减少 (1 * kallsyms_num_syms) 字节并正确处理 CONFIG_LTO_CLANG=y 的情况。

性能测试结果(在 x86 平台上):

之前:

min=234, max=10364402, avg=5206926

min=267, max=11168517, avg=5207587

之后:

min=1016, max=90894, avg=7272

min=1014, max=93470, avg=7293

kallsyms_lookup_name () 的平均查询性能提高了 715 倍。这是 kallsyms_lookup_name 一次重大改进,也是 Linux 6.2 的圣诞礼物。

上一篇:《终焉之莉莉》开发商新作《Redemption Reapers》公开宣传片,明年 2 月发售

下一篇:解读美国核聚变重大突破:究竟有何意义

相关推荐

明年 1 月 13 日开播,Showtime 发布《法官大人》(Your Honor)第 2 季预告片

12 月 14 日消息,Showtime 发布了由布莱恩・科兰斯顿(Bryan Cranston)主演的《法官大人》(Your Honor)第 2 季的预告片。本季共 10 集,将于 1 月 13

行业投资暴涨 139%,谁在追逐“人造太阳”

美国能源部部长表示,核聚变的商业化,或许可能会在未来的几个十年内实现,但大概率不是之前说的 50-60 年。人类距离“人造太阳”的目标,似乎又近了一

2022 淘宝年度大赏揭晓:飞盘、冰墩墩、手机壳等成为年度宝贝

12 月 14 日消息,淘宝今日公布 2022 年度大赏,包括“十大年度宝贝”、“十大买家秀流派”、“十大神奇掌柜”以及“十大年度直播间”等四大类奖项

2000MB/s 的小米移动固态硬盘现已开启众筹:1TB 容量 649 元

感谢网友 劳资没有昵称 的线索投递! 12 月 14 日消息,小米上周推出了一款 1TB 的小米移动固态硬盘,现已在小米商城开启众筹,众筹价 649 元。这款硬盘

推特前 CEO 多西承认公司存在严重问题:不应删除内容或封杀帐号

北京时间 12 月 14 日上午消息,据报道,Twitter 联合创始人兼 CEO 杰克・多西(Jack Dorsey)虽未在今日的博文中直接提及埃隆・马斯克(Elon Musk),但他还

查看更多