3
0
Fork 0
mirror of https://github.com/YosysHQ/yosys synced 2025-10-25 00:44:37 +00:00

extract_reduce: Fix segfault on "undriven" inputs

This is easily triggered when un-techmapping if the technology-specific
cell library isn't loaded. Outputs of technology-specific cells will be
seen as inputs, and nets using those outputs will be seen as undriven.
Just ignore these cells because they can't be part of a reduce chain
anyways.
This commit is contained in:
Robert Ou 2017-09-12 14:21:04 -07:00 committed by Andrew Zonenberg
parent f9d023c53f
commit ab1bf8d661

View file

@ -160,7 +160,7 @@ struct ExtractReducePass : public Pass
if (sig_to_sink[a[0]].size() + port_sigs.count(a[0]) == 1) if (sig_to_sink[a[0]].size() + port_sigs.count(a[0]) == 1)
{ {
Cell* cell_a = sig_to_driver[a[0]]; Cell* cell_a = sig_to_driver[a[0]];
if (((cell_a->type == "$_AND_" && gt == GateType::And) || if (cell_a && ((cell_a->type == "$_AND_" && gt == GateType::And) ||
(cell_a->type == "$_OR_" && gt == GateType::Or) || (cell_a->type == "$_OR_" && gt == GateType::Or) ||
(cell_a->type == "$_XOR_" && gt == GateType::Xor))) (cell_a->type == "$_XOR_" && gt == GateType::Xor)))
{ {
@ -177,7 +177,7 @@ struct ExtractReducePass : public Pass
if (sig_to_sink[b[0]].size() + port_sigs.count(b[0]) == 1) if (sig_to_sink[b[0]].size() + port_sigs.count(b[0]) == 1)
{ {
Cell* cell_b = sig_to_driver[b[0]]; Cell* cell_b = sig_to_driver[b[0]];
if (((cell_b->type == "$_AND_" && gt == GateType::And) || if (cell_b && ((cell_b->type == "$_AND_" && gt == GateType::And) ||
(cell_b->type == "$_OR_" && gt == GateType::Or) || (cell_b->type == "$_OR_" && gt == GateType::Or) ||
(cell_b->type == "$_XOR_" && gt == GateType::Xor))) (cell_b->type == "$_XOR_" && gt == GateType::Xor)))
{ {