Index: lib/Target/X86/X86TargetMachine.cpp =================================================================== --- lib/Target/X86/X86TargetMachine.cpp +++ lib/Target/X86/X86TargetMachine.cpp @@ -37,7 +37,7 @@ return make_unique(); } - if (TT.isOSLinux()) + if (TT.isOSLinux() || TT.isOSNaCl()) return make_unique(); if (TT.isOSBinFormatELF()) return make_unique(); Index: test/CodeGen/X86/constructor.ll =================================================================== --- test/CodeGen/X86/constructor.ll +++ test/CodeGen/X86/constructor.ll @@ -1,5 +1,6 @@ ; RUN: llc -mtriple x86_64-pc-linux -use-ctors < %s | FileCheck --check-prefix=CTOR %s ; RUN: llc -mtriple x86_64-pc-linux < %s | FileCheck --check-prefix=INIT-ARRAY %s +; RUN: llc -mtriple x86_64-unknown-nacl < %s | FileCheck --check-prefix=NACL %s @llvm.global_ctors = appending global [2 x { i32, void ()*, i8* }] [{ i32, void ()*, i8* } { i32 65535, void ()* @f, i8* null}, { i32, void ()*, i8* } { i32 15, void ()* @g, i8* @v }] @v = weak_odr global i8 0 @@ -27,3 +28,10 @@ ; INIT-ARRAY-NEXT: .section .init_array,"aw",@init_array ; INIT-ARRAY-NEXT: .align 8 ; INIT-ARRAY-NEXT: .quad f + +; NACL: .section .init_array.15,"aGw",@init_array,v,comdat +; NACL: .align 4 +; NACL: .long g +; NACL: .section .init_array,"aw",@init_array +; NACL: .align 4 +; NACL: .long f