c – 如何在不创建新进程的情况下运行汇编代码?

c – 如何在不创建新进程的情况下运行汇编代码?,第1张

概述该文件包含本机程序集代码,我想在当前进程中运行它. 但我不想创建一个真正的文件(.com或.exe),所以我试过: ...using namespace std;typedef void bitcode();void testcode(){ cout<<"test";};int main(){ bitcode *c=&testcode; // bitcode *c st 该文件包含本机程序集代码,我想在当前进程中运行它.
但我不想创建一个真正的文件(.com或.exe),所以我试过:

@[email protected] namespace std;typedef voID bitcode();voID testcode(){ cout<<"test";};int main(){ bitcode *c=&testcode; // bitcode *c stands for the file containing the assembly code. bitcode *d=reinterpret_cast<bitcode*> (malloc(20)); memcpy(d,c,20); d(); // it doesn't work return 0;};

但是,当我调用d();它时它不起作用.我想知道用C/C++做这个的正确方法是什么.

(我在windows上,如果你能告诉我如何在linux上制作它,我会非常感激)

非常感谢!

PS:我不是要求“在没有创建新流程的情况下在另一个流程中运行可执行文件”.

解决方法 在windows上,这是我之前写的代码.它至少在我的机器上适用于Win7 VS2010.

基本思想是调用VirtualAlloc以使用PAGE_EXECUTE_READWRITE标志分配内存.
并以正确的方式调用它,即保持堆栈平衡.

@H_419_12@#include "stdafx.h"#include "windows.h"int emitcode[] = {0x83ec8b55,0x565340ec,0x0c758b57,0x8b087d8b,0x348d104d,0xcf3c8dce,0x6f0fd9f7,0x6f0fce04,0x0f08ce4c,0x10ce546f,0xce5c6f0f,0x646f0f18,0x6f0f20ce,0x0f28ce6c,0x30ce746f,0xce7c6f0f,0x04e70f38,0x4ce70fcf,0xe70f08cf,0x0f10cf54,0x18cf5ce7,0xcf64e70f,0x6ce70f20,0xe70f28cf,0x0f30cf74,0x38cf7ce7,0x7508c183,0xf8ae0fad,0x5e5f770f,0x5de58b5b,0xccccccc3};int _tmain(int argc,_TCHAR* argv[]){ int *src = new int[64]; int *dst = new int[64]; int *dst2 = new int[64]; for (int i = 0; i < 64; ++i){ src[i] = i; } //fastercopy(dst,src,64/2); voID* address = NulL; address= VirtualAlloc(NulL,sizeof(emitcode),MEM_COMMIT|MEM_RESERVE,PAGE_EXECUTE_READWRITE); memcpy(address,emitcode,sizeof(emitcode)); //call emit code from assemble __asm { push 20h mov eax,DWord ptr [src] push eax mov ecx,DWord ptr [dst] push ecx mov ecx,DWord ptr [address] call ecx add esp,0Ch } for (int i = 0; i < 64; ++i){ printf("%d ",dst[i]); } //call emit code from function pointer typedef voID (*FASTCALL)(voID* dst,voID* src,int len); FASTCALL fastcall; fastcall = (FASTCALL)address; fastcall(dst2,64/2); printf("\n"); for (int i = 0; i < 64; ++i){ printf("%d ",dst2[i]); } return 0;} 总结

以上是内存溢出为你收集整理的c – 如何在不创建新进程的情况下运行汇编代码?全部内容,希望文章能够帮你解决c – 如何在不创建新进程的情况下运行汇编代码?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1219650.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存