Handle memory references is continuous assignments.

This commit is contained in:
steve 2005-08-31 05:07:31 +00:00
parent 3ff2488d4f
commit b69f59f2ec
3 changed files with 54 additions and 5 deletions

View File

@ -17,7 +17,7 @@
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
*/ */
#ifdef HAVE_CVS_IDENT #ifdef HAVE_CVS_IDENT
#ident "$Id: elab_net.cc,v 1.170 2005/08/06 17:58:16 steve Exp $" #ident "$Id: elab_net.cc,v 1.171 2005/08/31 05:07:31 steve Exp $"
#endif #endif
# include "config.h" # include "config.h"
@ -503,6 +503,7 @@ NetNet* PEBinary::elaborate_net_cmp_(Design*des, NetScope*scope,
if (lsig == 0) { if (lsig == 0) {
cerr << get_line() << ": internal error: " cerr << get_line() << ": internal error: "
"Cannot elaborate net for " << *lexp << endl; "Cannot elaborate net for " << *lexp << endl;
return 0;
} }
assert(lsig); assert(lsig);
delete lexp; delete lexp;
@ -2627,6 +2628,9 @@ NetNet* PEUnary::elaborate_net(Design*des, NetScope*scope,
/* /*
* $Log: elab_net.cc,v $ * $Log: elab_net.cc,v $
* Revision 1.171 2005/08/31 05:07:31 steve
* Handle memory references is continuous assignments.
*
* Revision 1.170 2005/08/06 17:58:16 steve * Revision 1.170 2005/08/06 17:58:16 steve
* Implement bi-directional part selects. * Implement bi-directional part selects.
* *

View File

@ -17,7 +17,7 @@
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
*/ */
#ifdef HAVE_CVS_IDENT #ifdef HAVE_CVS_IDENT
#ident "$Id: expr_synth.cc,v 1.71 2005/06/13 23:22:14 steve Exp $" #ident "$Id: expr_synth.cc,v 1.72 2005/08/31 05:07:31 steve Exp $"
#endif #endif
# include "config.h" # include "config.h"
@ -144,6 +144,7 @@ NetNet* NetEBBits::synthesize(Design*des)
NetNet* NetEBComp::synthesize(Design*des) NetNet* NetEBComp::synthesize(Design*des)
{ {
#if 0
NetEConst*lcon = reinterpret_cast<NetEConst*>(left_); NetEConst*lcon = reinterpret_cast<NetEConst*>(left_);
NetEConst*rcon = reinterpret_cast<NetEConst*>(right_); NetEConst*rcon = reinterpret_cast<NetEConst*>(right_);
@ -151,7 +152,7 @@ NetNet* NetEBComp::synthesize(Design*des)
0. We can use an OR gate to do the comparison. Synthesize 0. We can use an OR gate to do the comparison. Synthesize
the non-const side as normal, then or(nor) the signals the non-const side as normal, then or(nor) the signals
together to get result. */ together to get result. */
#if 0
// XXXX Need to check this for vector_width and wide logic. // XXXX Need to check this for vector_width and wide logic.
if ((rcon && (rcon->value() == verinum(0UL,rcon->expr_width()))) if ((rcon && (rcon->value() == verinum(0UL,rcon->expr_width())))
|| (lcon && (lcon->value() == verinum(0UL,lcon->expr_width())))) { || (lcon && (lcon->value() == verinum(0UL,lcon->expr_width())))) {
@ -234,6 +235,7 @@ NetNet* NetEBComp::synthesize(Design*des)
NetNet*osig = new NetNet(scope, scope->local_symbol(), NetNet*osig = new NetNet(scope, scope->local_symbol(),
NetNet::IMPLICIT, 1); NetNet::IMPLICIT, 1);
osig->local_flag(true); osig->local_flag(true);
osig->data_type(IVL_VT_LOGIC);
/* Handle the special case of a single bit equality /* Handle the special case of a single bit equality
operation. Make an XNOR gate instead of a comparator. */ operation. Make an XNOR gate instead of a comparator. */
@ -566,8 +568,15 @@ NetNet* NetEConcat::synthesize(Design*des)
{ {
/* First, synthesize the operands. */ /* First, synthesize the operands. */
NetNet**tmp = new NetNet*[parms_.count()]; NetNet**tmp = new NetNet*[parms_.count()];
for (unsigned idx = 0 ; idx < parms_.count() ; idx += 1) bool flag = true;
for (unsigned idx = 0 ; idx < parms_.count() ; idx += 1) {
tmp[idx] = parms_[idx]->synthesize(des); tmp[idx] = parms_[idx]->synthesize(des);
if (tmp[idx] == 0)
flag = false;
}
if (flag == false)
return 0;
assert(tmp[0]); assert(tmp[0]);
NetScope*scope = tmp[0]->scope(); NetScope*scope = tmp[0]->scope();
@ -577,6 +586,7 @@ NetNet* NetEConcat::synthesize(Design*des)
perm_string path = scope->local_symbol(); perm_string path = scope->local_symbol();
NetNet*osig = new NetNet(scope, path, NetNet::IMPLICIT, expr_width()); NetNet*osig = new NetNet(scope, path, NetNet::IMPLICIT, expr_width());
osig->local_flag(true); osig->local_flag(true);
osig->data_type(tmp[0]->data_type());
NetConcat*concat = new NetConcat(scope, scope->local_symbol(), NetConcat*concat = new NetConcat(scope, scope->local_symbol(),
osig->vector_width(), parms_.count()); osig->vector_width(), parms_.count());
@ -602,6 +612,7 @@ NetNet* NetEConst::synthesize(Design*des)
NetNet*osig = new NetNet(scope, path, NetNet::IMPLICIT, width-1,0); NetNet*osig = new NetNet(scope, path, NetNet::IMPLICIT, width-1,0);
osig->local_flag(true); osig->local_flag(true);
osig->data_type(IVL_VT_LOGIC);
osig->set_signed(has_sign()); osig->set_signed(has_sign());
NetConst*con = new NetConst(scope, scope->local_symbol(), value()); NetConst*con = new NetConst(scope, scope->local_symbol(), value());
connect(osig->pin(0), con->pin(0)); connect(osig->pin(0), con->pin(0));
@ -713,6 +724,33 @@ NetNet* NetEUReduce::synthesize(Design*des)
return osig; return osig;
} }
NetNet* NetEMemory::synthesize(Design *des)
{
NetNet*adr = idx_->synthesize(des);
NetScope*scope = adr->scope();
NetRamDq*ram = new NetRamDq(scope, scope->local_symbol(),
mem_, adr->vector_width());
des->add_node(ram);
ram->set_line(*this);
connect(ram->pin_Address(), adr->pin(0));
/* Create an output signal to receive the data. Assume that
memories return LOGIC. */
NetNet*osig = new NetNet(scope, scope->local_symbol(),
NetNet::IMPLICIT, ram->width());
osig->data_type(IVL_VT_LOGIC);
osig->local_flag(true);
osig->set_line(*this);
connect(ram->pin_Q(), osig->pin(0));
return osig;
}
NetNet* NetESelect::synthesize(Design *des) NetNet* NetESelect::synthesize(Design *des)
{ {
@ -875,6 +913,9 @@ NetNet* NetESignal::synthesize(Design*des)
/* /*
* $Log: expr_synth.cc,v $ * $Log: expr_synth.cc,v $
* Revision 1.72 2005/08/31 05:07:31 steve
* Handle memory references is continuous assignments.
*
* Revision 1.71 2005/06/13 23:22:14 steve * Revision 1.71 2005/06/13 23:22:14 steve
* use NetPartSelect to shrink part from high bits. * use NetPartSelect to shrink part from high bits.
* *

View File

@ -19,7 +19,7 @@
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
*/ */
#ifdef HAVE_CVS_IDENT #ifdef HAVE_CVS_IDENT
#ident "$Id: netlist.h,v 1.347 2005/07/14 23:34:19 steve Exp $" #ident "$Id: netlist.h,v 1.348 2005/08/31 05:07:31 steve Exp $"
#endif #endif
/* /*
@ -3041,6 +3041,7 @@ class NetEMemory : public NetExpr {
const NetExpr* index() const; const NetExpr* index() const;
virtual bool set_width(unsigned); virtual bool set_width(unsigned);
virtual NetNet* synthesize(Design*des);
NetExpr* eval_tree(); NetExpr* eval_tree();
virtual NetEMemory*dup_expr() const; virtual NetEMemory*dup_expr() const;
@ -3435,6 +3436,9 @@ extern ostream& operator << (ostream&, NetNet::Type);
/* /*
* $Log: netlist.h,v $ * $Log: netlist.h,v $
* Revision 1.348 2005/08/31 05:07:31 steve
* Handle memory references is continuous assignments.
*
* Revision 1.347 2005/07/14 23:34:19 steve * Revision 1.347 2005/07/14 23:34:19 steve
* gcc4 compile errors. * gcc4 compile errors.
* *