文档章节

VS中使用X64汇编

simpower
 simpower
发布于 06/24 00:12
字数 836
阅读 15
收藏 0

需要注意的是,在X86项目中,可以使用__asm{}来嵌入汇编代码,但是在X64项目中,再也不能使用__asm{}来编写嵌入式汇编程序了,必须使用专门的.asm汇编文件来编写相应的汇编代码,然后在其它地方来调用这些汇编代码。

 

那么,如何在VS中使用X64的汇编呢?本例子将演示如何在汇编文件中使用.c或者.cpp源文件中定义的函数和变量,以及如何在.c或者.cpp中使用汇编文件中定义的函数。

 

首先使用VS(本例子中使用的是VS2013)file=》new=》project,创建一个console项目如下:x64_asm。

项目创建好了之后,默认是一个X86的开发编译环境:

                         

点击红框中的下拉箭头,选择Configure Manager…:

选择点击上图中的New:

选择上图中的x64,然后点击OK。这样,就将项目切换成了X64开发编译环境了:

                                     

然后,在项目中手动添加一个.asm文件,比如名称叫amd64xx.asm。

接着在VS左侧的项目名称下的Source Files上右键,选择add,existing item将该文件添加到source files中。

 

 

接下来,再添加一个func.cpp和func.h文件,在func.cpp里定义两个函数print1和print2,以及一个全局变量g_iValue,供amd64xx.asm中调用:

//func.cpp

#include "stdafx.h"

#include "func.h"

 

void print1(void)

{

    printf("hello world1\n");

}

 

void print2(void)

{

    printf("hello world2\n");

}

//func.h

#pragma once

extern "C"//防止函数被name mangling

{

 

    void print1(void);

    void print2(void);

    __int64 g_iValue =100;

}

 

然后再来实现amd64xx.asm如下。在amd64xx.asm中,实现了2个函数,声明在amd64xx.h中,并且引用了func.cpp中定义的print2和g_ivalue。

//amd64xx.h

extern "C" int __stdcall func1();

extern "C" void __stdcall func2();

 

//amd64xx.asm

EXTERN  print2:PROC;引用外部函数

EXTERN  g_iValue:DQ;引用外部变量

 

.DATA

 

val1 DQ ?;自己定义变量

 

.CODE

 

func1 PROC

 

mov r10, g_iValue;使用func.h中的外部变量

mov val1,r10;使用自定义变量

mov rax,val1

ret;如果不返回,那么会继续执行func2

FUNC1 ENDP

 

func2 PROC

CALL print2 ;调用func.cpp中的外部函数

ret

FUNC2 ENDP

END

 

编译amd64xx.asm需要做单独的设置:

在amd64xx.asm文件上单击鼠标右键,选择“属性(properties)”:

在Excluded From Build中选择No

在Item Type中选择Custom Build Tool

然后点击确定。

再次右键打开amd64xx.asm的properties属性:

这个时候会看见一个Custome Build Tool的选项,如下:

在Command Line处输入:ml64 /Fo $(IntDir)%(fileName).obj /c %(fileName).asm

在Outputs处输入:$(IntDir)%(fileName).obj;%(Outputs)

然后点击确定。

 

最后在x64_asm.cpp的main函数里调用amd64xx.asm中的func1和func2:

 

//x64_asm.cpp

#include "stdafx.h"

#include "amd64xx.h"

 

int _tmain(int argc, _TCHAR* argv[])

{

    printf("%d\n",func1());//amd64xx.asm中定义的func1

    func2();//amd64xx.asm中定义的func2

    return 0;

}

最后在项目名称上右键,选择build编译项目:

如果没有报错,那么就可以直接运行程序了:

 

 

此种方法,是学习Windows内核X64驱动,VT等的基础。

 

项目代码:点击下载

本文转载自:https://www.mallocfree.com/basic/asm/asm-4-x64.htm

共有 人打赏支持
simpower
粉丝 24
博文 536
码字总数 38046
作品 0
海淀
程序员
[分享] X64下调试工具(不断更新)

下面我已列了一下常用工具,欢迎大家补充 查壳工具: Exeinfo PE 推荐使用 www.exeinfo.xn.pl Detect It Easy http://pan.baidu.com/s/1dDnaS2d PE工具(X64的): StudyPe+ by zaas 推荐使用...

伽罗kapple
2016/01/25
26
0
Win32-DLL型调试器,注入dll即可调试

GIT传送门: http://git.oschina.net/codetimer/CTDBG 这个调试器是几年前调试游戏的时候做的,现在翻出来共享下。 代码基本上就是C代码,使用Vs编译 (version >= 2010) 过保护的功能只在W...

codetask
2016/11/16
25
0
VS2012下X64平台嵌入汇编程序

VS2012在win32平台编译的时候可以很好的支持汇编语言的嵌入。建立一个控制台应用程序,选择空项目。项目建立好之后添加一个.cpp文件。在cpp文件中写入如下代码: [cpp] view plain copy prin...

simpower
06/26
0
0
Windows 下编译 OpenSSL

简述 OpenSSL 是一个开源的第三方库,它实现了 SSL(Secure SocketLayer)和 TLS(Transport Layer Security)协议,被广泛企业应用所采用。对于一般的开发人员而言,在 Win32 OpenSSL 上下载...

千山万水
01/15
0
0
char* 和 char[] 的区别

一、代码 有关下面代码,p和q的区别是什么: 二、区别和解释 p和q的区别是: p 是一个指针,指向程序 只读数据段 的”Hello World”,不可以通过p[x] = x 来赋值,因为不能改变只读数据段的内...

yangbodong22011
03/18
0
0

没有更多内容

加载失败,请刷新页面

加载更多

win32截屏并rgb24转yuv420

//最终f的内存布局为BGRA格式,需要保证buf长度足够(>w*h*4)void ScreenCap(void* buf, int w, int h){ HWND hDesk = GetDesktopWindow(); HDC hScreen = GetDC(hDesk); ......

styleman
50分钟前
1
0
php输出mysql取出的中文为??的问题

解决方法: @ $db=new mysqli(DB_HOST,DB_USER,DB_PASSWORD,DB_DB); $db->query("set names utf8");//添加此语句,可以解决问题...

Aomo
今天
1
2
白话SpringCloud | 第五章:服务容错保护(Hystrix)

前言 前一章节,我们知道了如何利用RestTemplate+Ribbon和Feign的方式进行服务的调用。在微服务架构中,一个服务可能会调用很多的其他微服务应用,虽然做了多集群部署,但可能还会存在诸如网...

oKong
今天
2
0
【解惑】领略Java内部类的“内部”

内部类有两种情况: (1) 在类中定义一个类(私有内部类,静态内部类) (2) 在方法中定义一个类(局部内部类,匿名内部类) 1、私有内部类 —— 在方法之间定义的内部类,非静态 我们首先看看类中...

偶尔诗文
今天
1
0
sqlserver 2008 r2 直接下载地址(百度云)

之前下载的sqlserver2008发现不能附加,就卸载了,重新找到了sqlserver2008R2的百度云资源 卸载sqlserver2008还是有点麻烦,不过就是需要删除注册表中的信息 自己来回卸载了3次终于重装sqlse...

dillonxiao
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部