mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-06-05 22:23:29 +00:00
For fewer heap allocations, faster lookups. Change-Id: I02da7c1a63608096ec898b0d89f9f97c6db8733f Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/98141 Commit-Queue: Ben Clayton <bclayton@google.com> Reviewed-by: Dan Sinclair <dsinclair@chromium.org> Kokoro: Kokoro <noreply+kokoro@google.com>
282 lines
11 KiB
C++
282 lines
11 KiB
C++
// 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_TINT_SEM_FUNCTION_H_
|
|
#define SRC_TINT_SEM_FUNCTION_H_
|
|
|
|
#include <array>
|
|
#include <utility>
|
|
#include <vector>
|
|
|
|
#include "src/tint/ast/variable.h"
|
|
#include "src/tint/sem/call.h"
|
|
#include "src/tint/utils/unique_vector.h"
|
|
#include "src/tint/utils/vector.h"
|
|
|
|
// Forward declarations
|
|
namespace tint::ast {
|
|
class BuiltinAttribute;
|
|
class Function;
|
|
class LocationAttribute;
|
|
class ReturnStatement;
|
|
} // namespace tint::ast
|
|
namespace tint::sem {
|
|
class Builtin;
|
|
class Variable;
|
|
} // namespace tint::sem
|
|
|
|
namespace tint::sem {
|
|
|
|
/// 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;
|
|
};
|
|
|
|
/// WorkgroupSize is a three-dimensional array of WorkgroupDimensions.
|
|
using WorkgroupSize = std::array<WorkgroupDimension, 3>;
|
|
|
|
/// Function holds the semantic information for function nodes.
|
|
class Function final : public Castable<Function, CallTarget> {
|
|
public:
|
|
/// A vector of [Variable*, ast::VariableBindingPoint] pairs
|
|
using VariableBindings = std::vector<std::pair<const Variable*, ast::VariableBindingPoint>>;
|
|
|
|
/// Constructor
|
|
/// @param declaration the ast::Function
|
|
/// @param return_type the return type of the function
|
|
/// @param parameters the parameters to the function
|
|
Function(const ast::Function* declaration,
|
|
Type* return_type,
|
|
utils::VectorRef<Parameter*> parameters);
|
|
|
|
/// Destructor
|
|
~Function() override;
|
|
|
|
/// @returns the ast::Function declaration
|
|
const ast::Function* Declaration() const { return declaration_; }
|
|
|
|
/// @returns the workgroup size {x, y, z} for the function.
|
|
const sem::WorkgroupSize& WorkgroupSize() const { return workgroup_size_; }
|
|
|
|
/// Sets the workgroup size {x, y, z} for the function.
|
|
/// @param workgroup_size the new workgroup size of the function
|
|
void SetWorkgroupSize(sem::WorkgroupSize workgroup_size) {
|
|
workgroup_size_ = std::move(workgroup_size);
|
|
}
|
|
|
|
/// @returns all directly referenced global variables
|
|
const utils::UniqueVector<const GlobalVariable*, 4>& DirectlyReferencedGlobals() const {
|
|
return directly_referenced_globals_;
|
|
}
|
|
|
|
/// Records that this function directly references the given global variable.
|
|
/// Note: Implicitly adds this global to the transtively-called globals.
|
|
/// @param global the module-scope variable
|
|
void AddDirectlyReferencedGlobal(const sem::GlobalVariable* global) {
|
|
directly_referenced_globals_.Add(global);
|
|
transitively_referenced_globals_.Add(global);
|
|
}
|
|
|
|
/// @returns all transitively referenced global variables
|
|
const utils::UniqueVector<const GlobalVariable*, 8>& TransitivelyReferencedGlobals() const {
|
|
return transitively_referenced_globals_;
|
|
}
|
|
|
|
/// Records that this function transitively references the given global
|
|
/// variable.
|
|
/// @param global the module-scoped variable
|
|
void AddTransitivelyReferencedGlobal(const sem::GlobalVariable* global) {
|
|
transitively_referenced_globals_.Add(global);
|
|
}
|
|
|
|
/// @returns the list of functions that this function transitively calls.
|
|
const utils::UniqueVector<const Function*, 8>& TransitivelyCalledFunctions() const {
|
|
return transitively_called_functions_;
|
|
}
|
|
|
|
/// Records that this function transitively calls `function`.
|
|
/// @param function the function this function transitively calls
|
|
void AddTransitivelyCalledFunction(const Function* function) {
|
|
transitively_called_functions_.Add(function);
|
|
}
|
|
|
|
/// @returns the list of builtins that this function directly calls.
|
|
const utils::UniqueVector<const Builtin*, 4>& DirectlyCalledBuiltins() const {
|
|
return directly_called_builtins_;
|
|
}
|
|
|
|
/// Records that this function transitively calls `builtin`.
|
|
/// @param builtin the builtin this function directly calls
|
|
void AddDirectlyCalledBuiltin(const Builtin* builtin) {
|
|
directly_called_builtins_.Add(builtin);
|
|
}
|
|
|
|
/// Adds the given texture/sampler pair to the list of unique pairs
|
|
/// that this function uses (directly or indirectly). These can only
|
|
/// be parameters to this function or global variables. Uniqueness is
|
|
/// ensured by texture_sampler_pairs_ being a UniqueVector.
|
|
/// @param texture the texture (must be non-null)
|
|
/// @param sampler the sampler (null indicates a texture-only reference)
|
|
void AddTextureSamplerPair(const sem::Variable* texture, const sem::Variable* sampler) {
|
|
texture_sampler_pairs_.Add(VariablePair(texture, sampler));
|
|
}
|
|
|
|
/// @returns the list of texture/sampler pairs that this function uses
|
|
/// (directly or indirectly).
|
|
const utils::Vector<VariablePair, 8>& TextureSamplerPairs() const {
|
|
return texture_sampler_pairs_;
|
|
}
|
|
|
|
/// @returns the list of direct calls to functions / builtins made by this
|
|
/// function
|
|
std::vector<const Call*> DirectCallStatements() const { return direct_calls_; }
|
|
|
|
/// Adds a record of the direct function / builtin calls made by this
|
|
/// function
|
|
/// @param call the call
|
|
void AddDirectCall(const Call* call) { direct_calls_.emplace_back(call); }
|
|
|
|
/// @param target the target of a call
|
|
/// @returns the Call to the given CallTarget, or nullptr the target was not
|
|
/// called by this function.
|
|
const Call* FindDirectCallTo(const CallTarget* target) const {
|
|
for (auto* call : direct_calls_) {
|
|
if (call->Target() == target) {
|
|
return call;
|
|
}
|
|
}
|
|
return nullptr;
|
|
}
|
|
|
|
/// @returns the list of callsites of this function
|
|
std::vector<const Call*> CallSites() const { return callsites_; }
|
|
|
|
/// Adds a record of a callsite to this function
|
|
/// @param call the callsite
|
|
void AddCallSite(const Call* call) { callsites_.emplace_back(call); }
|
|
|
|
/// @returns the ancestor entry points
|
|
const std::vector<const Function*>& AncestorEntryPoints() const {
|
|
return ancestor_entry_points_;
|
|
}
|
|
|
|
/// Adds a record that the given entry point transitively calls this function
|
|
/// @param entry_point the entry point that transtively calls this function
|
|
void AddAncestorEntryPoint(const sem::Function* entry_point) {
|
|
ancestor_entry_points_.emplace_back(entry_point);
|
|
}
|
|
|
|
/// Retrieves any referenced location variables
|
|
/// @returns the <variable, attribute> pair.
|
|
std::vector<std::pair<const Variable*, const ast::LocationAttribute*>>
|
|
TransitivelyReferencedLocationVariables() const;
|
|
|
|
/// Retrieves any referenced builtin variables
|
|
/// @returns the <variable, attribute> pair.
|
|
std::vector<std::pair<const Variable*, const ast::BuiltinAttribute*>>
|
|
TransitivelyReferencedBuiltinVariables() const;
|
|
|
|
/// Retrieves any referenced uniform variables. Note, the variables must be
|
|
/// decorated with both binding and group attributes.
|
|
/// @returns the referenced uniforms
|
|
VariableBindings TransitivelyReferencedUniformVariables() const;
|
|
|
|
/// Retrieves any referenced storagebuffer variables. Note, the variables
|
|
/// must be decorated with both binding and group attributes.
|
|
/// @returns the referenced storagebuffers
|
|
VariableBindings TransitivelyReferencedStorageBufferVariables() const;
|
|
|
|
/// Retrieves any referenced regular Sampler variables. Note, the
|
|
/// variables must be decorated with both binding and group attributes.
|
|
/// @returns the referenced storagebuffers
|
|
VariableBindings TransitivelyReferencedSamplerVariables() const;
|
|
|
|
/// Retrieves any referenced comparison Sampler variables. Note, the
|
|
/// variables must be decorated with both binding and group attributes.
|
|
/// @returns the referenced storagebuffers
|
|
VariableBindings TransitivelyReferencedComparisonSamplerVariables() const;
|
|
|
|
/// Retrieves any referenced sampled textures variables. Note, the
|
|
/// variables must be decorated with both binding and group attributes.
|
|
/// @returns the referenced sampled textures
|
|
VariableBindings TransitivelyReferencedSampledTextureVariables() const;
|
|
|
|
/// Retrieves any referenced multisampled textures variables. Note, the
|
|
/// variables must be decorated with both binding and group attributes.
|
|
/// @returns the referenced sampled textures
|
|
VariableBindings TransitivelyReferencedMultisampledTextureVariables() const;
|
|
|
|
/// Retrieves any referenced variables of the given type. Note, the variables
|
|
/// must be decorated with both binding and group attributes.
|
|
/// @param type the type of the variables to find
|
|
/// @returns the referenced variables
|
|
VariableBindings TransitivelyReferencedVariablesOfType(const tint::TypeInfo* type) const;
|
|
|
|
/// Retrieves any referenced variables of the given type. Note, the variables
|
|
/// must be decorated with both binding and group attributes.
|
|
/// @returns the referenced variables
|
|
template <typename T>
|
|
VariableBindings TransitivelyReferencedVariablesOfType() const {
|
|
return TransitivelyReferencedVariablesOfType(&TypeInfo::Of<T>());
|
|
}
|
|
|
|
/// 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;
|
|
|
|
/// Sets that this function has a discard statement
|
|
void SetHasDiscard() { has_discard_ = true; }
|
|
|
|
/// Returns true if this function has a discard statement
|
|
/// @returns true if this function has a discard statement
|
|
bool HasDiscard() const { return has_discard_; }
|
|
|
|
/// @return the behaviors of this function
|
|
const sem::Behaviors& Behaviors() const { return behaviors_; }
|
|
|
|
/// @return the behaviors of this function
|
|
sem::Behaviors& Behaviors() { return behaviors_; }
|
|
|
|
private:
|
|
Function(const Function&) = delete;
|
|
Function(Function&&) = delete;
|
|
|
|
VariableBindings TransitivelyReferencedSamplerVariablesImpl(ast::SamplerKind kind) const;
|
|
VariableBindings TransitivelyReferencedSampledTextureVariablesImpl(bool multisampled) const;
|
|
|
|
const ast::Function* const declaration_;
|
|
|
|
sem::WorkgroupSize workgroup_size_;
|
|
utils::UniqueVector<const GlobalVariable*, 4> directly_referenced_globals_;
|
|
utils::UniqueVector<const GlobalVariable*, 8> transitively_referenced_globals_;
|
|
utils::UniqueVector<const Function*, 8> transitively_called_functions_;
|
|
utils::UniqueVector<const Builtin*, 4> directly_called_builtins_;
|
|
utils::UniqueVector<VariablePair, 8> texture_sampler_pairs_;
|
|
std::vector<const Call*> direct_calls_;
|
|
std::vector<const Call*> callsites_;
|
|
std::vector<const Function*> ancestor_entry_points_;
|
|
bool has_discard_ = false;
|
|
sem::Behaviors behaviors_{sem::Behavior::kNext};
|
|
};
|
|
|
|
} // namespace tint::sem
|
|
|
|
#endif // SRC_TINT_SEM_FUNCTION_H_
|