在装了F:\c\MinGW\lib的情况下
masm,nasm,gas,
test_win.s
.section .data out_text: .asciz "hello world" .section .text .globl _main _main: pushl $out_text call _printf pushl $0 call _exit
这里用到了c运行时的main,exit,printf函数,因为win32的原因多加了个下划线
3.编译
as test_win.s -o test_win.o -gstabs ld test_win.o -o test_win.exe -LF:/c/MinGW/lib -lcrtdll
-gstabs保留了调试相关的符号表
-LF:/c/MinGW/lib -lcrtdll链接了c运行时,注意mingw路径是我机器上的
调试
gdb test_win.exe l b 5 r i r
另外查看寄存器可用"i r"指令
★★★★★★★★★★★★★★★★★★
com版本的hello world
test.s
.code16 .text movw %cs, %ax movw %ax, %ds movw %ax, %es movw %ax, %ss movw $11, %cx movw $0x1301,%ax movb $0x07,%bl movw $0,%dx movw $outstring,%bp int $0x10 jmp . outstring: .asciz "hello world"
注意.code16是很有必要的 (2)编译 as test.s -o test.o ld test.o -Ttext 0x0100 -o test.exe objcopy.exe -R .pdr -R .comment -R .note -S -O binary test.exe test.com 最后的objcopy将编译后的按binary输出成.com格式的
[另外如果跳过第二部exe生成,直接从.o生成.com也是可以运行的,不过对比发现有1bit的异常引起了输出字符的乱码
具体原因我就不去纠结的探索了,如果修改了那一比特,字符显示就正常了]
另外链接时的-Ttext 0x0100也可以用如下lds文件来控制
SECTIONS
{
. = 0x0100;
.text : {*(.text)}
}
同时链接时的选项应该为-Ttest.lds
此时如果ls -l一下会发现有将近4k之巨,这是因为填充了很多的0,用HxD这样的软件把结尾的0
给干掉再看其大小
参考http://www.cnblogs.com/pingf/archive/2011/03/09/1978263.html