From: Martin Storsjo Date: Fri, 5 Oct 2018 19:43:24 +0000 (+0000) Subject: [COFF] Do MinGW specific entry/subsystem inference X-Git-Tag: llvmorg-8.0.0-rc1~7138 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=08ab568aaaaab16b68453a0f16e7ee5853ccdd5d;p=platform%2Fupstream%2Fllvm.git [COFF] Do MinGW specific entry/subsystem inference ld.bfd doesn't do any inference of subsystem; unless the windows subsystem is specified, the console subsystem is used. For the console subsystem, the entry point is called mainCRTStartup, regardless of whether the the user code entry point is main or wmain. The same goes for the windows subsystem, where the entry point always is WinMainCRTStartup, for both WinMain and wWinMain in user code. One detail that we don't emulate, is that if the inferred entry point is undefined, ld.bfd silently just sets the entry point to the start of the image. And if an explicit entry point is set, but it is undefined, the link still succeeds but the linker warns about the entry point not being found. Differential Revision: https://reviews.llvm.org/D52931 llvm-svn: 343879 --- diff --git a/lld/COFF/Driver.cpp b/lld/COFF/Driver.cpp index 290e1fd..c2fc048 100644 --- a/lld/COFF/Driver.cpp +++ b/lld/COFF/Driver.cpp @@ -430,6 +430,11 @@ StringRef LinkerDriver::findDefaultEntry() { assert(Config->Subsystem != IMAGE_SUBSYSTEM_UNKNOWN && "must handle /subsystem before calling this"); + if (Config->MinGW) + return mangle(Config->Subsystem == IMAGE_SUBSYSTEM_WINDOWS_GUI + ? "WinMainCRTStartup" + : "mainCRTStartup"); + if (Config->Subsystem == IMAGE_SUBSYSTEM_WINDOWS_GUI) { if (findUnderscoreMangle("wWinMain")) { if (!findUnderscoreMangle("WinMain")) @@ -449,6 +454,8 @@ StringRef LinkerDriver::findDefaultEntry() { WindowsSubsystem LinkerDriver::inferSubsystem() { if (Config->DLL) return IMAGE_SUBSYSTEM_WINDOWS_GUI; + if (Config->MinGW) + return IMAGE_SUBSYSTEM_WINDOWS_CUI; // Note that link.exe infers the subsystem from the presence of these // functions even if /entry: or /nodefaultlib are passed which causes them // to not be called. diff --git a/lld/test/COFF/entry-inference-mingw.s b/lld/test/COFF/entry-inference-mingw.s new file mode 100644 index 0000000..cf35620 --- /dev/null +++ b/lld/test/COFF/entry-inference-mingw.s @@ -0,0 +1,44 @@ +# REQUIRES: x86 +# RUN: llvm-mc -triple=x86_64-windows-gnu %s -filetype=obj -o %t.o + +# RUN: lld-link -lldmingw %t.o -out:%t-default.exe 2>&1 | FileCheck -allow-empty -check-prefix=LINK %s +# RUN: lld-link -lldmingw %t.o -out:%t-cui.exe -subsystem:console 2>&1 | FileCheck -allow-empty -check-prefix=LINK %s +# RUN: lld-link -lldmingw %t.o -out:%t-gui.exe -subsystem:windows 2>&1 | FileCheck -allow-empty -check-prefix=LINK %s + +# RUN: llvm-readobj -file-headers %t-default.exe | FileCheck -check-prefix=CUI %s +# RUN: llvm-readobj -file-headers %t-cui.exe | FileCheck -check-prefix=CUI %s +# RUN: llvm-readobj -file-headers %t-gui.exe | FileCheck -check-prefix=GUI %s + +# Check that this doesn't print any warnings. +# LINK-NOT: found both wmain and main + +# CUI: AddressOfEntryPoint: 0x1001 +# CUI: Subsystem: IMAGE_SUBSYSTEM_WINDOWS_CUI (0x3) + +# GUI: AddressOfEntryPoint: 0x1002 +# GUI: Subsystem: IMAGE_SUBSYSTEM_WINDOWS_GUI (0x2) + + + .text + .globl mainCRTStartup + .globl WinMainCRTStartup +# MinGW only uses the entry points above, these other ones aren't +# used as entry. + .globl main + .globl wmain + .globl wmainCRTStartup + .globl wWinMainCRTStartup +foo: + ret +mainCRTStartup: + ret +WinMainCRTStartup: + ret +main: + ret +wmain: + ret +wmainCRTStartup: + ret +wWinMainCRTStartup: + ret diff --git a/lld/test/COFF/subsystem-inference-mingw.s b/lld/test/COFF/subsystem-inference-mingw.s new file mode 100644 index 0000000..3339e64 --- /dev/null +++ b/lld/test/COFF/subsystem-inference-mingw.s @@ -0,0 +1,17 @@ +# REQUIRES: x86 +# RUN: llvm-mc -triple=x86_64-windows-gnu %s -filetype=obj -o %t.o + +# RUN: lld-link -lldmingw %t.o -out:%t.exe +# RUN: llvm-readobj -file-headers %t.exe | FileCheck %s + +# CHECK: AddressOfEntryPoint: 0x1001 +# CHECK: Subsystem: IMAGE_SUBSYSTEM_WINDOWS_CUI (0x3) + + .text + .globl foo + .globl mainCRTStartup +foo: + ret +mainCRTStartup: + call foo + ret