首页 > 编程语言 > 详细

nasm 函数返回一个数组 x86

时间:2020-12-29 00:00:14      阅读:29      评论:0      收藏:0      [点我收藏+]

getArguments.asm:

extern VirtualAlloc

section .text
  global dllmain
  export getArguments

dllmain:
  mov eax,1
  ret 12

getArguments:
  push ebp
  mov ebp,esp

  push 0x40   ; PAGE_EXECUTE_READWRITE
  push 0x3000 ; MEM_COMMIT | MEM_RESERVE
  push 8      ; size
  push 0      ; lpAddress
  call VirtualAlloc
  mov dword [eax],1   ; index 0
  mov dword [eax+4],2 ; index 1

  mov esp,ebp
  pop ebp
  ret

build.fil:

/entry:dllmain 
/dll
Kernel32.dll

getArguments.obj

build.bat:

nasm -f win32 getArguments.asm
golink @build.fil

c++:

#include <iostream>
#include <Windows.h>

typedef int* (CALLBACK* f_t)();
f_t f;

int main()
{
  HMODULE mydll = LoadLibraryA("getArguments.dll");
  if (mydll == NULL) return 0;

  f = (f_t)GetProcAddress(mydll, "getArguments");
  int* r = f();

  printf("%d\n", r[0]); // 1
  printf("%d\n", r[1]); // 2

  return 0;
}

See alse:

nasm 函数返回一个数组 x86

原文:https://www.cnblogs.com/ajanuw/p/14203936.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!