Index: lib/Target/X86/X86TargetMachine.cpp =================================================================== --- lib/Target/X86/X86TargetMachine.cpp +++ lib/Target/X86/X86TargetMachine.cpp @@ -37,8 +37,8 @@ return make_unique(); } - if (TT.isOSLinux()) - return make_unique(); + if (TT.isOSLinux() || TT.isOSNaCl()) + return make_unique(); if (TT.isOSBinFormatELF()) return make_unique(); if (TT.isKnownWindowsMSVCEnvironment()) Index: lib/Target/X86/X86TargetObjectFile.h =================================================================== --- lib/Target/X86/X86TargetObjectFile.h +++ lib/Target/X86/X86TargetObjectFile.h @@ -44,9 +44,9 @@ const MCExpr *getDebugThreadLocalSymbol(const MCSymbol *Sym) const override; }; - /// X86LinuxTargetObjectFile - This implementation is used for linux x86 - /// and x86-64. - class X86LinuxTargetObjectFile : public X86ELFTargetObjectFile { + /// X86LinuxNaClTargetObjectFile - This implementation is used for linux and + /// Native Client on x86 and x86-64. + class X86LinuxNaClTargetObjectFile : public X86ELFTargetObjectFile { void Initialize(MCContext &Ctx, const TargetMachine &TM) override; }; Index: lib/Target/X86/X86TargetObjectFile.cpp =================================================================== --- lib/Target/X86/X86TargetObjectFile.cpp +++ lib/Target/X86/X86TargetObjectFile.cpp @@ -66,7 +66,8 @@ } void -X86LinuxTargetObjectFile::Initialize(MCContext &Ctx, const TargetMachine &TM) { +X86LinuxNaClTargetObjectFile::Initialize(MCContext &Ctx, + const TargetMachine &TM) { TargetLoweringObjectFileELF::Initialize(Ctx, TM); InitializeELF(TM.Options.UseInitArray); } 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-NEXT: .align 4 +; NACL-NEXT: .long g +; NACL-NEXT: .section .init_array,"aw",@init_array +; NACL-NEXT: .align 4 +; NACL-NEXT: .long f