标签:自带 习题 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