mirror of https://github.com/YosysHQ/yosys.git
kernel: SigPool to use const& + overloads to prevent implicit SigSpec
This commit is contained in:
parent
a0cc795e85
commit
a076052fe4
|
@ -39,7 +39,7 @@ struct SigPool
|
||||||
bits.clear();
|
bits.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
void add(RTLIL::SigSpec sig)
|
void add(const RTLIL::SigSpec &sig)
|
||||||
{
|
{
|
||||||
for (auto &bit : sig)
|
for (auto &bit : sig)
|
||||||
if (bit.wire != NULL)
|
if (bit.wire != NULL)
|
||||||
|
@ -52,7 +52,7 @@ struct SigPool
|
||||||
bits.insert(bit);
|
bits.insert(bit);
|
||||||
}
|
}
|
||||||
|
|
||||||
void del(RTLIL::SigSpec sig)
|
void del(const RTLIL::SigSpec &sig)
|
||||||
{
|
{
|
||||||
for (auto &bit : sig)
|
for (auto &bit : sig)
|
||||||
if (bit.wire != NULL)
|
if (bit.wire != NULL)
|
||||||
|
@ -65,7 +65,7 @@ struct SigPool
|
||||||
bits.erase(bit);
|
bits.erase(bit);
|
||||||
}
|
}
|
||||||
|
|
||||||
void expand(RTLIL::SigSpec from, RTLIL::SigSpec to)
|
void expand(const RTLIL::SigSpec &from, const RTLIL::SigSpec &to)
|
||||||
{
|
{
|
||||||
log_assert(GetSize(from) == GetSize(to));
|
log_assert(GetSize(from) == GetSize(to));
|
||||||
for (int i = 0; i < GetSize(from); i++) {
|
for (int i = 0; i < GetSize(from); i++) {
|
||||||
|
@ -75,16 +75,16 @@ struct SigPool
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
RTLIL::SigSpec extract(RTLIL::SigSpec sig)
|
RTLIL::SigSpec extract(const RTLIL::SigSpec &sig) const
|
||||||
{
|
{
|
||||||
RTLIL::SigSpec result;
|
RTLIL::SigSpec result;
|
||||||
for (auto &bit : sig)
|
for (auto &bit : sig)
|
||||||
if (bit.wire != NULL && bits.count(bit))
|
if (bit.wire != NULL && bits.count(bit))
|
||||||
result.append_bit(bit);
|
result.append(bit);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
RTLIL::SigSpec remove(RTLIL::SigSpec sig)
|
RTLIL::SigSpec remove(const RTLIL::SigSpec &sig) const
|
||||||
{
|
{
|
||||||
RTLIL::SigSpec result;
|
RTLIL::SigSpec result;
|
||||||
for (auto &bit : sig)
|
for (auto &bit : sig)
|
||||||
|
@ -93,12 +93,12 @@ struct SigPool
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool check(RTLIL::SigBit bit)
|
bool check(const RTLIL::SigBit &bit) const
|
||||||
{
|
{
|
||||||
return bit.wire != NULL && bits.count(bit);
|
return bit.wire != NULL && bits.count(bit);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool check_any(RTLIL::SigSpec sig)
|
bool check_any(const RTLIL::SigSpec &sig) const
|
||||||
{
|
{
|
||||||
for (auto &bit : sig)
|
for (auto &bit : sig)
|
||||||
if (bit.wire != NULL && bits.count(bit))
|
if (bit.wire != NULL && bits.count(bit))
|
||||||
|
@ -106,7 +106,7 @@ struct SigPool
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool check_all(RTLIL::SigSpec sig)
|
bool check_all(const RTLIL::SigSpec &sig) const
|
||||||
{
|
{
|
||||||
for (auto &bit : sig)
|
for (auto &bit : sig)
|
||||||
if (bit.wire != NULL && bits.count(bit) == 0)
|
if (bit.wire != NULL && bits.count(bit) == 0)
|
||||||
|
@ -114,14 +114,14 @@ struct SigPool
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
RTLIL::SigSpec export_one()
|
RTLIL::SigSpec export_one() const
|
||||||
{
|
{
|
||||||
for (auto &bit : bits)
|
for (auto &bit : bits)
|
||||||
return RTLIL::SigSpec(bit.first, bit.second);
|
return RTLIL::SigSpec(bit.first, bit.second);
|
||||||
return RTLIL::SigSpec();
|
return RTLIL::SigSpec();
|
||||||
}
|
}
|
||||||
|
|
||||||
RTLIL::SigSpec export_all()
|
RTLIL::SigSpec export_all() const
|
||||||
{
|
{
|
||||||
pool<RTLIL::SigBit> sig;
|
pool<RTLIL::SigBit> sig;
|
||||||
for (auto &bit : bits)
|
for (auto &bit : bits)
|
||||||
|
@ -153,7 +153,7 @@ struct SigSet
|
||||||
bits.clear();
|
bits.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
void insert(RTLIL::SigSpec sig, T data)
|
void insert(const RTLIL::SigSpec &sig, T data)
|
||||||
{
|
{
|
||||||
for (auto &bit : sig)
|
for (auto &bit : sig)
|
||||||
if (bit.wire != NULL)
|
if (bit.wire != NULL)
|
||||||
|
@ -262,7 +262,7 @@ struct SigMap
|
||||||
add(it.first, it.second);
|
add(it.first, it.second);
|
||||||
}
|
}
|
||||||
|
|
||||||
void add(RTLIL::SigSpec from, RTLIL::SigSpec to)
|
void add(const RTLIL::SigSpec& from, const RTLIL::SigSpec& to)
|
||||||
{
|
{
|
||||||
log_assert(GetSize(from) == GetSize(to));
|
log_assert(GetSize(from) == GetSize(to));
|
||||||
|
|
||||||
|
@ -287,15 +287,21 @@ struct SigMap
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void add(RTLIL::SigSpec sig)
|
void add(const RTLIL::SigBit &bit)
|
||||||
{
|
{
|
||||||
for (auto &bit : sig) {
|
RTLIL::SigBit b = database.find(bit);
|
||||||
RTLIL::SigBit b = database.find(bit);
|
if (b.wire != nullptr)
|
||||||
if (b.wire != nullptr)
|
database.promote(bit);
|
||||||
database.promote(bit);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void add(const RTLIL::SigSpec &sig)
|
||||||
|
{
|
||||||
|
for (auto &bit : sig)
|
||||||
|
add(bit);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void add(const Wire *wire) { return add(RTLIL::SigSpec(wire)); }
|
||||||
|
|
||||||
void apply(RTLIL::SigBit &bit) const
|
void apply(RTLIL::SigBit &bit) const
|
||||||
{
|
{
|
||||||
bit = database.find(bit);
|
bit = database.find(bit);
|
||||||
|
|
Loading…
Reference in New Issue