python3kgae marked 3 inline comments as done. python3kgae added inline comments.
================ Comment at: clang/lib/CodeGen/CGHLSLRuntime.cpp:208 + // ctors/dtors added for entry. + Triple T(M.getTargetTriple()); + if (T.getEnvironment() != Triple::EnvironmentType::Library) { ---------------- beanz wrote: > I question whether we should do this early or late. It feels wrong to me to > have clang modifying IR. There are places where clang does this sort of thing > so it isn't unprecedented, but it feels wrong. The reason I want to do it is that with the global variable for ctors/dtors, the ctor/dtor functions will not be removed in optimization passes. As a result, the global variable will have 2 stores ( 1 for the ctor, 1 for the inlined ctor ). That might cause optimizations to go a different path. Also, we insert the call of dtor/ctors to entry which already did what the global variable for ctor/dtor asked. If the global variable for ctor/dtor is still kept, other backends might call the ctor/dtor again. ================ Comment at: clang/lib/Sema/SemaDeclAttr.cpp:6898 Triple Target = S.Context.getTargetInfo().getTriple(); - if (Target.getEnvironment() != Triple::Compute) { + if (Target.getEnvironment() != Triple::Compute && + Target.getEnvironment() != Triple::Library) { ---------------- beanz wrote: > This change should be separate. It doesn't directly relate to the change > you've described in the description. I understand you need it to use the same > test source, but don't group unrelated functional changes. I'll create another PR for this. ================ Comment at: clang/test/CodeGenHLSL/GlobalDestructorsLib.hlsl:1 -// RUN: %clang_cc1 -triple dxil-pc-shadermodel6.0-compute -std=hlsl202x -S -emit-llvm -disable-llvm-passes %s -o - | FileCheck %s +// RUN: %clang_cc1 -triple dxil-pc-shadermodel6.3-library -std=hlsl202x -S -emit-llvm -disable-llvm-passes %s -o - | FileCheck %s + ---------------- beanz wrote: > The source of this test and the test it was copied from are almost identical. > It feels very much like they should be the same file with different check > prefixes. You can even have them share a check prefix for the things that are > common and only have a differing prefix for the things that are different. Will merge it. Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D133993/new/ https://reviews.llvm.org/D133993 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits