gpt4 book ai didi

c - Hex-rays 无法使用数组反编译汇编代码

转载 作者:太空宇宙 更新时间:2023-11-03 23:43:23 25 4
gpt4 key购买 nike

我正在使用这个使用全局变量的函数编译一个 TASM 汇编文件(以保护模式运行):

array dd 0,29535,29535,29096,27889,35168,39271,24798,29855,29772,38197,22395
dd 56219,56131,56121,56133,24256,24229,24412,51616,37038,28755,29069,28107,46700,31766,30517,35050,33790,00000,0000,64000,64000,64000,64000,64000
dd 32190,10299,64000,25841,9185,25203,24473,25203,39396,64000,64000,64000,64000,64000,64000,64000,64000,15266,50285,25477,64000,64000
dd -1

adderVar EQU 0255442

result dd ?

modifyList proc near
PUSHAD
PUSH DS ES
mov edi,offset array
mov eax,adderVar
e:
cmp dword ptr [edi],-1
je f
add dword ptr eax,[edi]
mov dword ptr [edi],eax
add edi,4
jmp e
f:
mov [result],eax
POP ES DS
POPAD
ret
modifyList endp

此代码将固定值 (adderVar) 添加到数组的第一个元素,然后将所有先前元素的总和添加到下一个元素,在结束分隔符 (-1) 处停止。

将 .OBJ 文件加载到 IDA 并使用 Hex-rays 创建 C 文件生成以下代码:

int dword_3408E = 0; // weak
int dword_34092 = 29535; // weak
int dword_34096 = 29535; // weak
int dword_3409A = 29096; // weak
int dword_3409E = 27889; // weak
int dword_340A2 = 35168; // weak
int dword_340A6 = 39271; // weak
int dword_340AA = 24798; // weak
int dword_340AE = 29855; // weak
int dword_340B2 = 29772; // weak
int dword_340B6 = 38197; // weak
int dword_340BA = 22395; // weak
int dword_340BE = 56219; // weak
int dword_340C2 = 56131; // weak
int dword_340C6 = 56121; // weak
int dword_340CA = 56133; // weak
int dword_340CE = 24256; // weak
int dword_340D2 = 24229; // weak
int dword_340D6 = 24412; // weak
int dword_340DA = 51616; // weak
int dword_340DE = 37038; // weak
int dword_340E2 = 28755; // weak
int dword_340E6 = 29069; // weak
int dword_340EA = 28107; // weak
int dword_340EE = 46700; // weak
int dword_340F2 = 31766; // weak
int dword_340F6 = 30517; // weak
int dword_340FA = 35050; // weak
int dword_3411A = 64000; // weak
int dword_3411E = 32190; // weak
int dword_34126 = 64000; // weak
int dword_3412A = 25841; // weak
int dword_3412E = 9185; // weak
int dword_34132 = 25203; // weak
int dword_34136 = 24473; // weak
int dword_3413A = 25203; // weak
int dword_3415E = 64000; // weak
int dword_34162 = 15266; // weak
int dword_34166 = 50285; // weak
int dword_3417A; // weak


__int64 __usercall sub_167AA@<edx:eax>(__int64 a1@<edx:eax>)
{
int *v1; // edi@1
signed int v2; // eax@1
__int64 v4; // [sp-20h] [bp-20h]@1

v4 = a1;
v1 = &dword_3408E;
v2 = 255442;
while ( *v1 != -1 )
{
v2 += *v1;
*v1 = v2;
++v1;
}
dword_3417A = v2;
return v4;
}
// 3408E: using guessed type int dword_3408E;
// 3417A: using guessed type int dword_3417A;

似乎变量中缺少值 25477、64000、64000 和 -1 分隔符,并且 C 代码假设所有 int 都是相邻的。

谁能猜出导致 Hex-rays 失败的原因,以及如何修改汇编代码以获得正确的 C 输出?

最佳答案

您可以在汇编窗口中将 dword_3408E 转换为数组。之后,如果您更改了默认值,请使用 F5 或其他热键在 Hex-Rays 窗口中重新分析代码,因此 Hex-Rays 也会将其显示为数组。

还有一点。您的功能原型(prototype)也不正确。应该是'void sub_167AA()',因为你用的不是参数和返回值,而是全局变量。

关于c - Hex-rays 无法使用数组反编译汇编代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40075545/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com