news 2026/4/15 6:27:58

当Ada记录类型含有可变长数组分量时的逆向分析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
当Ada记录类型含有可变长数组分量时的逆向分析

请看IDA生成的以下伪代码:

char *a7;//函数的输入参数 int v31; // ecx int v32; // ecx int v33; // edx int v34; // ebx int v35; // ecx int v36; // ecx int v37; // edx int v38; // eax int v39; // edx v31 = *a7; if ( v31 > 99 ) v31 = 99; v32 = (~(532 * v31 + 532) >> 31) & (532 * v31 + 532); v33 = *a7; if ( v33 < -1 ) v33 = -1; v34 = v32; if ( v32 > 532 * v33 + 532 ) v34 = 532 * v33 + 532; v35 = *a7; if ( v35 > 99 ) v35 = 99; v36 = (~(532 * v35 + 532) >> 31) & (532 * v35 + 532); v37 = *a7; if ( v37 < -1 ) v37 = -1; v38 = 532 * v37 + 532; v39 = v36; if ( v36 > v38 ) v39 = v38; server_types__default_carp_leg(&a7[v34 + 536 + v39 + v34]);

根据推断,a7是一个指针,在原始设计中它指向一个Ada的记录类型。

该类型的头部包含了3个可变长数组,数组的下标范围是[-1, 99]。

数组的分量又是一个记录,其长度是532个字节。

以下是改为C代码后定义的结构类型:

typedef struct { unsigned8 _0; unsigned8 _1; unsigned8 _2; server_types__lat_path_leg_t _4a[100]; server_types__lat_path_leg_t _4b[100]; server_types__lat_path_trans_t _4c[100]; server_types__lat_path_leg_t _4d; server_types__carp_leg_t carp_leg; } server_types__lat_pathsIP_t;

在上述结构类型定义中,分量_4a、_4b、_4c对应原始设计的三个可变长数组,但数组长度改为常数100。

类型server_types__lat_path_leg_t与server_types__lat_path_trans_t的长度都是532个字节。

调用函数server_types__default_carp_leg时的参数地址表达式:

v34 + 536 + v39 + v34

可解释为:

4 + v34 + v34 + v39 + 532

其中4是类型server_types__lat_pathsIP_t中的分量_0、_1、_2的长度,第一个v34是分量_4a的长度,第二个v34是分量_4b的长度,v39是分量_4c的长度,532是分量_4d的长度。

这个表达式的值是分量carp_leg在结构中的偏移量。

因此,这条函数调用语句的参数是分量carp_leg的地址。

在调用语句前的这段伪代码是由Ada编译器根据可变长数组的特性生成的,用于计算赋予v34和v39的值。

现在我们改为C代码后,不需要计算v34和v39了。

最后,整段伪代码简化为以下C代码:

server_types__lat_pathsIP_t* a7; server_types__default_carp_leg(&a7->carp_leg);

另外,如果原始设计者在定义这个记录类型时,把三个可变长数组分量放在记录的最后部分,就可省去关于其他分量的偏移量的计算。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/11 11:35:04

刀客doc:小米是时候切断和粉丝的脐带了

文/刀客doc(头条精选作者)刚刚&#xff0c;小米就“大熊事件”给出了一份相对完整的处理结果。公司发言人通过官微回应&#xff0c;公布了内部调查结论&#xff0c;文中称&#xff1a;“因为米粉&#xff0c;所以小米。米粉的信任和支持&#xff0c;是小米不断前行的基石。我们…

作者头像 李华
网站建设 2026/4/14 13:56:52

晶台光耦在储能系统中的作用

光耦在储能系统中通过电气隔离实现高压与低压电路的安全隔离&#xff0c;是保障系统稳定运行的关键器件。晶台光耦KL1018/KL1019系列采用LSOP4封装&#xff0c;具备5KV隔离电压及-55~110℃宽温特性&#xff0c;广泛应用于太阳能储能逆变器。其红外发射二极管与光电晶体管耦合结…

作者头像 李华
网站建设 2026/4/11 0:02:16

虎贲等考 AI:AI 重构学术写作生态,全流程智能辅助赋能科研新可能

在学术探索的道路上&#xff0c;从选题构思到答辩收官&#xff0c;科研工作者与学子常被文献搜集繁琐、数据支撑薄弱、格式规范复杂、查重降重棘手等问题困扰。虎贲等考 AI 作为一款依托前沿人工智能技术打造的专业论文写作辅助工具&#xff0c;以 “全流程覆盖、高专业保障、强…

作者头像 李华
网站建设 2026/4/8 2:49:24

写论文软件哪个好?虎贲等考 AI 凭 “学术闭环力” 稳坐首选

毕业季的论文攻坚战&#xff0c;“写论文软件哪个好” 成了学子圈的高频拷问。有的软件文献引用虚拟无据&#xff0c;有的生成内容缺乏数据支撑&#xff0c;有的功能碎片化需反复切换工具 —— 真正靠谱的写论文软件&#xff0c;既要 “写得快”&#xff0c;更要 “写得专业、写…

作者头像 李华
网站建设 2026/4/8 6:01:34

trae 中让 clangd 插件格式化代码时大括号换行

在 clangd 中使用 clang-format 时&#xff0c;要控制大括号的换行风格&#xff0c;你需要配置 .clang-format 文件。以下是常用的大括号换行配置选项&#xff1a; 1. 创建或修改 .clang-format 文件 在你的项目根目录或用户目录创建此文件&#xff1a; # 基础风格&#xff08;…

作者头像 李华