more SkSL fuzzer crash fixes
BUG=skia: GOLD_TRYBOT_URL= https://gold.skia.org/search?issue=2414413002 Review-Url: https://codereview.chromium.org/2414413002
This commit is contained in:
parent
cce3e58f66
commit
7effa7a29a
@ -525,6 +525,9 @@ std::unique_ptr<InterfaceBlock> IRGenerator::convertInterfaceBlock(const ASTInte
|
|||||||
std::unique_ptr<VarDeclarations> decl = this->convertVarDeclarations(
|
std::unique_ptr<VarDeclarations> decl = this->convertVarDeclarations(
|
||||||
*intf.fDeclarations[i],
|
*intf.fDeclarations[i],
|
||||||
Variable::kGlobal_Storage);
|
Variable::kGlobal_Storage);
|
||||||
|
if (!decl) {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
for (const auto& var : decl->fVars) {
|
for (const auto& var : decl->fVars) {
|
||||||
fields.push_back(Type::Field(var.fVar->fModifiers, var.fVar->fName,
|
fields.push_back(Type::Field(var.fVar->fModifiers, var.fVar->fName,
|
||||||
&var.fVar->fType));
|
&var.fVar->fType));
|
||||||
@ -1024,11 +1027,17 @@ std::unique_ptr<Expression> IRGenerator::convertConstructor(
|
|||||||
int rows = args[i]->fType.rows();
|
int rows = args[i]->fType.rows();
|
||||||
args[i] = this->coerce(std::move(args[i]),
|
args[i] = this->coerce(std::move(args[i]),
|
||||||
type.componentType().toCompound(fContext, columns, rows));
|
type.componentType().toCompound(fContext, columns, rows));
|
||||||
|
if (!args[i]) {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
actual += args[i]->fType.rows() * args[i]->fType.columns();
|
actual += args[i]->fType.rows() * args[i]->fType.columns();
|
||||||
} else if (args[i]->fType.kind() == Type::kScalar_Kind) {
|
} else if (args[i]->fType.kind() == Type::kScalar_Kind) {
|
||||||
actual += 1;
|
actual += 1;
|
||||||
if (type.kind() != Type::kScalar_Kind) {
|
if (type.kind() != Type::kScalar_Kind) {
|
||||||
args[i] = this->coerce(std::move(args[i]), type.componentType());
|
args[i] = this->coerce(std::move(args[i]), type.componentType());
|
||||||
|
if (!args[i]) {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
fErrors.error(position, "'" + args[i]->fType.description() + "' is not a valid "
|
fErrors.error(position, "'" + args[i]->fType.description() + "' is not a valid "
|
||||||
|
Loading…
Reference in New Issue
Block a user