mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-05-05 05:18:08 +02:00
compiler/types: Add a contains_64bit helper
Reviewed-by: Alejandro Piñeiro <apinheiro@igalia.com>
This commit is contained in:
parent
323958908e
commit
30b548fc62
4 changed files with 29 additions and 0 deletions
|
|
@ -260,6 +260,22 @@ glsl_type::contains_double() const
|
|||
}
|
||||
}
|
||||
|
||||
bool
|
||||
glsl_type::contains_64bit() const
|
||||
{
|
||||
if (this->is_array()) {
|
||||
return this->fields.array->contains_64bit();
|
||||
} else if (this->is_record() || this->is_interface()) {
|
||||
for (unsigned int i = 0; i < this->length; i++) {
|
||||
if (this->fields.structure[i].type->contains_64bit())
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
} else {
|
||||
return this->is_64bit();
|
||||
}
|
||||
}
|
||||
|
||||
bool
|
||||
glsl_type::contains_opaque() const {
|
||||
switch (base_type) {
|
||||
|
|
|
|||
|
|
@ -544,6 +544,12 @@ public:
|
|||
*/
|
||||
bool contains_double() const;
|
||||
|
||||
/**
|
||||
* Query whether or not type is a 64-bit type, or for struct, interface and
|
||||
* array types, contains a double type.
|
||||
*/
|
||||
bool contains_64bit() const;
|
||||
|
||||
/**
|
||||
* Query whether or not a type is a float type
|
||||
*/
|
||||
|
|
|
|||
|
|
@ -332,6 +332,12 @@ glsl_type_is_integer(const struct glsl_type *type)
|
|||
return type->is_integer();
|
||||
}
|
||||
|
||||
bool
|
||||
glsl_type_contains_64bit(const struct glsl_type *type)
|
||||
{
|
||||
return type->contains_64bit();
|
||||
}
|
||||
|
||||
const glsl_type *
|
||||
glsl_void_type(void)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -150,6 +150,7 @@ bool glsl_type_is_dual_slot(const struct glsl_type *type);
|
|||
bool glsl_type_is_numeric(const struct glsl_type *type);
|
||||
bool glsl_type_is_boolean(const struct glsl_type *type);
|
||||
bool glsl_type_is_integer(const struct glsl_type *type);
|
||||
bool glsl_type_contains_64bit(const struct glsl_type *type);
|
||||
bool glsl_sampler_type_is_shadow(const struct glsl_type *type);
|
||||
bool glsl_sampler_type_is_array(const struct glsl_type *type);
|
||||
bool glsl_contains_atomic(const struct glsl_type *type);
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue