diff --git a/kernel/rtlil.cc b/kernel/rtlil.cc index a3801116e13..bc48c88c853 100644 --- a/kernel/rtlil.cc +++ b/kernel/rtlil.cc @@ -313,12 +313,14 @@ RTLIL::Const::~Const() { bool RTLIL::Const::operator<(const RTLIL::Const &other) const { - // Compare common prefix - for (int i = 0; i < size() && i < other.size(); i++) + if (size() < other.size()) + return size() < other.size(); + + for (int i = 0; i < size(); i++) if ((*this)[i] != other[i]) return (*this)[i] < other[i]; - return size() < other.size(); + return false; } bool RTLIL::Const::operator ==(const RTLIL::Const &other) const @@ -340,7 +342,6 @@ bool RTLIL::Const::operator !=(const RTLIL::Const &other) const std::vector& RTLIL::Const::bits() { - log_assert(is_bits()); bitvectorize(); return get_bits(); } @@ -3913,7 +3914,7 @@ RTLIL::SigChunk::SigChunk(const RTLIL::SigBit &bit) wire = bit.wire; offset = 0; if (wire == NULL) - data = RTLIL::Const(bit.data).to_bits(); + data = {bit.data}; else offset = bit.offset; width = 1;