首页
社区
课程
招聘
在汇编程序中调用C语言的库函数
发表于: 2006-1-9 23:12 11516

在汇编程序中调用C语言的库函数

2006-1-9 23:12
11516

在汇编程序中调用C语言的库函数

作者:chaykovsky
E-mail:chaykovsky@163.com
http://JinYawei.MyCool.Net

在汇编语言中如果能够调用C语言的库函数,有时会很方便
先给个示例程序:

.386
.model        flat,stdcall
option        casemap:none

;Include定义
include stdio.inc
includelib msvcrt.lib

.data
szMsg        db        "在汇编程序中调用C的puts函数!",0

.code
start:
        invoke        puts,offset szMsg
        ret
end        start

是不是有点像C中的Hello,world程序。

stdio.inc怎么来的?
stdio.inc为标准输入输出C函数的声明。
MASM32软件包中没有,Microsoft也没有提供,这个是我从VC中的stdio.h转换得来的。

怎么转换?
Microsoft提供了一个.H文件转换为.inc文件的工具 H2INC,在VC的目录中可以找到。

转换命令:
h2inc /WIN32 *.h

stdio.h直接转换时,会出错,要做一些修改。
1)在最前面加一句:
#define _WIN32
2)把文件中的#pragma pack(push,8)与//#pragma pack(pop)注释掉

转换成功之后,只要在程序开头加上
include stdio.inc
includelib msvcrt.lib
就可以调用C语言的输入输出函数了。

建议将msvcrt.lib所在的目录设置到lib环境变量中,并将stdio.inc所在的目录设置到include环境变量中

msvcrt.lib为msvcrt.dll或者msvcr71.dll(VC7.1)的库文件,VC的lib目录中有

使用h2inc转换头文件时需要注意一些事项:

1)/WIN32 参数一定要加上,不然就会按默认的16位进行转换

2)h文件最后一行要有个回车

3)函数类型声明会先转化为@proto_n的形式,然后再声明,如果转换了好几个关文件,那么几个文件中都是从@proto_0开始的,如果你同时包含这几文件时编译器就会提示:symbol type conflict(符号类型冲突)。

解决方法:
转换后,用文本编辑器的全部替换功能,将不同文件中的“proto_”全部替换为不同的字符串。

4)结构和联合也有与3)一样的问题。

5)如果h文件中的函数声名中没有加__cdecl修饰,就会被转换为默认的STDCALL类型

6)h2inc不会转换h文件中的程序,有很多C语法也不支持。

附件中我转换的stdio.inc等头文件和示例程序附件:c_include.rar


[招生]系统0day安全班,企业级设备固件漏洞挖掘,Linux平台漏洞挖掘!

收藏
免费 7
支持
分享
最新回复 (9)
雪    币: 217
活跃值: (99)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
2
好文!虽然用汇编写函数调用的程序没有多大意义:)
2006-1-10 09:59
0
雪    币: 214
活跃值: (230)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
3
好文章,超喜欢。
2006-1-11 08:59
0
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
4
没有了Startup code 很多库函数也用不了了
2006-1-11 09:50
0
雪    币: 223
能力值: (RANK:130 )
在线值:
发帖
回帖
粉丝
5
呵呵,学习了,以前就一直想知道这个要怎么弄,今天算是学到了。

还有,4楼说的库函数指的是哪些?能不能举一两个例子,谢谢了。
2006-1-11 13:27
0
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
6
具体的我也不太懂 大约就是C运行时库 在main之前 会有一些初始化工作 包括全局变量(C++的全局对象)的初始化 一些C的库函数 比如printf 就会用到errno变量
2006-1-11 18:24
0
雪    币: 221
活跃值: (100)
能力值: ( LV6,RANK:90 )
在线值:
发帖
回帖
粉丝
7
如果使用静态库LIBC.LIB的话,需要一些初始化工作,并且程序中必须定义main标号,那样将会很麻烦,而且容易出错。

这里用的是动态链接链接库msvcrt.lib对应DLL为msvcrt.dll或者msvcr71.dll(VC7.1),就像使用Windows的API一样,并不须要初始化工作。

示例程序中的puts可以直接换成printf
2006-1-13 16:18
0
雪    币: 308
活跃值: (362)
能力值: ( LV12,RANK:370 )
在线值:
发帖
回帖
粉丝
8
好,正需要,谢谢!!!
2006-1-14 20:21
0
雪    币: 1334
活跃值: (15)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
9
晕过去了
2006-1-17 20:13
0
雪    币: 290
活跃值: (655)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
10
从来就只有c内嵌汇编,以追求速度等;asm调用c,有些晕,最多也就是因为没有源码,利用.h文件调用lib而已!
2006-1-17 22:53
0
游客
登录 | 注册 方可回帖
返回
//