Win32程序集 - WriteFile()到控制台不显示输出

时间:2016-10-12 16:37:56

标签: winapi gcc assembly nasm kernel32

我现在编写一些Windows本机程序集,使用NASM 2.12.01和GCC 4.8.1作为链接器。

然而,这个简单的HelloWorld程序编译和放大没有任何投诉的链接,但不会向控制台屏幕输出任何内容。

似乎GetStdHandle没有向当前控制台返回有效句柄,因此输出不会显示出来。

但问题可能还有其他问题。

代码:

; Name:     hello.asm
; Assemble: nasm.exe -fwin32 hello.asm
; Link:     gcc -mwindows -o hello hello.obj -lkernel32 -lmsvcrt
; Run:      a.exe

BITS 32
extern _GetStdHandle@4
extern _WriteFile@20
extern _ExitProcess@4
extern __getch
extern _puts

SECTION .data
    str:    db `Hello world!\n`         ; C-like strings in NASM with backticks
    strlen  equ $-str
    pause:  db "Do you know where the ANY key is? :-)",0

SECTION .text
GLOBAL _main
_main:
; Stack frame for NumberOfBytesWritten
push ebp
sub esp, 4

; http://msdn.microsoft.com/en-us/library/windows/desktop/ms683231.aspx
; HANDLE WINAPI GetStdHandle(
;   _In_  DWORD nStdHandle
; );
push -11
call _GetStdHandle@4

; http://msdn.microsoft.com/en-us/library/windows/desktop/aa365747.aspx
; BOOL WINAPI WriteFile(
;   _In_         HANDLE hFile,
;   _In_         LPCVOID lpBuffer,
;   _In_         DWORD nNumberOfBytesToWrite,
;   _Out_opt_    LPDWORD lpNumberOfBytesWritten,
;   _Inout_opt_  LPOVERLAPPED lpOverlapped
; );
push 0              ; lpOverlapped,
lea ebx, [ebp-4]    ; EBX: address of NumberOfBytesWritten
push ebx            ; lpNumberOfBytesWritten,
push strlen         ; nNumberOfBytesToWrite
push str            ; lpBuffer,
push eax            ; hFile (result from GetStdHandle
call _WriteFile@20

; msvcrt.dll (C library)
push pause
call _puts          ; http://msdn.microsoft.com/library/tf52y4t1.aspx
add esp, 4
call __getch        ; http://msdn.microsoft.com/library/078sfkak.aspx

; ExitProcess (0)
push 0
call _ExitProcess@4

2 个答案:

答案 0 :(得分:1)

要生成控制台应用程序,必须使用GCC的-mconsole选项。请参阅在线文档section 3.18.55, x86 Windows Options

您正在使用-mwindows来创建GUI应用程序。启动GUI应用程序时,Windows不会创建控制台或设置标准句柄。

答案 1 :(得分:0)

您永远不会正确设置堆栈框架!

这不是正确的方法:

push ebp
sub esp, 4
你错过了什么吗?你的筹码搞砸了!

延长应该是:

push ebp
  mov   ebp, esp
  sub   esp, 4 

对于epilouge,只需反转。