从C代码进行编译时,我在理解除法和Modulo在Assembly中的工作方式时遇到了一些麻烦:
源C代码:
int k1=55,k2=33;
int k3=0,k4=0;
k3=k1/4;
k4=k2/13;
int v1=30,v2=40,v6=50;
int v3=0,v4=0,v5=0;
puts("Modulo v1:");
v3=v1%20;
puts("Modulo v2:");
v4=v2%21;
puts("Modulo v3:");
v6=v3%18;
return 0;
IDA拆卸:
mov dword ptr [esp+3Ch], 55
mov dword ptr [esp+38h], 33
mov dword ptr [esp+34h], 0
mov dword ptr [esp+30h], 0
mov eax, [esp+3Ch] ; "k3=k1/4"
cdq
and edx, 3
add eax, edx
sar eax, 2
mov [esp+34h], eax
mov ecx, [esp+38h] ; "k4=k2/13"
mov edx, 4EC4EC4Fh
mov eax, ecx
imul edx ; Why Imul ?
sar edx, 2
mov eax, ecx
sar eax, 1Fh
sub edx, eax
mov eax, edx
mov [esp+30h], eax
mov dword ptr [esp+2Ch], 30
mov dword ptr [esp+28h], 28h
mov dword ptr [esp+24h], 32h
mov dword ptr [esp+20h], 0
mov dword ptr [esp+1Ch], 0
mov dword ptr [esp+18h], 0
mov dword ptr [esp], offset aModuloV1 ; "Modulo v1:"
call _puts
mov ecx, [esp+2Ch] ; "v3=v1%20"
mov edx, 66666667h ; Weird number ??
mov eax, ecx
imul edx ; Why imul when it's Modulo ?
sar edx, 3
mov eax, ecx
sar eax, 1Fh
sub edx, eax
mov eax, edx
shl eax, 2
add eax, edx
shl eax, 2
sub ecx, eax
mov eax, ecx
mov [esp+20h], eax
mov dword ptr [esp], offset aModuloV2 ; "Modulo v2:"
call _puts
mov ecx, [esp+28h]
mov edx, 30C30C31h ; Weird Number ??
mov eax, ecx
imul edx ; Imul again ?
sar edx, 2
mov eax, ecx
sar eax, 1Fh
sub edx, eax
mov eax, edx
shl eax, 2
add eax, edx
shl eax, 2
add eax, edx
sub ecx, eax
mov eax, ecx
mov [esp+1Ch], eax
mov dword ptr [esp], offset aModuloV3 ; "Modulo v3:"
call _puts
mov ecx, [esp+20h]
mov edx, 38E38E39h
mov eax, ecx
imul edx ; Why Imul ?
sar edx, 2
mov eax, ecx
sar eax, 1Fh
sub edx, eax
mov eax, edx
shl eax, 3
add eax, edx
add eax, eax
sub ecx, eax
mov eax, ecx
mov [esp+24h], eax
我最初认为只有DIV和MOD之类的说明,但是当涉及到IDA拆卸时,我只能看到
之类的说明。 SAR,SHR
(这2条指令对DIV和Modulo有何作用?)
IMUL
(为什么我想要的是DIV和Modulo?)
AND
(不知道它在做什么)
还有一些奇怪的数字:
mov edx, 66666667h ; Weird "66666667h" number ??
mov edx, 30C30C31h ; Weird "30C30C31h" number ??
mov edx, 38E38E39h ; Weird "38E38E39h" number ?
我已经搜索过很多次google,但仍然找不到完整的解释,我可以清楚地理解这些ASM指令如何在C代码中用作DIV和Modulo。
有人可以逐步解释这些组装说明吗?还是有任何关键字可以让我进行一些Google搜索?