// Copyright 2021 The Tint Authors. // // Licensed under the Apache License, Version 2.0(the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #ifndef SRC_SEM_FUNCTION_H_ #define SRC_SEM_FUNCTION_H_ #include #include #include #include "src/ast/variable.h" #include "src/sem/call_target.h" namespace tint { // Forward declarations namespace ast { class BindingDecoration; class BuiltinDecoration; class CallExpression; class Function; class GroupDecoration; class LocationDecoration; class ReturnStatement; } // namespace ast namespace sem { class Variable; /// WorkgroupDimension describes the size of a single dimension of an entry /// point's workgroup size. struct WorkgroupDimension { /// The size of this dimension. uint32_t value; /// A pipeline-overridable constant that overrides the size, or nullptr if /// this dimension is not overridable. const ast::Variable* overridable_const = nullptr; }; /// Function holds the semantic information for function nodes. class Function : public Castable { public: /// A vector of [Variable*, ast::Variable::BindingPoint] pairs using VariableBindings = std::vector>; /// Constructor /// @param declaration the ast::Function /// @param return_type the return type of the function /// @param parameters the parameters to the function /// @param referenced_module_vars the referenced module variables /// @param local_referenced_module_vars the locally referenced module /// @param return_statements the function return statements /// @param callsites the callsites of the function /// @param ancestor_entry_points the ancestor entry points /// @param workgroup_size the workgroup size Function(ast::Function* declaration, Type* return_type, std::vector parameters, std::vector referenced_module_vars, std::vector local_referenced_module_vars, std::vector return_statements, std::vector callsites, std::vector ancestor_entry_points, std::array workgroup_size); /// Destructor ~Function() override; /// @returns the ast::Function declaration ast::Function* Declaration() const { return declaration_; } /// Note: If this function calls other functions, the return will also include /// all of the referenced variables from the callees. /// @returns the referenced module variables const std::vector& ReferencedModuleVariables() const { return referenced_module_vars_; } /// @returns the locally referenced module variables const std::vector& LocalReferencedModuleVariables() const { return local_referenced_module_vars_; } /// @returns the return statements const std::vector ReturnStatements() const { return return_statements_; } /// @returns the list of callsites of this function std::vector CallSites() const { return callsites_; } /// @returns the ancestor entry points const std::vector& AncestorEntryPoints() const { return ancestor_entry_points_; } /// Retrieves any referenced location variables /// @returns the pair. std::vector> ReferencedLocationVariables() const; /// Retrieves any referenced builtin variables /// @returns the pair. std::vector> ReferencedBuiltinVariables() const; /// Retrieves any referenced uniform variables. Note, the variables must be /// decorated with both binding and group decorations. /// @returns the referenced uniforms VariableBindings ReferencedUniformVariables() const; /// Retrieves any referenced storagebuffer variables. Note, the variables /// must be decorated with both binding and group decorations. /// @returns the referenced storagebuffers VariableBindings ReferencedStorageBufferVariables() const; /// Retrieves any referenced regular Sampler variables. Note, the /// variables must be decorated with both binding and group decorations. /// @returns the referenced storagebuffers VariableBindings ReferencedSamplerVariables() const; /// Retrieves any referenced comparison Sampler variables. Note, the /// variables must be decorated with both binding and group decorations. /// @returns the referenced storagebuffers VariableBindings ReferencedComparisonSamplerVariables() const; /// Retrieves any referenced sampled textures variables. Note, the /// variables must be decorated with both binding and group decorations. /// @returns the referenced sampled textures VariableBindings ReferencedSampledTextureVariables() const; /// Retrieves any referenced multisampled textures variables. Note, the /// variables must be decorated with both binding and group decorations. /// @returns the referenced sampled textures VariableBindings ReferencedMultisampledTextureVariables() const; /// Retrieves any referenced storage texture variables. Note, the variables /// must be decorated with both binding and group decorations. /// @returns the referenced storage textures VariableBindings ReferencedStorageTextureVariables() const; /// Retrieves any referenced depth texture variables. Note, the variables /// must be decorated with both binding and group decorations. /// @returns the referenced depth textures VariableBindings ReferencedDepthTextureVariables() const; /// Retrieves any referenced external texture variables. Note, the variables /// must be decorated with both binding and group decorations. /// @returns the referenced external textures VariableBindings ReferencedExternalTextureVariables() const; /// Checks if the given entry point is an ancestor /// @param sym the entry point symbol /// @returns true if `sym` is an ancestor entry point of this function bool HasAncestorEntryPoint(Symbol sym) const; /// @returns the workgroup size {x, y, z} for the function. const std::array& workgroup_size() const { return workgroup_size_; } private: VariableBindings ReferencedSamplerVariablesImpl(ast::SamplerKind kind) const; VariableBindings ReferencedSampledTextureVariablesImpl( bool multisampled) const; ast::Function* const declaration_; std::vector const referenced_module_vars_; std::vector const local_referenced_module_vars_; std::vector const return_statements_; std::vector const callsites_; std::vector const ancestor_entry_points_; std::array workgroup_size_; }; } // namespace sem } // namespace tint #endif // SRC_SEM_FUNCTION_H_