// // Copyright (c) 2002-2015 The ANGLE Project Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. // // Defines analyses of the AST needed for HLSL generation #ifndef COMPILER_TRANSLATOR_ASTMETADATAHLSL_H_ #define COMPILER_TRANSLATOR_ASTMETADATAHLSL_H_ #include #include namespace sh { class CallDAG; class TIntermNode; class TIntermIfElse; class TIntermLoop; struct ASTMetadataHLSL { ASTMetadataHLSL() : mUsesGradient(false), mCalledInDiscontinuousLoop(false), mHasGradientLoopInCallGraph(false), mNeedsLod0(false) {} // Here "something uses a gradient" means here that it either contains a // gradient operation, or a call to a function that uses a gradient. bool hasGradientInCallGraph(TIntermLoop *node); bool hasGradientLoop(TIntermIfElse *node); // Does the function use a gradient. bool mUsesGradient; // Even if usesGradient is true, some control flow might not use a gradient // so we store the set of all gradient-using control flows. std::set mControlFlowsContainingGradient; // Remember information about the discontinuous loops and which functions // are called in such loops. bool mCalledInDiscontinuousLoop; bool mHasGradientLoopInCallGraph; std::set mDiscontinuousLoops; std::set mIfsContainingGradientLoop; // Will we need to generate a Lod0 version of the function. bool mNeedsLod0; }; typedef std::vector MetadataList; // Return the AST analysis result, in the order defined by the call DAG MetadataList CreateASTMetadataHLSL(TIntermNode *root, const CallDAG &callDag); } // namespace sh #endif // COMPILER_TRANSLATOR_ASTMETADATAHLSL_H_