标签:自带 习题 write div sde unit ase x64 file
其实这个我自己出给自己的练习题现在都还没做对。。。虽然看得懂一点汇编指令,但我还是不理解寄存器以及对它们正确的使用,断断续续的学汇编,进步超缓慢。。而且一段时间不写,连指令作用都忘了。
最早电脑装了 gcc,用的nasm,但后来不想用 gcc 了,一直在用 msvc,然后 nasm 无法与 msvc 链接生成 exe 文件(可能我太菜了,没找到正确姿势),但用微软自带的汇编器 ml 也不错,虽然语法稍有些不同,但指令都差不多,不过就很恼火的是一直无法调用 printf / scanf 。。。只能用win32api MessageBox 或 WriteFile 代替输出,但输入呢?
这是我的错误解决方案(鬼知道我用反汇编调了多少次,才稍微明白了一点汇编逻辑,如今 crack me 还是只会字节修补(捂脸)):
extrn MessageBoxA: PROC
extrn ExitProcess: PROC
.data
ti db ‘result‘, 0
msg db ‘phahhb‘, 0
.code
main proc
sub rsp, 28h
mov eax, offset msg
;lea edx, [eax+1]
loc_401086:
mov cl, [eax]
cmp cl, 0
jmp loc_401B12
inc eax
cmp cl, 61h
jl short loc_401086
;test cl, cl
sub cl, 20h
mov [eax], cl
jmp loc_401086
loc_401B12:
mov rcx, 0 ; hWnd = HWND_DESKTOP
lea rdx, [eax] ; LPCSTR lpText
lea r8, ti ; LPCSTR lpCaption
mov r9d, 0 ; uType = MB_OK
call MessageBoxA
add rsp, 28h
mov ecx, eax ; uExitCode = MessageBox(...)
call ExitProcess
main endp
End
虽然我知道 mov [eax], cl 那里是不对的,应该写入另一个寄存器,但我竟然蠢到不知道该写到哪个寄存器里面才能改变 eax 的对应位置上的字符。。。
下面是我自己写的 bat,以方便运行汇编小项目,可以改改做模板用:
@echo off call "C:\Program Files (x86)\Microsoft Visual Studio\2019\Community\Common7\Tools\VsDevCmd.bat" d: cd D:\AssembleProjects\helloml64 "D:\AssembleProjects\hello\hello.asm" /link /subsystem:windows /DYNAMICBASE "C:\Program Files (x86)\Windows Kits\10\Lib\10.0.18362.0\um\x64\kernel32.lib" "C:\Program Files (x86)\Windows Kits\10\Lib\10.0.18362.0\um\x64\user32.lib" /LARGEADDRESSAWARE:NO /OUT:"D:\AssembleProjects\hello\hello.exe" /entry:main "D:\AssembleProjects\hello\hello.exe" pause
标签:自带 习题 write div sde unit ase x64 file
原文地址:https://www.cnblogs.com/darkchii/p/12758113.html