mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2024-12-22 11:56:49 +01:00
Fix shader compiler asan out of bounds
This commit is contained in:
parent
37c50b6f21
commit
298be38336
@ -1680,6 +1680,9 @@ void RasterizerStorageGLES2::shader_get_param_list(RID p_shader, List<PropertyIn
|
|||||||
case ShaderLanguage::TYPE_USAMPLER3D: {
|
case ShaderLanguage::TYPE_USAMPLER3D: {
|
||||||
// Not implemented in GLES2
|
// Not implemented in GLES2
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
|
default: {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
p_param_list->push_back(pi);
|
p_param_list->push_back(pi);
|
||||||
|
@ -926,6 +926,8 @@ String ShaderLanguage::get_datatype_name(DataType p_type) {
|
|||||||
return "samplerExternalOES";
|
return "samplerExternalOES";
|
||||||
case TYPE_STRUCT:
|
case TYPE_STRUCT:
|
||||||
return "struct";
|
return "struct";
|
||||||
|
default: {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return "";
|
return "";
|
||||||
@ -2701,6 +2703,8 @@ Variant ShaderLanguage::constant_value_to_variant(const Vector<ShaderLanguage::C
|
|||||||
break;
|
break;
|
||||||
case ShaderLanguage::TYPE_VOID:
|
case ShaderLanguage::TYPE_VOID:
|
||||||
break;
|
break;
|
||||||
|
default: {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
@ -2786,8 +2790,18 @@ ShaderLanguage::DataType ShaderLanguage::get_scalar_type(DataType p_type) {
|
|||||||
TYPE_INT,
|
TYPE_INT,
|
||||||
TYPE_UINT,
|
TYPE_UINT,
|
||||||
TYPE_FLOAT,
|
TYPE_FLOAT,
|
||||||
|
TYPE_INT,
|
||||||
|
TYPE_UINT,
|
||||||
|
TYPE_FLOAT,
|
||||||
|
TYPE_INT,
|
||||||
|
TYPE_UINT,
|
||||||
|
TYPE_FLOAT,
|
||||||
|
TYPE_FLOAT,
|
||||||
|
TYPE_VOID,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static_assert(sizeof(scalar_types) / sizeof(*scalar_types) == TYPE_MAX, "get_scalar_type must be updated if DataType is updated");
|
||||||
|
|
||||||
return scalar_types[p_type];
|
return scalar_types[p_type];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2817,8 +2831,18 @@ int ShaderLanguage::get_cardinality(DataType p_type) {
|
|||||||
1,
|
1,
|
||||||
1,
|
1,
|
||||||
1,
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
|
1,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static_assert(sizeof(cardinality_table) / sizeof(*cardinality_table) == TYPE_MAX, "get_cardinality must be updated if DataType is updated");
|
||||||
|
|
||||||
return cardinality_table[p_type];
|
return cardinality_table[p_type];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -210,6 +210,7 @@ public:
|
|||||||
TYPE_SAMPLERCUBE,
|
TYPE_SAMPLERCUBE,
|
||||||
TYPE_SAMPLEREXT,
|
TYPE_SAMPLEREXT,
|
||||||
TYPE_STRUCT,
|
TYPE_STRUCT,
|
||||||
|
TYPE_MAX,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum DataPrecision {
|
enum DataPrecision {
|
||||||
|
Loading…
Reference in New Issue
Block a user