type::Manager: Simplify interface and use BlockAllocator
Internally use BlockAllocator to allocate the types. When we optimize the allocation patterns of BlockAllocator, this will now benefit both AST nodes and types. Remove Reset(). It was not used. Remove type::Manager::Get(std::unique_ptr<type::Type>) - this was used (via Module::unique_type) in one place, which has easily been migrated to using the standard Module::create<>. Replace all remaining uses of std::unique_ptr<> of types in tests with the standard create<> so we can guarantee uniqueness of the types. Change-Id: Ib0e1fe94e492b31816450df5de0c839a0aefcb9e Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/38362 Commit-Queue: Ben Clayton <bclayton@google.com> Reviewed-by: dan sinclair <dsinclair@chromium.org>
This commit is contained in:
parent
1e29f4beb0
commit
281b602f59
|
@ -69,13 +69,13 @@ extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
|
||||||
}
|
}
|
||||||
std::unordered_set<tint::type::Type*> src_types;
|
std::unordered_set<tint::type::Type*> src_types;
|
||||||
for (auto& src_type : src.types()) {
|
for (auto& src_type : src.types()) {
|
||||||
src_types.emplace(src_type.second.get());
|
src_types.emplace(src_type.second);
|
||||||
}
|
}
|
||||||
for (auto* dst_node : dst.nodes()) {
|
for (auto* dst_node : dst.nodes()) {
|
||||||
ASSERT_EQ(src_nodes.count(dst_node), 0u);
|
ASSERT_EQ(src_nodes.count(dst_node), 0u);
|
||||||
}
|
}
|
||||||
for (auto& dst_type : dst.types()) {
|
for (auto& dst_type : dst.types()) {
|
||||||
ASSERT_EQ(src_types.count(dst_type.second.get()), 0u);
|
ASSERT_EQ(src_types.count(dst_type.second), 0u);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Regenerate the wgsl for the src module. We use this instead of the original
|
// Regenerate the wgsl for the src module. We use this instead of the original
|
||||||
|
|
|
@ -135,21 +135,9 @@ class Module {
|
||||||
return type_mgr_.Get<T>(std::forward<ARGS>(args)...);
|
return type_mgr_.Get<T>(std::forward<ARGS>(args)...);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Moves the type `ty` to the Module, returning a pointer to the unique
|
|
||||||
/// (de-aliased) type.
|
|
||||||
/// When the Module is destructed, the returned `Type` will also be
|
|
||||||
/// destructed.
|
|
||||||
/// @see create()
|
|
||||||
/// @param ty the type to add to the module
|
|
||||||
/// @returns the de-aliased type pointer
|
|
||||||
template <typename T>
|
|
||||||
traits::EnableIfIsType<T, type::Type>* unique_type(std::unique_ptr<T> ty) {
|
|
||||||
return static_cast<T*>(type_mgr_.Get(std::move(ty)));
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns all the declared types in the module
|
/// Returns all the declared types in the module
|
||||||
/// @returns the mapping from name string to type.
|
/// @returns the mapping from name string to type.
|
||||||
const std::unordered_map<std::string, std::unique_ptr<type::Type>>& types() {
|
const std::unordered_map<std::string, type::Type*>& types() {
|
||||||
return type_mgr_.types();
|
return type_mgr_.types();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -128,13 +128,13 @@ fn main() -> void {
|
||||||
}
|
}
|
||||||
std::unordered_set<type::Type*> src_types;
|
std::unordered_set<type::Type*> src_types;
|
||||||
for (auto& src_type : src.types()) {
|
for (auto& src_type : src.types()) {
|
||||||
src_types.emplace(src_type.second.get());
|
src_types.emplace(src_type.second);
|
||||||
}
|
}
|
||||||
for (auto* dst_node : dst.nodes()) {
|
for (auto* dst_node : dst.nodes()) {
|
||||||
ASSERT_EQ(src_nodes.count(dst_node), 0u) << dst_node->str();
|
ASSERT_EQ(src_nodes.count(dst_node), 0u) << dst_node->str();
|
||||||
}
|
}
|
||||||
for (auto& dst_type : dst.types()) {
|
for (auto& dst_type : dst.types()) {
|
||||||
ASSERT_EQ(src_types.count(dst_type.second.get()), 0u)
|
ASSERT_EQ(src_types.count(dst_type.second), 0u)
|
||||||
<< dst_type.second->type_name();
|
<< dst_type.second->type_name();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -275,13 +275,12 @@ class InspectorHelper : public ast::BuilderWithModule {
|
||||||
/// @returns a tuple {struct type, access control type}, where the struct has
|
/// @returns a tuple {struct type, access control type}, where the struct has
|
||||||
/// the layout for an uniform buffer, and the control type wraps the
|
/// the layout for an uniform buffer, and the control type wraps the
|
||||||
/// struct.
|
/// struct.
|
||||||
std::tuple<type::Struct*, std::unique_ptr<type::AccessControl>>
|
std::tuple<type::Struct*, type::AccessControl*> MakeUniformBufferTypes(
|
||||||
MakeUniformBufferTypes(
|
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
std::vector<std::tuple<type::Type*, uint32_t>> members_info) {
|
std::vector<std::tuple<type::Type*, uint32_t>> members_info) {
|
||||||
auto* struct_type = MakeStructType(name, members_info, true);
|
auto* struct_type = MakeStructType(name, members_info, true);
|
||||||
auto access_type = std::make_unique<type::AccessControl>(
|
auto* access_type =
|
||||||
ast::AccessControl::kReadOnly, struct_type);
|
create<type::AccessControl>(ast::AccessControl::kReadOnly, struct_type);
|
||||||
return {struct_type, std::move(access_type)};
|
return {struct_type, std::move(access_type)};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -292,12 +291,11 @@ class InspectorHelper : public ast::BuilderWithModule {
|
||||||
/// @returns a tuple {struct type, access control type}, where the struct has
|
/// @returns a tuple {struct type, access control type}, where the struct has
|
||||||
/// the layout for a storage buffer, and the control type wraps the
|
/// the layout for a storage buffer, and the control type wraps the
|
||||||
/// struct.
|
/// struct.
|
||||||
std::tuple<type::Struct*, std::unique_ptr<type::AccessControl>>
|
std::tuple<type::Struct*, type::AccessControl*> MakeStorageBufferTypes(
|
||||||
MakeStorageBufferTypes(
|
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
std::vector<std::tuple<type::Type*, uint32_t>> members_info) {
|
std::vector<std::tuple<type::Type*, uint32_t>> members_info) {
|
||||||
auto* struct_type = MakeStructType(name, members_info, false);
|
auto* struct_type = MakeStructType(name, members_info, false);
|
||||||
auto access_type = std::make_unique<type::AccessControl>(
|
auto* access_type = create<type::AccessControl>(
|
||||||
ast::AccessControl::kReadWrite, struct_type);
|
ast::AccessControl::kReadWrite, struct_type);
|
||||||
return {struct_type, std::move(access_type)};
|
return {struct_type, std::move(access_type)};
|
||||||
}
|
}
|
||||||
|
@ -309,13 +307,13 @@ class InspectorHelper : public ast::BuilderWithModule {
|
||||||
/// @returns a tuple {struct type, access control type}, where the struct has
|
/// @returns a tuple {struct type, access control type}, where the struct has
|
||||||
/// the layout for a read-only storage buffer, and the control type
|
/// the layout for a read-only storage buffer, and the control type
|
||||||
/// wraps the struct.
|
/// wraps the struct.
|
||||||
std::tuple<type::Struct*, std::unique_ptr<type::AccessControl>>
|
std::tuple<type::Struct*, type::AccessControl*>
|
||||||
MakeReadOnlyStorageBufferTypes(
|
MakeReadOnlyStorageBufferTypes(
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
std::vector<std::tuple<type::Type*, uint32_t>> members_info) {
|
std::vector<std::tuple<type::Type*, uint32_t>> members_info) {
|
||||||
auto* struct_type = MakeStructType(name, members_info, false);
|
auto* struct_type = MakeStructType(name, members_info, false);
|
||||||
auto access_type = std::make_unique<type::AccessControl>(
|
auto* access_type =
|
||||||
ast::AccessControl::kReadOnly, struct_type);
|
create<type::AccessControl>(ast::AccessControl::kReadOnly, struct_type);
|
||||||
return {struct_type, std::move(access_type)};
|
return {struct_type, std::move(access_type)};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -424,28 +422,26 @@ class InspectorHelper : public ast::BuilderWithModule {
|
||||||
/// @param dim the dimensions of the texture
|
/// @param dim the dimensions of the texture
|
||||||
/// @param type the data type of the sampled texture
|
/// @param type the data type of the sampled texture
|
||||||
/// @returns the generated SampleTextureType
|
/// @returns the generated SampleTextureType
|
||||||
std::unique_ptr<type::SampledTexture> MakeSampledTextureType(
|
type::SampledTexture* MakeSampledTextureType(type::TextureDimension dim,
|
||||||
type::TextureDimension dim,
|
type::Type* type) {
|
||||||
type::Type* type) {
|
return create<type::SampledTexture>(dim, type);
|
||||||
return std::make_unique<type::SampledTexture>(dim, type);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Generates a DepthTexture appropriate for the params
|
/// Generates a DepthTexture appropriate for the params
|
||||||
/// @param dim the dimensions of the texture
|
/// @param dim the dimensions of the texture
|
||||||
/// @returns the generated DepthTexture
|
/// @returns the generated DepthTexture
|
||||||
std::unique_ptr<type::DepthTexture> MakeDepthTextureType(
|
type::DepthTexture* MakeDepthTextureType(type::TextureDimension dim) {
|
||||||
type::TextureDimension dim) {
|
return create<type::DepthTexture>(dim);
|
||||||
return std::make_unique<type::DepthTexture>(dim);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Generates a MultisampledTexture appropriate for the params
|
/// Generates a MultisampledTexture appropriate for the params
|
||||||
/// @param dim the dimensions of the texture
|
/// @param dim the dimensions of the texture
|
||||||
/// @param type the data type of the sampled texture
|
/// @param type the data type of the sampled texture
|
||||||
/// @returns the generated SampleTextureType
|
/// @returns the generated SampleTextureType
|
||||||
std::unique_ptr<type::MultisampledTexture> MakeMultisampledTextureType(
|
type::MultisampledTexture* MakeMultisampledTextureType(
|
||||||
type::TextureDimension dim,
|
type::TextureDimension dim,
|
||||||
type::Type* type) {
|
type::Type* type) {
|
||||||
return std::make_unique<type::MultisampledTexture>(dim, type);
|
return create<type::MultisampledTexture>(dim, type);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Adds a sampled texture variable to the module
|
/// Adds a sampled texture variable to the module
|
||||||
|
@ -632,9 +628,9 @@ class InspectorHelper : public ast::BuilderWithModule {
|
||||||
if (vector_type_memo_.find(std::tie(type, count)) ==
|
if (vector_type_memo_.find(std::tie(type, count)) ==
|
||||||
vector_type_memo_.end()) {
|
vector_type_memo_.end()) {
|
||||||
vector_type_memo_[std::tie(type, count)] =
|
vector_type_memo_[std::tie(type, count)] =
|
||||||
std::make_unique<type::Vector>(ty.u32, count);
|
create<type::Vector>(ty.u32, count);
|
||||||
}
|
}
|
||||||
return vector_type_memo_[std::tie(type, count)].get();
|
return vector_type_memo_[std::tie(type, count)];
|
||||||
}
|
}
|
||||||
type::Sampler* sampler_type() { return &sampler_type_; }
|
type::Sampler* sampler_type() { return &sampler_type_; }
|
||||||
type::Sampler* comparison_sampler_type() { return &comparison_sampler_type_; }
|
type::Sampler* comparison_sampler_type() { return &comparison_sampler_type_; }
|
||||||
|
@ -646,8 +642,7 @@ class InspectorHelper : public ast::BuilderWithModule {
|
||||||
type::Sampler sampler_type_;
|
type::Sampler sampler_type_;
|
||||||
type::Sampler comparison_sampler_type_;
|
type::Sampler comparison_sampler_type_;
|
||||||
std::map<uint32_t, type::Array*> array_type_memo_;
|
std::map<uint32_t, type::Array*> array_type_memo_;
|
||||||
std::map<std::tuple<type::Type*, uint32_t>, std::unique_ptr<type::Vector>>
|
std::map<std::tuple<type::Type*, uint32_t>, type::Vector*> vector_type_memo_;
|
||||||
vector_type_memo_;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class InspectorGetEntryPointTest : public InspectorHelper,
|
class InspectorGetEntryPointTest : public InspectorHelper,
|
||||||
|
@ -1282,10 +1277,10 @@ TEST_F(InspectorGetUniformBufferResourceBindingsTest, MissingEntryPoint) {
|
||||||
|
|
||||||
TEST_F(InspectorGetUniformBufferResourceBindingsTest, NonEntryPointFunc) {
|
TEST_F(InspectorGetUniformBufferResourceBindingsTest, NonEntryPointFunc) {
|
||||||
type::Struct* foo_struct_type;
|
type::Struct* foo_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> foo_control_type;
|
type::AccessControl* foo_control_type;
|
||||||
std::tie(foo_struct_type, foo_control_type) =
|
std::tie(foo_struct_type, foo_control_type) =
|
||||||
MakeUniformBufferTypes("foo_type", {{ty.i32, 0}});
|
MakeUniformBufferTypes("foo_type", {{ty.i32, 0}});
|
||||||
AddUniformBuffer("foo_ub", foo_control_type.get(), 0, 0);
|
AddUniformBuffer("foo_ub", foo_control_type, 0, 0);
|
||||||
|
|
||||||
auto* ub_func = MakeStructVariableReferenceBodyFunction("ub_func", "foo_ub",
|
auto* ub_func = MakeStructVariableReferenceBodyFunction("ub_func", "foo_ub",
|
||||||
{{0, ty.i32}});
|
{{0, ty.i32}});
|
||||||
|
@ -1335,10 +1330,10 @@ TEST_F(InspectorGetUniformBufferResourceBindingsTest, MissingBlockDeco) {
|
||||||
|
|
||||||
TEST_F(InspectorGetUniformBufferResourceBindingsTest, Simple) {
|
TEST_F(InspectorGetUniformBufferResourceBindingsTest, Simple) {
|
||||||
type::Struct* foo_struct_type;
|
type::Struct* foo_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> foo_control_type;
|
type::AccessControl* foo_control_type;
|
||||||
std::tie(foo_struct_type, foo_control_type) =
|
std::tie(foo_struct_type, foo_control_type) =
|
||||||
MakeUniformBufferTypes("foo_type", {{ty.i32, 0}});
|
MakeUniformBufferTypes("foo_type", {{ty.i32, 0}});
|
||||||
AddUniformBuffer("foo_ub", foo_control_type.get(), 0, 0);
|
AddUniformBuffer("foo_ub", foo_control_type, 0, 0);
|
||||||
|
|
||||||
auto* ub_func = MakeStructVariableReferenceBodyFunction("ub_func", "foo_ub",
|
auto* ub_func = MakeStructVariableReferenceBodyFunction("ub_func", "foo_ub",
|
||||||
{{0, ty.i32}});
|
{{0, ty.i32}});
|
||||||
|
@ -1364,10 +1359,10 @@ TEST_F(InspectorGetUniformBufferResourceBindingsTest, Simple) {
|
||||||
|
|
||||||
TEST_F(InspectorGetUniformBufferResourceBindingsTest, MultipleMembers) {
|
TEST_F(InspectorGetUniformBufferResourceBindingsTest, MultipleMembers) {
|
||||||
type::Struct* foo_struct_type;
|
type::Struct* foo_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> foo_control_type;
|
type::AccessControl* foo_control_type;
|
||||||
std::tie(foo_struct_type, foo_control_type) = MakeUniformBufferTypes(
|
std::tie(foo_struct_type, foo_control_type) = MakeUniformBufferTypes(
|
||||||
"foo_type", {{ty.i32, 0}, {ty.u32, 4}, {ty.f32, 8}});
|
"foo_type", {{ty.i32, 0}, {ty.u32, 4}, {ty.f32, 8}});
|
||||||
AddUniformBuffer("foo_ub", foo_control_type.get(), 0, 0);
|
AddUniformBuffer("foo_ub", foo_control_type, 0, 0);
|
||||||
|
|
||||||
auto* ub_func = MakeStructVariableReferenceBodyFunction(
|
auto* ub_func = MakeStructVariableReferenceBodyFunction(
|
||||||
"ub_func", "foo_ub", {{0, ty.i32}, {1, ty.u32}, {2, ty.f32}});
|
"ub_func", "foo_ub", {{0, ty.i32}, {1, ty.u32}, {2, ty.f32}});
|
||||||
|
@ -1393,12 +1388,12 @@ TEST_F(InspectorGetUniformBufferResourceBindingsTest, MultipleMembers) {
|
||||||
|
|
||||||
TEST_F(InspectorGetUniformBufferResourceBindingsTest, MultipleUniformBuffers) {
|
TEST_F(InspectorGetUniformBufferResourceBindingsTest, MultipleUniformBuffers) {
|
||||||
type::Struct* ub_struct_type;
|
type::Struct* ub_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> ub_control_type;
|
type::AccessControl* ub_control_type;
|
||||||
std::tie(ub_struct_type, ub_control_type) = MakeUniformBufferTypes(
|
std::tie(ub_struct_type, ub_control_type) = MakeUniformBufferTypes(
|
||||||
"ub_type", {{ty.i32, 0}, {ty.u32, 4}, {ty.f32, 8}});
|
"ub_type", {{ty.i32, 0}, {ty.u32, 4}, {ty.f32, 8}});
|
||||||
AddUniformBuffer("ub_foo", ub_control_type.get(), 0, 0);
|
AddUniformBuffer("ub_foo", ub_control_type, 0, 0);
|
||||||
AddUniformBuffer("ub_bar", ub_control_type.get(), 0, 1);
|
AddUniformBuffer("ub_bar", ub_control_type, 0, 1);
|
||||||
AddUniformBuffer("ub_baz", ub_control_type.get(), 2, 0);
|
AddUniformBuffer("ub_baz", ub_control_type, 2, 0);
|
||||||
|
|
||||||
auto AddReferenceFunc = [this](const std::string& func_name,
|
auto AddReferenceFunc = [this](const std::string& func_name,
|
||||||
const std::string& var_name) {
|
const std::string& var_name) {
|
||||||
|
@ -1445,10 +1440,10 @@ TEST_F(InspectorGetUniformBufferResourceBindingsTest, MultipleUniformBuffers) {
|
||||||
|
|
||||||
TEST_F(InspectorGetUniformBufferResourceBindingsTest, ContainingArray) {
|
TEST_F(InspectorGetUniformBufferResourceBindingsTest, ContainingArray) {
|
||||||
type::Struct* foo_struct_type;
|
type::Struct* foo_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> foo_control_type;
|
type::AccessControl* foo_control_type;
|
||||||
std::tie(foo_struct_type, foo_control_type) =
|
std::tie(foo_struct_type, foo_control_type) =
|
||||||
MakeUniformBufferTypes("foo_type", {{ty.i32, 0}, {u32_array_type(4), 4}});
|
MakeUniformBufferTypes("foo_type", {{ty.i32, 0}, {u32_array_type(4), 4}});
|
||||||
AddUniformBuffer("foo_ub", foo_control_type.get(), 0, 0);
|
AddUniformBuffer("foo_ub", foo_control_type, 0, 0);
|
||||||
|
|
||||||
auto* ub_func = MakeStructVariableReferenceBodyFunction("ub_func", "foo_ub",
|
auto* ub_func = MakeStructVariableReferenceBodyFunction("ub_func", "foo_ub",
|
||||||
{{0, ty.i32}});
|
{{0, ty.i32}});
|
||||||
|
@ -1474,10 +1469,10 @@ TEST_F(InspectorGetUniformBufferResourceBindingsTest, ContainingArray) {
|
||||||
|
|
||||||
TEST_F(InspectorGetStorageBufferResourceBindingsTest, Simple) {
|
TEST_F(InspectorGetStorageBufferResourceBindingsTest, Simple) {
|
||||||
type::Struct* foo_struct_type;
|
type::Struct* foo_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> foo_control_type;
|
type::AccessControl* foo_control_type;
|
||||||
std::tie(foo_struct_type, foo_control_type) =
|
std::tie(foo_struct_type, foo_control_type) =
|
||||||
MakeStorageBufferTypes("foo_type", {{ty.i32, 0}});
|
MakeStorageBufferTypes("foo_type", {{ty.i32, 0}});
|
||||||
AddStorageBuffer("foo_sb", foo_control_type.get(), 0, 0);
|
AddStorageBuffer("foo_sb", foo_control_type, 0, 0);
|
||||||
|
|
||||||
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
||||||
{{0, ty.i32}});
|
{{0, ty.i32}});
|
||||||
|
@ -1503,10 +1498,10 @@ TEST_F(InspectorGetStorageBufferResourceBindingsTest, Simple) {
|
||||||
|
|
||||||
TEST_F(InspectorGetStorageBufferResourceBindingsTest, MultipleMembers) {
|
TEST_F(InspectorGetStorageBufferResourceBindingsTest, MultipleMembers) {
|
||||||
type::Struct* foo_struct_type;
|
type::Struct* foo_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> foo_control_type;
|
type::AccessControl* foo_control_type;
|
||||||
std::tie(foo_struct_type, foo_control_type) = MakeStorageBufferTypes(
|
std::tie(foo_struct_type, foo_control_type) = MakeStorageBufferTypes(
|
||||||
"foo_type", {{ty.i32, 0}, {ty.u32, 4}, {ty.f32, 8}});
|
"foo_type", {{ty.i32, 0}, {ty.u32, 4}, {ty.f32, 8}});
|
||||||
AddStorageBuffer("foo_sb", foo_control_type.get(), 0, 0);
|
AddStorageBuffer("foo_sb", foo_control_type, 0, 0);
|
||||||
|
|
||||||
auto* sb_func = MakeStructVariableReferenceBodyFunction(
|
auto* sb_func = MakeStructVariableReferenceBodyFunction(
|
||||||
"sb_func", "foo_sb", {{0, ty.i32}, {1, ty.u32}, {2, ty.f32}});
|
"sb_func", "foo_sb", {{0, ty.i32}, {1, ty.u32}, {2, ty.f32}});
|
||||||
|
@ -1532,12 +1527,12 @@ TEST_F(InspectorGetStorageBufferResourceBindingsTest, MultipleMembers) {
|
||||||
|
|
||||||
TEST_F(InspectorGetStorageBufferResourceBindingsTest, MultipleStorageBuffers) {
|
TEST_F(InspectorGetStorageBufferResourceBindingsTest, MultipleStorageBuffers) {
|
||||||
type::Struct* sb_struct_type;
|
type::Struct* sb_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> sb_control_type;
|
type::AccessControl* sb_control_type;
|
||||||
std::tie(sb_struct_type, sb_control_type) = MakeStorageBufferTypes(
|
std::tie(sb_struct_type, sb_control_type) = MakeStorageBufferTypes(
|
||||||
"sb_type", {{ty.i32, 0}, {ty.u32, 4}, {ty.f32, 8}});
|
"sb_type", {{ty.i32, 0}, {ty.u32, 4}, {ty.f32, 8}});
|
||||||
AddStorageBuffer("sb_foo", sb_control_type.get(), 0, 0);
|
AddStorageBuffer("sb_foo", sb_control_type, 0, 0);
|
||||||
AddStorageBuffer("sb_bar", sb_control_type.get(), 0, 1);
|
AddStorageBuffer("sb_bar", sb_control_type, 0, 1);
|
||||||
AddStorageBuffer("sb_baz", sb_control_type.get(), 2, 0);
|
AddStorageBuffer("sb_baz", sb_control_type, 2, 0);
|
||||||
|
|
||||||
auto AddReferenceFunc = [this](const std::string& func_name,
|
auto AddReferenceFunc = [this](const std::string& func_name,
|
||||||
const std::string& var_name) {
|
const std::string& var_name) {
|
||||||
|
@ -1587,10 +1582,10 @@ TEST_F(InspectorGetStorageBufferResourceBindingsTest, MultipleStorageBuffers) {
|
||||||
|
|
||||||
TEST_F(InspectorGetStorageBufferResourceBindingsTest, ContainingArray) {
|
TEST_F(InspectorGetStorageBufferResourceBindingsTest, ContainingArray) {
|
||||||
type::Struct* foo_struct_type;
|
type::Struct* foo_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> foo_control_type;
|
type::AccessControl* foo_control_type;
|
||||||
std::tie(foo_struct_type, foo_control_type) =
|
std::tie(foo_struct_type, foo_control_type) =
|
||||||
MakeStorageBufferTypes("foo_type", {{ty.i32, 0}, {u32_array_type(4), 4}});
|
MakeStorageBufferTypes("foo_type", {{ty.i32, 0}, {u32_array_type(4), 4}});
|
||||||
AddStorageBuffer("foo_sb", foo_control_type.get(), 0, 0);
|
AddStorageBuffer("foo_sb", foo_control_type, 0, 0);
|
||||||
|
|
||||||
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
||||||
{{0, ty.i32}});
|
{{0, ty.i32}});
|
||||||
|
@ -1616,10 +1611,10 @@ TEST_F(InspectorGetStorageBufferResourceBindingsTest, ContainingArray) {
|
||||||
|
|
||||||
TEST_F(InspectorGetStorageBufferResourceBindingsTest, ContainingRuntimeArray) {
|
TEST_F(InspectorGetStorageBufferResourceBindingsTest, ContainingRuntimeArray) {
|
||||||
type::Struct* foo_struct_type;
|
type::Struct* foo_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> foo_control_type;
|
type::AccessControl* foo_control_type;
|
||||||
std::tie(foo_struct_type, foo_control_type) =
|
std::tie(foo_struct_type, foo_control_type) =
|
||||||
MakeStorageBufferTypes("foo_type", {{ty.i32, 0}, {u32_array_type(0), 4}});
|
MakeStorageBufferTypes("foo_type", {{ty.i32, 0}, {u32_array_type(0), 4}});
|
||||||
AddStorageBuffer("foo_sb", foo_control_type.get(), 0, 0);
|
AddStorageBuffer("foo_sb", foo_control_type, 0, 0);
|
||||||
|
|
||||||
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
||||||
{{0, ty.i32}});
|
{{0, ty.i32}});
|
||||||
|
@ -1645,10 +1640,10 @@ TEST_F(InspectorGetStorageBufferResourceBindingsTest, ContainingRuntimeArray) {
|
||||||
|
|
||||||
TEST_F(InspectorGetStorageBufferResourceBindingsTest, SkipReadOnly) {
|
TEST_F(InspectorGetStorageBufferResourceBindingsTest, SkipReadOnly) {
|
||||||
type::Struct* foo_struct_type;
|
type::Struct* foo_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> foo_control_type;
|
type::AccessControl* foo_control_type;
|
||||||
std::tie(foo_struct_type, foo_control_type) =
|
std::tie(foo_struct_type, foo_control_type) =
|
||||||
MakeReadOnlyStorageBufferTypes("foo_type", {{ty.i32, 0}});
|
MakeReadOnlyStorageBufferTypes("foo_type", {{ty.i32, 0}});
|
||||||
AddStorageBuffer("foo_sb", foo_control_type.get(), 0, 0);
|
AddStorageBuffer("foo_sb", foo_control_type, 0, 0);
|
||||||
|
|
||||||
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
||||||
{{0, ty.i32}});
|
{{0, ty.i32}});
|
||||||
|
@ -1670,10 +1665,10 @@ TEST_F(InspectorGetStorageBufferResourceBindingsTest, SkipReadOnly) {
|
||||||
|
|
||||||
TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest, Simple) {
|
TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest, Simple) {
|
||||||
type::Struct* foo_struct_type;
|
type::Struct* foo_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> foo_control_type;
|
type::AccessControl* foo_control_type;
|
||||||
std::tie(foo_struct_type, foo_control_type) =
|
std::tie(foo_struct_type, foo_control_type) =
|
||||||
MakeReadOnlyStorageBufferTypes("foo_type", {{ty.i32, 0}});
|
MakeReadOnlyStorageBufferTypes("foo_type", {{ty.i32, 0}});
|
||||||
AddStorageBuffer("foo_sb", foo_control_type.get(), 0, 0);
|
AddStorageBuffer("foo_sb", foo_control_type, 0, 0);
|
||||||
|
|
||||||
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
||||||
{{0, ty.i32}});
|
{{0, ty.i32}});
|
||||||
|
@ -1701,12 +1696,12 @@ TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest, Simple) {
|
||||||
TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest,
|
TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest,
|
||||||
MultipleStorageBuffers) {
|
MultipleStorageBuffers) {
|
||||||
type::Struct* sb_struct_type;
|
type::Struct* sb_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> sb_control_type;
|
type::AccessControl* sb_control_type;
|
||||||
std::tie(sb_struct_type, sb_control_type) = MakeReadOnlyStorageBufferTypes(
|
std::tie(sb_struct_type, sb_control_type) = MakeReadOnlyStorageBufferTypes(
|
||||||
"sb_type", {{ty.i32, 0}, {ty.u32, 4}, {ty.f32, 8}});
|
"sb_type", {{ty.i32, 0}, {ty.u32, 4}, {ty.f32, 8}});
|
||||||
AddStorageBuffer("sb_foo", sb_control_type.get(), 0, 0);
|
AddStorageBuffer("sb_foo", sb_control_type, 0, 0);
|
||||||
AddStorageBuffer("sb_bar", sb_control_type.get(), 0, 1);
|
AddStorageBuffer("sb_bar", sb_control_type, 0, 1);
|
||||||
AddStorageBuffer("sb_baz", sb_control_type.get(), 2, 0);
|
AddStorageBuffer("sb_baz", sb_control_type, 2, 0);
|
||||||
|
|
||||||
auto AddReferenceFunc = [this](const std::string& func_name,
|
auto AddReferenceFunc = [this](const std::string& func_name,
|
||||||
const std::string& var_name) {
|
const std::string& var_name) {
|
||||||
|
@ -1757,10 +1752,10 @@ TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest,
|
||||||
|
|
||||||
TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest, ContainingArray) {
|
TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest, ContainingArray) {
|
||||||
type::Struct* foo_struct_type;
|
type::Struct* foo_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> foo_control_type;
|
type::AccessControl* foo_control_type;
|
||||||
std::tie(foo_struct_type, foo_control_type) = MakeReadOnlyStorageBufferTypes(
|
std::tie(foo_struct_type, foo_control_type) = MakeReadOnlyStorageBufferTypes(
|
||||||
"foo_type", {{ty.i32, 0}, {u32_array_type(4), 4}});
|
"foo_type", {{ty.i32, 0}, {u32_array_type(4), 4}});
|
||||||
AddStorageBuffer("foo_sb", foo_control_type.get(), 0, 0);
|
AddStorageBuffer("foo_sb", foo_control_type, 0, 0);
|
||||||
|
|
||||||
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
||||||
{{0, ty.i32}});
|
{{0, ty.i32}});
|
||||||
|
@ -1788,10 +1783,10 @@ TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest, ContainingArray) {
|
||||||
TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest,
|
TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest,
|
||||||
ContainingRuntimeArray) {
|
ContainingRuntimeArray) {
|
||||||
type::Struct* foo_struct_type;
|
type::Struct* foo_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> foo_control_type;
|
type::AccessControl* foo_control_type;
|
||||||
std::tie(foo_struct_type, foo_control_type) = MakeReadOnlyStorageBufferTypes(
|
std::tie(foo_struct_type, foo_control_type) = MakeReadOnlyStorageBufferTypes(
|
||||||
"foo_type", {{ty.i32, 0}, {u32_array_type(0), 4}});
|
"foo_type", {{ty.i32, 0}, {u32_array_type(0), 4}});
|
||||||
AddStorageBuffer("foo_sb", foo_control_type.get(), 0, 0);
|
AddStorageBuffer("foo_sb", foo_control_type, 0, 0);
|
||||||
|
|
||||||
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
||||||
{{0, ty.i32}});
|
{{0, ty.i32}});
|
||||||
|
@ -1818,10 +1813,10 @@ TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest,
|
||||||
|
|
||||||
TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest, SkipNonReadOnly) {
|
TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest, SkipNonReadOnly) {
|
||||||
type::Struct* foo_struct_type;
|
type::Struct* foo_struct_type;
|
||||||
std::unique_ptr<type::AccessControl> foo_control_type;
|
type::AccessControl* foo_control_type;
|
||||||
std::tie(foo_struct_type, foo_control_type) =
|
std::tie(foo_struct_type, foo_control_type) =
|
||||||
MakeStorageBufferTypes("foo_type", {{ty.i32, 0}});
|
MakeStorageBufferTypes("foo_type", {{ty.i32, 0}});
|
||||||
AddStorageBuffer("foo_sb", foo_control_type.get(), 0, 0);
|
AddStorageBuffer("foo_sb", foo_control_type, 0, 0);
|
||||||
|
|
||||||
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
auto* sb_func = MakeStructVariableReferenceBodyFunction("sb_func", "foo_sb",
|
||||||
{{0, ty.i32}});
|
{{0, ty.i32}});
|
||||||
|
@ -1843,9 +1838,9 @@ TEST_F(InspectorGetReadOnlyStorageBufferResourceBindingsTest, SkipNonReadOnly) {
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(InspectorGetSamplerResourceBindingsTest, Simple) {
|
TEST_F(InspectorGetSamplerResourceBindingsTest, Simple) {
|
||||||
auto sampled_texture_type =
|
auto* sampled_texture_type =
|
||||||
MakeSampledTextureType(type::TextureDimension::k1d, ty.f32);
|
MakeSampledTextureType(type::TextureDimension::k1d, ty.f32);
|
||||||
AddSampledTexture("foo_texture", sampled_texture_type.get(), 0, 0);
|
AddSampledTexture("foo_texture", sampled_texture_type, 0, 0);
|
||||||
AddSampler("foo_sampler", 0, 1);
|
AddSampler("foo_sampler", 0, 1);
|
||||||
AddGlobalVariable("foo_coords", ty.f32);
|
AddGlobalVariable("foo_coords", ty.f32);
|
||||||
|
|
||||||
|
@ -1882,9 +1877,9 @@ TEST_F(InspectorGetSamplerResourceBindingsTest, NoSampler) {
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(InspectorGetSamplerResourceBindingsTest, InFunction) {
|
TEST_F(InspectorGetSamplerResourceBindingsTest, InFunction) {
|
||||||
auto sampled_texture_type =
|
auto* sampled_texture_type =
|
||||||
MakeSampledTextureType(type::TextureDimension::k1d, ty.f32);
|
MakeSampledTextureType(type::TextureDimension::k1d, ty.f32);
|
||||||
AddSampledTexture("foo_texture", sampled_texture_type.get(), 0, 0);
|
AddSampledTexture("foo_texture", sampled_texture_type, 0, 0);
|
||||||
AddSampler("foo_sampler", 0, 1);
|
AddSampler("foo_sampler", 0, 1);
|
||||||
AddGlobalVariable("foo_coords", ty.f32);
|
AddGlobalVariable("foo_coords", ty.f32);
|
||||||
|
|
||||||
|
@ -1910,9 +1905,9 @@ TEST_F(InspectorGetSamplerResourceBindingsTest, InFunction) {
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(InspectorGetSamplerResourceBindingsTest, UnknownEntryPoint) {
|
TEST_F(InspectorGetSamplerResourceBindingsTest, UnknownEntryPoint) {
|
||||||
auto sampled_texture_type =
|
auto* sampled_texture_type =
|
||||||
MakeSampledTextureType(type::TextureDimension::k1d, ty.f32);
|
MakeSampledTextureType(type::TextureDimension::k1d, ty.f32);
|
||||||
AddSampledTexture("foo_texture", sampled_texture_type.get(), 0, 0);
|
AddSampledTexture("foo_texture", sampled_texture_type, 0, 0);
|
||||||
AddSampler("foo_sampler", 0, 1);
|
AddSampler("foo_sampler", 0, 1);
|
||||||
AddGlobalVariable("foo_coords", ty.f32);
|
AddGlobalVariable("foo_coords", ty.f32);
|
||||||
|
|
||||||
|
@ -1930,8 +1925,8 @@ TEST_F(InspectorGetSamplerResourceBindingsTest, UnknownEntryPoint) {
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(InspectorGetSamplerResourceBindingsTest, SkipsComparisonSamplers) {
|
TEST_F(InspectorGetSamplerResourceBindingsTest, SkipsComparisonSamplers) {
|
||||||
auto depth_texture_type = MakeDepthTextureType(type::TextureDimension::k2d);
|
auto* depth_texture_type = MakeDepthTextureType(type::TextureDimension::k2d);
|
||||||
AddDepthTexture("foo_texture", depth_texture_type.get());
|
AddDepthTexture("foo_texture", depth_texture_type);
|
||||||
AddComparisonSampler("foo_sampler", 0, 1);
|
AddComparisonSampler("foo_sampler", 0, 1);
|
||||||
AddGlobalVariable("foo_coords", ty.f32);
|
AddGlobalVariable("foo_coords", ty.f32);
|
||||||
AddGlobalVariable("foo_depth", ty.f32);
|
AddGlobalVariable("foo_depth", ty.f32);
|
||||||
|
@ -1952,8 +1947,8 @@ TEST_F(InspectorGetSamplerResourceBindingsTest, SkipsComparisonSamplers) {
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(InspectorGetComparisonSamplerResourceBindingsTest, Simple) {
|
TEST_F(InspectorGetComparisonSamplerResourceBindingsTest, Simple) {
|
||||||
auto depth_texture_type = MakeDepthTextureType(type::TextureDimension::k2d);
|
auto* depth_texture_type = MakeDepthTextureType(type::TextureDimension::k2d);
|
||||||
AddDepthTexture("foo_texture", depth_texture_type.get());
|
AddDepthTexture("foo_texture", depth_texture_type);
|
||||||
AddComparisonSampler("foo_sampler", 0, 1);
|
AddComparisonSampler("foo_sampler", 0, 1);
|
||||||
AddGlobalVariable("foo_coords", ty.f32);
|
AddGlobalVariable("foo_coords", ty.f32);
|
||||||
AddGlobalVariable("foo_depth", ty.f32);
|
AddGlobalVariable("foo_depth", ty.f32);
|
||||||
|
@ -1991,8 +1986,8 @@ TEST_F(InspectorGetComparisonSamplerResourceBindingsTest, NoSampler) {
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(InspectorGetComparisonSamplerResourceBindingsTest, InFunction) {
|
TEST_F(InspectorGetComparisonSamplerResourceBindingsTest, InFunction) {
|
||||||
auto depth_texture_type = MakeDepthTextureType(type::TextureDimension::k2d);
|
auto* depth_texture_type = MakeDepthTextureType(type::TextureDimension::k2d);
|
||||||
AddDepthTexture("foo_texture", depth_texture_type.get());
|
AddDepthTexture("foo_texture", depth_texture_type);
|
||||||
AddComparisonSampler("foo_sampler", 0, 1);
|
AddComparisonSampler("foo_sampler", 0, 1);
|
||||||
AddGlobalVariable("foo_coords", ty.f32);
|
AddGlobalVariable("foo_coords", ty.f32);
|
||||||
AddGlobalVariable("foo_depth", ty.f32);
|
AddGlobalVariable("foo_depth", ty.f32);
|
||||||
|
@ -2020,8 +2015,8 @@ TEST_F(InspectorGetComparisonSamplerResourceBindingsTest, InFunction) {
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(InspectorGetComparisonSamplerResourceBindingsTest, UnknownEntryPoint) {
|
TEST_F(InspectorGetComparisonSamplerResourceBindingsTest, UnknownEntryPoint) {
|
||||||
auto depth_texture_type = MakeDepthTextureType(type::TextureDimension::k2d);
|
auto* depth_texture_type = MakeDepthTextureType(type::TextureDimension::k2d);
|
||||||
AddDepthTexture("foo_texture", depth_texture_type.get());
|
AddDepthTexture("foo_texture", depth_texture_type);
|
||||||
AddComparisonSampler("foo_sampler", 0, 1);
|
AddComparisonSampler("foo_sampler", 0, 1);
|
||||||
AddGlobalVariable("foo_coords", ty.f32);
|
AddGlobalVariable("foo_coords", ty.f32);
|
||||||
AddGlobalVariable("foo_depth", ty.f32);
|
AddGlobalVariable("foo_depth", ty.f32);
|
||||||
|
@ -2040,9 +2035,9 @@ TEST_F(InspectorGetComparisonSamplerResourceBindingsTest, UnknownEntryPoint) {
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(InspectorGetComparisonSamplerResourceBindingsTest, SkipsSamplers) {
|
TEST_F(InspectorGetComparisonSamplerResourceBindingsTest, SkipsSamplers) {
|
||||||
auto sampled_texture_type =
|
auto* sampled_texture_type =
|
||||||
MakeSampledTextureType(type::TextureDimension::k1d, ty.f32);
|
MakeSampledTextureType(type::TextureDimension::k1d, ty.f32);
|
||||||
AddSampledTexture("foo_texture", sampled_texture_type.get(), 0, 0);
|
AddSampledTexture("foo_texture", sampled_texture_type, 0, 0);
|
||||||
AddSampler("foo_sampler", 0, 1);
|
AddSampler("foo_sampler", 0, 1);
|
||||||
AddGlobalVariable("foo_coords", ty.f32);
|
AddGlobalVariable("foo_coords", ty.f32);
|
||||||
|
|
||||||
|
@ -2075,9 +2070,9 @@ TEST_F(InspectorGetSampledTextureResourceBindingsTest, Empty) {
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_P(InspectorGetSampledTextureResourceBindingsTestWithParam, textureSample) {
|
TEST_P(InspectorGetSampledTextureResourceBindingsTestWithParam, textureSample) {
|
||||||
auto sampled_texture_type = MakeSampledTextureType(
|
auto* sampled_texture_type = MakeSampledTextureType(
|
||||||
GetParam().type_dim, GetBaseType(GetParam().sampled_kind));
|
GetParam().type_dim, GetBaseType(GetParam().sampled_kind));
|
||||||
AddSampledTexture("foo_texture", sampled_texture_type.get(), 0, 0);
|
AddSampledTexture("foo_texture", sampled_texture_type, 0, 0);
|
||||||
AddSampler("foo_sampler", 0, 1);
|
AddSampler("foo_sampler", 0, 1);
|
||||||
auto* coord_type =
|
auto* coord_type =
|
||||||
GetCoordsType(GetParam().type_dim, GetParam().sampled_kind);
|
GetCoordsType(GetParam().type_dim, GetParam().sampled_kind);
|
||||||
|
@ -2165,9 +2160,9 @@ INSTANTIATE_TEST_SUITE_P(
|
||||||
|
|
||||||
TEST_P(InspectorGetSampledArrayTextureResourceBindingsTestWithParam,
|
TEST_P(InspectorGetSampledArrayTextureResourceBindingsTestWithParam,
|
||||||
textureSample) {
|
textureSample) {
|
||||||
auto sampled_texture_type = MakeSampledTextureType(
|
auto* sampled_texture_type = MakeSampledTextureType(
|
||||||
GetParam().type_dim, GetBaseType(GetParam().sampled_kind));
|
GetParam().type_dim, GetBaseType(GetParam().sampled_kind));
|
||||||
AddSampledTexture("foo_texture", sampled_texture_type.get(), 0, 0);
|
AddSampledTexture("foo_texture", sampled_texture_type, 0, 0);
|
||||||
AddSampler("foo_sampler", 0, 1);
|
AddSampler("foo_sampler", 0, 1);
|
||||||
auto* coord_type =
|
auto* coord_type =
|
||||||
GetCoordsType(GetParam().type_dim, GetParam().sampled_kind);
|
GetCoordsType(GetParam().type_dim, GetParam().sampled_kind);
|
||||||
|
@ -2237,9 +2232,9 @@ INSTANTIATE_TEST_SUITE_P(
|
||||||
|
|
||||||
TEST_P(InspectorGetMultisampledTextureResourceBindingsTestWithParam,
|
TEST_P(InspectorGetMultisampledTextureResourceBindingsTestWithParam,
|
||||||
textureSample) {
|
textureSample) {
|
||||||
auto multisampled_texture_type = MakeMultisampledTextureType(
|
auto* multisampled_texture_type = MakeMultisampledTextureType(
|
||||||
GetParam().type_dim, GetBaseType(GetParam().sampled_kind));
|
GetParam().type_dim, GetBaseType(GetParam().sampled_kind));
|
||||||
AddMultisampledTexture("foo_texture", multisampled_texture_type.get(), 0, 0);
|
AddMultisampledTexture("foo_texture", multisampled_texture_type, 0, 0);
|
||||||
AddSampler("foo_sampler", 0, 1);
|
AddSampler("foo_sampler", 0, 1);
|
||||||
auto* coord_type =
|
auto* coord_type =
|
||||||
GetCoordsType(GetParam().type_dim, GetParam().sampled_kind);
|
GetCoordsType(GetParam().type_dim, GetParam().sampled_kind);
|
||||||
|
@ -2316,9 +2311,9 @@ TEST_F(InspectorGetMultisampledArrayTextureResourceBindingsTest, Empty) {
|
||||||
|
|
||||||
TEST_P(InspectorGetMultisampledArrayTextureResourceBindingsTestWithParam,
|
TEST_P(InspectorGetMultisampledArrayTextureResourceBindingsTestWithParam,
|
||||||
textureSample) {
|
textureSample) {
|
||||||
auto multisampled_texture_type = MakeMultisampledTextureType(
|
auto* multisampled_texture_type = MakeMultisampledTextureType(
|
||||||
GetParam().type_dim, GetBaseType(GetParam().sampled_kind));
|
GetParam().type_dim, GetBaseType(GetParam().sampled_kind));
|
||||||
AddMultisampledTexture("foo_texture", multisampled_texture_type.get(), 0, 0);
|
AddMultisampledTexture("foo_texture", multisampled_texture_type, 0, 0);
|
||||||
AddSampler("foo_sampler", 0, 1);
|
AddSampler("foo_sampler", 0, 1);
|
||||||
auto* coord_type =
|
auto* coord_type =
|
||||||
GetCoordsType(GetParam().type_dim, GetParam().sampled_kind);
|
GetCoordsType(GetParam().type_dim, GetParam().sampled_kind);
|
||||||
|
|
|
@ -359,7 +359,7 @@ Expect<bool> ParserImpl::expect_global_decl() {
|
||||||
if (!expect("struct declaration", Token::Type::kSemicolon))
|
if (!expect("struct declaration", Token::Type::kSemicolon))
|
||||||
return Failure::kErrored;
|
return Failure::kErrored;
|
||||||
|
|
||||||
auto* type = module_.unique_type(std::move(str.value));
|
auto* type = str.value;
|
||||||
register_constructed(
|
register_constructed(
|
||||||
module_.SymbolToName(type->As<type::Struct>()->symbol()), type);
|
module_.SymbolToName(type->As<type::Struct>()->symbol()), type);
|
||||||
module_.AddConstructedType(type);
|
module_.AddConstructedType(type);
|
||||||
|
@ -1205,8 +1205,7 @@ Expect<ast::StorageClass> ParserImpl::expect_storage_class(
|
||||||
|
|
||||||
// struct_decl
|
// struct_decl
|
||||||
// : struct_decoration_decl* STRUCT IDENT struct_body_decl
|
// : struct_decoration_decl* STRUCT IDENT struct_body_decl
|
||||||
Maybe<std::unique_ptr<type::Struct>> ParserImpl::struct_decl(
|
Maybe<type::Struct*> ParserImpl::struct_decl(ast::DecorationList& decos) {
|
||||||
ast::DecorationList& decos) {
|
|
||||||
auto t = peek();
|
auto t = peek();
|
||||||
auto source = t.source();
|
auto source = t.source();
|
||||||
|
|
||||||
|
@ -1225,7 +1224,7 @@ Maybe<std::unique_ptr<type::Struct>> ParserImpl::struct_decl(
|
||||||
if (struct_decos.errored)
|
if (struct_decos.errored)
|
||||||
return Failure::kErrored;
|
return Failure::kErrored;
|
||||||
|
|
||||||
return std::make_unique<type::Struct>(
|
return create<type::Struct>(
|
||||||
module_.RegisterSymbol(name.value),
|
module_.RegisterSymbol(name.value),
|
||||||
create<ast::Struct>(source, std::move(body.value),
|
create<ast::Struct>(source, std::move(body.value),
|
||||||
std::move(struct_decos.value)));
|
std::move(struct_decos.value)));
|
||||||
|
|
|
@ -397,7 +397,7 @@ class ParserImpl {
|
||||||
/// `struct_decoration_decl*` provided as `decos`.
|
/// `struct_decoration_decl*` provided as `decos`.
|
||||||
/// @returns the struct type or nullptr on error
|
/// @returns the struct type or nullptr on error
|
||||||
/// @param decos the list of decorations for the struct declaration.
|
/// @param decos the list of decorations for the struct declaration.
|
||||||
Maybe<std::unique_ptr<type::Struct>> struct_decl(ast::DecorationList& decos);
|
Maybe<type::Struct*> struct_decl(ast::DecorationList& decos);
|
||||||
/// Parses a `struct_body_decl` grammar element, erroring on parse failure.
|
/// Parses a `struct_body_decl` grammar element, erroring on parse failure.
|
||||||
/// @returns the struct members
|
/// @returns the struct members
|
||||||
Expect<ast::StructMemberList> expect_struct_body_decl();
|
Expect<ast::StructMemberList> expect_struct_body_decl();
|
||||||
|
|
|
@ -24,18 +24,5 @@ Manager::Manager(Manager&&) = default;
|
||||||
Manager& Manager::operator=(Manager&& rhs) = default;
|
Manager& Manager::operator=(Manager&& rhs) = default;
|
||||||
Manager::~Manager() = default;
|
Manager::~Manager() = default;
|
||||||
|
|
||||||
void Manager::Reset() {
|
|
||||||
types_.clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
type::Type* Manager::Get(std::unique_ptr<type::Type> type) {
|
|
||||||
auto name = type->type_name();
|
|
||||||
|
|
||||||
if (types_.find(name) == types_.end()) {
|
|
||||||
types_[name] = std::move(type);
|
|
||||||
}
|
|
||||||
return types_.find(name)->second.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace type
|
} // namespace type
|
||||||
} // namespace tint
|
} // namespace tint
|
||||||
|
|
|
@ -15,11 +15,11 @@
|
||||||
#ifndef SRC_TYPE_TYPE_MANAGER_H_
|
#ifndef SRC_TYPE_TYPE_MANAGER_H_
|
||||||
#define SRC_TYPE_TYPE_MANAGER_H_
|
#define SRC_TYPE_TYPE_MANAGER_H_
|
||||||
|
|
||||||
#include <memory>
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
|
#include "src/block_allocator.h"
|
||||||
#include "src/type/type.h"
|
#include "src/type/type.h"
|
||||||
|
|
||||||
namespace tint {
|
namespace tint {
|
||||||
|
@ -28,6 +28,9 @@ namespace type {
|
||||||
/// The type manager holds all the pointers to the known types.
|
/// The type manager holds all the pointers to the known types.
|
||||||
class Manager {
|
class Manager {
|
||||||
public:
|
public:
|
||||||
|
/// Iterator is the type returned by begin() and end()
|
||||||
|
using Iterator = BlockAllocator<type::Type>::ConstIterator;
|
||||||
|
|
||||||
/// Constructor
|
/// Constructor
|
||||||
Manager();
|
Manager();
|
||||||
|
|
||||||
|
@ -42,31 +45,38 @@ class Manager {
|
||||||
/// Destructor
|
/// Destructor
|
||||||
~Manager();
|
~Manager();
|
||||||
|
|
||||||
/// Clears all registered types.
|
|
||||||
void Reset();
|
|
||||||
|
|
||||||
/// Get the given type from the type manager
|
|
||||||
/// @param type The type to register
|
|
||||||
/// @return the pointer to the registered type
|
|
||||||
type::Type* Get(std::unique_ptr<type::Type> type);
|
|
||||||
|
|
||||||
/// Get the given type `T` from the type manager
|
/// Get the given type `T` from the type manager
|
||||||
/// @param args the arguments to pass to the type constructor
|
/// @param args the arguments to pass to the type constructor
|
||||||
/// @return the pointer to the registered type
|
/// @return the pointer to the registered type
|
||||||
template <typename T, typename... ARGS>
|
template <typename T, typename... ARGS>
|
||||||
T* Get(ARGS&&... args) {
|
T* Get(ARGS&&... args) {
|
||||||
auto ty = Get(std::make_unique<T>(std::forward<ARGS>(args)...));
|
// Note: We do not use std::forward here, as we may need to use the
|
||||||
return static_cast<T*>(ty);
|
// arguments again for the call to Create<T>() below.
|
||||||
|
auto name = T(args...).type_name();
|
||||||
|
auto it = by_name_.find(name);
|
||||||
|
if (it != by_name_.end()) {
|
||||||
|
return static_cast<T*>(it->second);
|
||||||
|
}
|
||||||
|
|
||||||
|
auto* type = types_.Create<T>(std::forward<ARGS>(args)...);
|
||||||
|
by_name_.emplace(name, type);
|
||||||
|
return type;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the type map
|
/// Returns the type map
|
||||||
/// @returns the mapping from name string to type.
|
/// @returns the mapping from name string to type.
|
||||||
const std::unordered_map<std::string, std::unique_ptr<type::Type>>& types() {
|
const std::unordered_map<std::string, type::Type*>& types() {
|
||||||
return types_;
|
return by_name_;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// @returns an iterator to the beginning of the types
|
||||||
|
Iterator begin() const { return types_.Objects().begin(); }
|
||||||
|
/// @returns an iterator to the end of the types
|
||||||
|
Iterator end() const { return types_.Objects().end(); }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::unordered_map<std::string, std::unique_ptr<type::Type>> types_;
|
std::unordered_map<std::string, type::Type*> by_name_;
|
||||||
|
BlockAllocator<type::Type> types_;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace type
|
} // namespace type
|
||||||
|
|
|
@ -26,46 +26,33 @@ using TypeManagerTest = testing::Test;
|
||||||
|
|
||||||
TEST_F(TypeManagerTest, GetUnregistered) {
|
TEST_F(TypeManagerTest, GetUnregistered) {
|
||||||
Manager tm;
|
Manager tm;
|
||||||
auto* t = tm.Get(std::make_unique<I32>());
|
auto* t = tm.Get<I32>();
|
||||||
ASSERT_NE(t, nullptr);
|
ASSERT_NE(t, nullptr);
|
||||||
EXPECT_TRUE(t->Is<I32>());
|
EXPECT_TRUE(t->Is<I32>());
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(TypeManagerTest, GetSameTypeReturnsSamePtr) {
|
TEST_F(TypeManagerTest, GetSameTypeReturnsSamePtr) {
|
||||||
Manager tm;
|
Manager tm;
|
||||||
auto* t = tm.Get(std::make_unique<I32>());
|
auto* t = tm.Get<I32>();
|
||||||
ASSERT_NE(t, nullptr);
|
ASSERT_NE(t, nullptr);
|
||||||
EXPECT_TRUE(t->Is<I32>());
|
EXPECT_TRUE(t->Is<I32>());
|
||||||
|
|
||||||
auto* t2 = tm.Get(std::make_unique<I32>());
|
auto* t2 = tm.Get<I32>();
|
||||||
EXPECT_EQ(t, t2);
|
EXPECT_EQ(t, t2);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(TypeManagerTest, GetDifferentTypeReturnsDifferentPtr) {
|
TEST_F(TypeManagerTest, GetDifferentTypeReturnsDifferentPtr) {
|
||||||
Manager tm;
|
Manager tm;
|
||||||
auto* t = tm.Get(std::make_unique<I32>());
|
Type* t = tm.Get<I32>();
|
||||||
ASSERT_NE(t, nullptr);
|
ASSERT_NE(t, nullptr);
|
||||||
EXPECT_TRUE(t->Is<I32>());
|
EXPECT_TRUE(t->Is<I32>());
|
||||||
|
|
||||||
auto* t2 = tm.Get(std::make_unique<U32>());
|
Type* t2 = tm.Get<U32>();
|
||||||
ASSERT_NE(t2, nullptr);
|
ASSERT_NE(t2, nullptr);
|
||||||
EXPECT_NE(t, t2);
|
EXPECT_NE(t, t2);
|
||||||
EXPECT_TRUE(t2->Is<U32>());
|
EXPECT_TRUE(t2->Is<U32>());
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_F(TypeManagerTest, ResetClearsPreviousData) {
|
|
||||||
Manager tm;
|
|
||||||
auto* t = tm.Get(std::make_unique<I32>());
|
|
||||||
ASSERT_NE(t, nullptr);
|
|
||||||
|
|
||||||
EXPECT_FALSE(tm.types().empty());
|
|
||||||
tm.Reset();
|
|
||||||
EXPECT_TRUE(tm.types().empty());
|
|
||||||
|
|
||||||
auto* t2 = tm.Get(std::make_unique<I32>());
|
|
||||||
ASSERT_NE(t2, nullptr);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
} // namespace type
|
} // namespace type
|
||||||
} // namespace tint
|
} // namespace tint
|
||||||
|
|
|
@ -1109,7 +1109,8 @@ bool TypeDeterminer::DetermineMemberAccessor(
|
||||||
// The vector will have a number of components equal to the length of the
|
// The vector will have a number of components equal to the length of the
|
||||||
// swizzle. This assumes the validator will check that the swizzle
|
// swizzle. This assumes the validator will check that the swizzle
|
||||||
// is correct.
|
// is correct.
|
||||||
ret = mod_->create<type::Vector>(vec->type(), size);
|
ret =
|
||||||
|
mod_->create<type::Vector>(vec->type(), static_cast<uint32_t>(size));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
set_error(
|
set_error(
|
||||||
|
|
|
@ -1345,23 +1345,22 @@ inline std::ostream& operator<<(std::ostream& out, TextureTestParams data) {
|
||||||
class Intrinsic_TextureOperation
|
class Intrinsic_TextureOperation
|
||||||
: public TypeDeterminerTestWithParam<TextureTestParams> {
|
: public TypeDeterminerTestWithParam<TextureTestParams> {
|
||||||
public:
|
public:
|
||||||
std::unique_ptr<type::Type> get_coords_type(type::TextureDimension dim,
|
type::Type* get_coords_type(type::TextureDimension dim, type::Type* type) {
|
||||||
type::Type* type) {
|
|
||||||
if (dim == type::TextureDimension::k1d) {
|
if (dim == type::TextureDimension::k1d) {
|
||||||
if (type->Is<type::I32>()) {
|
if (type->Is<type::I32>()) {
|
||||||
return std::make_unique<type::I32>();
|
return create<type::I32>();
|
||||||
} else if (type->Is<type::U32>()) {
|
} else if (type->Is<type::U32>()) {
|
||||||
return std::make_unique<type::U32>();
|
return create<type::U32>();
|
||||||
} else {
|
} else {
|
||||||
return std::make_unique<type::F32>();
|
return create<type::F32>();
|
||||||
}
|
}
|
||||||
} else if (dim == type::TextureDimension::k1dArray ||
|
} else if (dim == type::TextureDimension::k1dArray ||
|
||||||
dim == type::TextureDimension::k2d) {
|
dim == type::TextureDimension::k2d) {
|
||||||
return std::make_unique<type::Vector>(type, 2);
|
return create<type::Vector>(type, 2);
|
||||||
} else if (dim == type::TextureDimension::kCubeArray) {
|
} else if (dim == type::TextureDimension::kCubeArray) {
|
||||||
return std::make_unique<type::Vector>(type, 4);
|
return create<type::Vector>(type, 4);
|
||||||
} else {
|
} else {
|
||||||
return std::make_unique<type::Vector>(type, 3);
|
return create<type::Vector>(type, 3);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1373,14 +1372,14 @@ class Intrinsic_TextureOperation
|
||||||
call_params->push_back(Expr(name));
|
call_params->push_back(Expr(name));
|
||||||
}
|
}
|
||||||
|
|
||||||
std::unique_ptr<type::Type> subtype(Texture type) {
|
type::Type* subtype(Texture type) {
|
||||||
if (type == Texture::kF32) {
|
if (type == Texture::kF32) {
|
||||||
return std::make_unique<type::F32>();
|
return create<type::F32>();
|
||||||
}
|
}
|
||||||
if (type == Texture::kI32) {
|
if (type == Texture::kI32) {
|
||||||
return std::make_unique<type::I32>();
|
return create<type::I32>();
|
||||||
}
|
}
|
||||||
return std::make_unique<type::U32>();
|
return create<type::U32>();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1390,14 +1389,14 @@ TEST_P(Intrinsic_StorageTextureOperation, TextureLoadRo) {
|
||||||
auto type = GetParam().type;
|
auto type = GetParam().type;
|
||||||
auto format = GetParam().format;
|
auto format = GetParam().format;
|
||||||
|
|
||||||
auto coords_type = get_coords_type(dim, ty.i32);
|
auto* coords_type = get_coords_type(dim, ty.i32);
|
||||||
|
|
||||||
type::Type* texture_type = mod->create<type::StorageTexture>(dim, format);
|
type::Type* texture_type = mod->create<type::StorageTexture>(dim, format);
|
||||||
|
|
||||||
ast::ExpressionList call_params;
|
ast::ExpressionList call_params;
|
||||||
|
|
||||||
add_call_param("texture", texture_type, &call_params);
|
add_call_param("texture", texture_type, &call_params);
|
||||||
add_call_param("coords", coords_type.get(), &call_params);
|
add_call_param("coords", coords_type, &call_params);
|
||||||
add_call_param("lod", ty.i32, &call_params);
|
add_call_param("lod", ty.i32, &call_params);
|
||||||
|
|
||||||
auto* expr = Call("textureLoad", call_params);
|
auto* expr = Call("textureLoad", call_params);
|
||||||
|
@ -1460,14 +1459,14 @@ TEST_P(Intrinsic_SampledTextureOperation, TextureLoadSampled) {
|
||||||
auto dim = GetParam().dim;
|
auto dim = GetParam().dim;
|
||||||
auto type = GetParam().type;
|
auto type = GetParam().type;
|
||||||
|
|
||||||
std::unique_ptr<type::Type> s = subtype(type);
|
type::Type* s = subtype(type);
|
||||||
auto coords_type = get_coords_type(dim, ty.i32);
|
auto* coords_type = get_coords_type(dim, ty.i32);
|
||||||
auto texture_type = std::make_unique<type::SampledTexture>(dim, s.get());
|
auto* texture_type = create<type::SampledTexture>(dim, s);
|
||||||
|
|
||||||
ast::ExpressionList call_params;
|
ast::ExpressionList call_params;
|
||||||
|
|
||||||
add_call_param("texture", texture_type.get(), &call_params);
|
add_call_param("texture", texture_type, &call_params);
|
||||||
add_call_param("coords", coords_type.get(), &call_params);
|
add_call_param("coords", coords_type, &call_params);
|
||||||
add_call_param("lod", ty.i32, &call_params);
|
add_call_param("lod", ty.i32, &call_params);
|
||||||
|
|
||||||
auto* expr = Call("textureLoad", call_params);
|
auto* expr = Call("textureLoad", call_params);
|
||||||
|
|
Loading…
Reference in New Issue