diff --git a/clang/lib/Driver/ToolChains/Clang.cpp b/clang/lib/Driver/ToolChains/Clang.cpp --- a/clang/lib/Driver/ToolChains/Clang.cpp +++ b/clang/lib/Driver/ToolChains/Clang.cpp @@ -4973,10 +4973,8 @@ // Enable -mconstructor-aliases except on darwin, where we have to work around // a linker bug (see ), and CUDA/AMDGPU device code, - // where aliases aren't supported. Similarly, aliases aren't yet supported - // for AIX. - if (!RawTriple.isOSDarwin() && !RawTriple.isNVPTX() && - !RawTriple.isAMDGPU() && !RawTriple.isOSAIX()) + // where aliases aren't supported. + if (!RawTriple.isOSDarwin() && !RawTriple.isNVPTX() && !RawTriple.isAMDGPU()) CmdArgs.push_back("-mconstructor-aliases"); // Darwin's kernel doesn't support guard variables; just die if we diff --git a/clang/test/Driver/aix-constructor-alias.c b/clang/test/Driver/aix-constructor-alias.c --- a/clang/test/Driver/aix-constructor-alias.c +++ b/clang/test/Driver/aix-constructor-alias.c @@ -1,7 +1,7 @@ -// Check that we don't pass -mconstructor-aliases when compiling for AIX. +// Check that we pass -mconstructor-aliases when compiling for AIX. // RUN: %clang -### -target powerpc-ibm-aix7.1.0.0 %s -c -o %t.o 2>&1 \ // RUN: | FileCheck %s // RUN: %clang -### -target powerpc64-ibm-aix7.1.0.0 %s -c -o %t.o 2>&1 \ // RUN: | FileCheck %s -// CHECK-NOT: "-mconstructor-aliases" +// CHECK: "-mconstructor-aliases"