summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2016-04-04 18:09:41 -0700
committerAlan Mishchenko <alanmi@berkeley.edu>2016-04-04 18:09:41 -0700
commitee17cbbf4b029c0022c9ce3f343c1a7a00b4163b (patch)
tree33b7358e4ae81039b5d1da7773bf354a6f479773 /src
parentac7a799076e3f2184aae74a55062e02e330c78eb (diff)
downloadabc-ee17cbbf4b029c0022c9ce3f343c1a7a00b4163b.tar.gz
abc-ee17cbbf4b029c0022c9ce3f343c1a7a00b4163b.tar.bz2
abc-ee17cbbf4b029c0022c9ce3f343c1a7a00b4163b.zip
Supporting negative and reverse ranges of word-level variables in Wlc.
Diffstat (limited to 'src')
-rw-r--r--src/base/wlc/wlc.h78
-rw-r--r--src/base/wlc/wlcBlast.c44
-rw-r--r--src/base/wlc/wlcNtk.c83
-rw-r--r--src/base/wlc/wlcReadSmt.c2
-rw-r--r--src/base/wlc/wlcReadVer.c65
-rw-r--r--src/base/wlc/wlcWriteVer.c2
6 files changed, 168 insertions, 106 deletions
diff --git a/src/base/wlc/wlc.h b/src/base/wlc/wlc.h
index 8f1b9440..f3a4f7aa 100644
--- a/src/base/wlc/wlc.h
+++ b/src/base/wlc/wlc.h
@@ -61,38 +61,38 @@ typedef enum {
WLC_OBJ_BIT_AND, // 16: bitwise AND
WLC_OBJ_BIT_OR, // 17: bitwise OR
WLC_OBJ_BIT_XOR, // 18: bitwise XOR
- WLC_OBJ_BIT_NXOR, // 18: bitwise NXOR
- WLC_OBJ_BIT_SELECT, // 19: bit selection
- WLC_OBJ_BIT_CONCAT, // 20: bit concatenation
- WLC_OBJ_BIT_ZEROPAD, // 21: zero padding
- WLC_OBJ_BIT_SIGNEXT, // 22: sign extension
- WLC_OBJ_LOGIC_NOT, // 23: logic NOT
- WLC_OBJ_LOGIC_AND, // 24: logic AND
- WLC_OBJ_LOGIC_OR, // 25: logic OR
- WLC_OBJ_LOGIC_XOR, // 27: logic XOR
- WLC_OBJ_COMP_EQU, // 28: compare equal
- WLC_OBJ_COMP_NOTEQU, // 29: compare not equal
- WLC_OBJ_COMP_LESS, // 30: compare less
- WLC_OBJ_COMP_MORE, // 31: compare more
- WLC_OBJ_COMP_LESSEQU, // 32: compare less or equal
- WLC_OBJ_COMP_MOREEQU, // 33: compare more or equal
- WLC_OBJ_REDUCT_AND, // 34: reduction AND
- WLC_OBJ_REDUCT_OR, // 35: reduction OR
- WLC_OBJ_REDUCT_XOR, // 36: reduction XOR
- WLC_OBJ_REDUCT_NAND, // 34: reduction NAND
- WLC_OBJ_REDUCT_NOR, // 35: reduction NOR
- WLC_OBJ_REDUCT_NXOR, // 36: reduction NXOR
- WLC_OBJ_ARI_ADD, // 37: arithmetic addition
- WLC_OBJ_ARI_SUB, // 38: arithmetic subtraction
- WLC_OBJ_ARI_MULTI, // 39: arithmetic multiplier
- WLC_OBJ_ARI_DIVIDE, // 40: arithmetic division
- WLC_OBJ_ARI_MODULUS, // 41: arithmetic modulus
- WLC_OBJ_ARI_POWER, // 42: arithmetic power
- WLC_OBJ_ARI_MINUS, // 43: arithmetic minus
- WLC_OBJ_ARI_SQRT, // 44: integer square root
- WLC_OBJ_ARI_SQUARE, // 45: integer square root
- WLC_OBJ_TABLE, // 46: bit table
- WLC_OBJ_NUMBER // 47: unused
+ WLC_OBJ_BIT_NXOR, // 19: bitwise NXOR
+ WLC_OBJ_BIT_SELECT, // 20: bit selection
+ WLC_OBJ_BIT_CONCAT, // 21: bit concatenation
+ WLC_OBJ_BIT_ZEROPAD, // 22: zero padding
+ WLC_OBJ_BIT_SIGNEXT, // 23: sign extension
+ WLC_OBJ_LOGIC_NOT, // 24: logic NOT
+ WLC_OBJ_LOGIC_AND, // 25: logic AND
+ WLC_OBJ_LOGIC_OR, // 27: logic OR
+ WLC_OBJ_LOGIC_XOR, // 28: logic XOR
+ WLC_OBJ_COMP_EQU, // 29: compare equal
+ WLC_OBJ_COMP_NOTEQU, // 30: compare not equal
+ WLC_OBJ_COMP_LESS, // 31: compare less
+ WLC_OBJ_COMP_MORE, // 32: compare more
+ WLC_OBJ_COMP_LESSEQU, // 33: compare less or equal
+ WLC_OBJ_COMP_MOREEQU, // 34: compare more or equal
+ WLC_OBJ_REDUCT_AND, // 35: reduction AND
+ WLC_OBJ_REDUCT_OR, // 36: reduction OR
+ WLC_OBJ_REDUCT_XOR, // 37: reduction XOR
+ WLC_OBJ_REDUCT_NAND, // 38: reduction NAND
+ WLC_OBJ_REDUCT_NOR, // 39: reduction NOR
+ WLC_OBJ_REDUCT_NXOR, // 40: reduction NXOR
+ WLC_OBJ_ARI_ADD, // 41: arithmetic addition
+ WLC_OBJ_ARI_SUB, // 42: arithmetic subtraction
+ WLC_OBJ_ARI_MULTI, // 43: arithmetic multiplier
+ WLC_OBJ_ARI_DIVIDE, // 44: arithmetic division
+ WLC_OBJ_ARI_MODULUS, // 45: arithmetic modulus
+ WLC_OBJ_ARI_POWER, // 46: arithmetic power
+ WLC_OBJ_ARI_MINUS, // 47: arithmetic minus
+ WLC_OBJ_ARI_SQRT, // 48: integer square root
+ WLC_OBJ_ARI_SQUARE, // 49: integer square
+ WLC_OBJ_TABLE, // 50: bit table
+ WLC_OBJ_NUMBER // 51: unused
} Wlc_ObjType_t;
// when adding new types, remember to update table Wlc_Names in "wlcNtk.c"
@@ -115,8 +115,8 @@ struct Wlc_Obj_t_ // 24 bytes
unsigned fIsFi : 1; // this is FI
unsigned fXConst : 1; // this is X-valued constant
unsigned nFanins; // fanin count
- unsigned End; // range end
- unsigned Beg; // range begin
+ int End; // range end
+ int Beg; // range begin
union { int Fanins[2]; // fanin IDs
int * pFanins[1]; };
};
@@ -175,7 +175,7 @@ static inline int Wlc_ObjIsCo( Wlc_Obj_t * p )
static inline int Wlc_ObjId( Wlc_Ntk_t * p, Wlc_Obj_t * pObj ) { return pObj - p->pObjs; }
static inline int Wlc_ObjCiId( Wlc_Obj_t * p ) { assert( Wlc_ObjIsCi(p) ); return p->Fanins[1]; }
static inline int Wlc_ObjFaninNum( Wlc_Obj_t * p ) { return p->nFanins; }
-static inline int Wlc_ObjHasArray( Wlc_Obj_t * p ) { return p->nFanins > 2 || p->Type == WLC_OBJ_CONST; }
+static inline int Wlc_ObjHasArray( Wlc_Obj_t * p ) { return p->nFanins > 2 || p->Type == WLC_OBJ_CONST || p->Type == WLC_OBJ_BIT_SELECT; }
static inline int * Wlc_ObjFanins( Wlc_Obj_t * p ) { return Wlc_ObjHasArray(p) ? p->pFanins[0] : p->Fanins; }
static inline int Wlc_ObjFaninId( Wlc_Obj_t * p, int i ) { return Wlc_ObjFanins(p)[i]; }
static inline int Wlc_ObjFaninId0( Wlc_Obj_t * p ) { return Wlc_ObjFanins(p)[0]; }
@@ -186,9 +186,11 @@ static inline Wlc_Obj_t * Wlc_ObjFanin0( Wlc_Ntk_t * p, Wlc_Obj_t * pObj )
static inline Wlc_Obj_t * Wlc_ObjFanin1( Wlc_Ntk_t * p, Wlc_Obj_t * pObj ) { return Wlc_NtkObj( p, Wlc_ObjFaninId(pObj, 1) ); }
static inline Wlc_Obj_t * Wlc_ObjFanin2( Wlc_Ntk_t * p, Wlc_Obj_t * pObj ) { return Wlc_NtkObj( p, Wlc_ObjFaninId(pObj, 2) ); }
-static inline int Wlc_ObjRange( Wlc_Obj_t * p ) { return p->End - p->Beg + 1; }
-static inline int Wlc_ObjRangeEnd( Wlc_Obj_t * p ) { assert(p->Type == WLC_OBJ_BIT_SELECT); return p->Fanins[1] >> 16; }
-static inline int Wlc_ObjRangeBeg( Wlc_Obj_t * p ) { assert(p->Type == WLC_OBJ_BIT_SELECT); return p->Fanins[1] & 0xFFFF; }
+static inline int Wlc_ObjRange( Wlc_Obj_t * p ) { return 1 + (p->End >= p->Beg ? p->End - p->Beg : p->Beg - p->End); }
+static inline int Wlc_ObjRangeEnd( Wlc_Obj_t * p ) { assert(p->Type == WLC_OBJ_BIT_SELECT); return p->pFanins[0][1]; }
+static inline int Wlc_ObjRangeBeg( Wlc_Obj_t * p ) { assert(p->Type == WLC_OBJ_BIT_SELECT); return p->pFanins[0][2]; }
+static inline int Wlc_ObjRangeIsReversed( Wlc_Obj_t * p ) { return p->End < p->Beg; }
+
static inline int Wlc_ObjIsSigned( Wlc_Obj_t * p ) { return p->Signed; }
static inline int Wlc_ObjIsSignedFanin01( Wlc_Ntk_t * p, Wlc_Obj_t * pObj ){ return Wlc_ObjFanin0(p, pObj)->Signed && Wlc_ObjFanin1(p, pObj)->Signed; }
static inline int Wlc_ObjSign( Wlc_Obj_t * p ) { return Abc_Var2Lit( Wlc_ObjRange(p), Wlc_ObjIsSigned(p) ); }
diff --git a/src/base/wlc/wlcBlast.c b/src/base/wlc/wlcBlast.c
index 7cd0f369..99edb88a 100644
--- a/src/base/wlc/wlcBlast.c
+++ b/src/base/wlc/wlcBlast.c
@@ -846,8 +846,18 @@ Gia_Man_t * Wlc_NtkBitBlast( Wlc_Ntk_t * p, Vec_Int_t * vBoxIds )
}
else if ( Wlc_ObjIsCi(pObj) )
{
- for ( k = 0; k < nRange; k++ )
- Vec_IntPush( vRes, Gia_ManAppendCi(pNew) );
+ if ( Wlc_ObjRangeIsReversed(pObj) )
+ {
+ for ( k = 0; k < nRange; k++ )
+ Vec_IntPush( vRes, -1 );
+ for ( k = 0; k < nRange; k++ )
+ Vec_IntWriteEntry( vRes, Vec_IntSize(vRes)-1-k, Gia_ManAppendCi(pNew) );
+ }
+ else
+ {
+ for ( k = 0; k < nRange; k++ )
+ Vec_IntPush( vRes, Gia_ManAppendCi(pNew) );
+ }
if ( pObj->Type == WLC_OBJ_FO )
nFFouts += Vec_IntSize(vRes);
}
@@ -962,10 +972,20 @@ Gia_Man_t * Wlc_NtkBitBlast( Wlc_Ntk_t * p, Vec_Int_t * vBoxIds )
Wlc_Obj_t * pFanin = Wlc_ObjFanin0(p, pObj);
int End = Wlc_ObjRangeEnd(pObj);
int Beg = Wlc_ObjRangeBeg(pObj);
- assert( nRange == End - Beg + 1 );
- assert( (int)pFanin->Beg <= Beg && End <= (int)pFanin->End );
- for ( k = Beg; k <= End; k++ )
- Vec_IntPush( vRes, pFans0[k - pFanin->Beg] );
+ if ( End >= Beg )
+ {
+ assert( nRange == End - Beg + 1 );
+ assert( pFanin->Beg <= Beg && End <= pFanin->End );
+ for ( k = Beg; k <= End; k++ )
+ Vec_IntPush( vRes, pFans0[k - pFanin->Beg] );
+ }
+ else
+ {
+ assert( nRange == Beg - End + 1 );
+ assert( pFanin->End <= End && Beg <= pFanin->Beg );
+ for ( k = End; k <= Beg; k++ )
+ Vec_IntPush( vRes, pFans0[k - pFanin->End] );
+ }
}
else if ( pObj->Type == WLC_OBJ_BIT_CONCAT )
{
@@ -1165,8 +1185,16 @@ Gia_Man_t * Wlc_NtkBitBlast( Wlc_Ntk_t * p, Vec_Int_t * vBoxIds )
pFans0 = Vec_IntEntryP( vBits, Wlc_ObjCopy(p, Wlc_ObjId(p, pObj)) );
if ( fVerbose )
printf( "%s(%d) ", Wlc_ObjName(p, Wlc_ObjId(p, pObj)), Gia_ManCoNum(pNew) );
- for ( k = 0; k < nRange; k++ )
- Gia_ManAppendCo( pNew, pFans0[k] );
+ if ( Wlc_ObjRangeIsReversed(pObj) )
+ {
+ for ( k = 0; k < nRange; k++ )
+ Gia_ManAppendCo( pNew, pFans0[nRange-1-k] );
+ }
+ else
+ {
+ for ( k = 0; k < nRange; k++ )
+ Gia_ManAppendCo( pNew, pFans0[k] );
+ }
if ( pObj->fIsFi )
nFFins += nRange;
}
diff --git a/src/base/wlc/wlcNtk.c b/src/base/wlc/wlcNtk.c
index 6205d759..2f3b07bf 100644
--- a/src/base/wlc/wlcNtk.c
+++ b/src/base/wlc/wlcNtk.c
@@ -33,10 +33,10 @@ ABC_NAMESPACE_IMPL_START
static char * Wlc_Names[WLC_OBJ_NUMBER+1] = {
NULL, // 00: unknown
"pi", // 01: primary input
- "po", // 02: primary output
- "ff", // 03: box output
- "bi", // 04: box input
- "ff", // 05: flop
+ "po", // 02: primary output (unused)
+ "ff", // 03: flop output
+ "bi", // 04: flop input (unused)
+ "ff", // 05: flop (unused)
"const", // 06: constant
"buf", // 07: buffer
"mux", // 08: multiplexer
@@ -44,46 +44,46 @@ static char * Wlc_Names[WLC_OBJ_NUMBER+1] = {
">>>", // 10: shift right (arithmetic)
"<<", // 11: shift left
"<<<", // 12: shift left (arithmetic)
- "rotateR", // 13: shift left (arithmetic)
- "rotateL", // 14: shift left (arithmetic)
+ "rotateR", // 13: rotate right
+ "rotateL", // 14: rotate left
"~", // 15: bitwise NOT
"&", // 16: bitwise AND
"|", // 17: bitwise OR
"^", // 18: bitwise XOR
- "~^", // 18: bitwise NXOR
- "[:]", // 19: bit selection
- "{,}", // 20: bit concatenation
- "zeroPad", // 21: zero padding
- "signExt", // 22: sign extension
- "!", // 23: logic NOT
- "&&", // 24: logic AND
- "||", // 25: logic OR
- "^^", // 27: logic XOR
- "==", // 28: compare equal
- "!=", // 29: compare not equal
- "<", // 30: compare less
- ">", // 31: compare more
- "<=", // 32: compare less or equal
- ">=", // 33: compare more or equal
- "&", // 34: reduction AND
- "|", // 35: reduction OR
- "^", // 36: reduction XOR
- "~&", // 34: reduction NAND
- "~|", // 35: reduction NOR
- "~^", // 36: reduction NXOR
- "+", // 37: arithmetic addition
- "-", // 38: arithmetic subtraction
- "*", // 39: arithmetic multiplier
- "/", // 40: arithmetic division
- "%", // 41: arithmetic modulus
- "**", // 42: arithmetic power
- "-", // 43: arithmetic minus
- "sqrt", // 44: integer square root
- "table", // 45: bit table
- NULL // 46: unused
+ "~^", // 19: bitwise NXOR
+ "[:]", // 20: bit selection
+ "{,}", // 21: bit concatenation
+ "zeroPad", // 22: zero padding
+ "signExt", // 23: sign extension
+ "!", // 24: logic NOT
+ "&&", // 25: logic AND
+ "||", // 27: logic OR
+ "^^", // 28: logic XOR
+ "==", // 29: compare equal
+ "!=", // 30: compare not equal
+ "<", // 31: compare less
+ ">", // 32: compare more
+ "<=", // 33: compare less or equal
+ ">=", // 34: compare more or equal
+ "&", // 35: reduction AND
+ "|", // 36: reduction OR
+ "^", // 37: reduction XOR
+ "~&", // 38: reduction NAND
+ "~|", // 39: reduction NOR
+ "~^", // 40: reduction NXOR
+ "+", // 41: arithmetic addition
+ "-", // 42: arithmetic subtraction
+ "*", // 43: arithmetic multiplier
+ "/", // 44: arithmetic division
+ "%", // 45: arithmetic modulus
+ "**", // 46: arithmetic power
+ "-", // 47: arithmetic minus
+ "sqrt", // 48: integer square root
+ "square", // 49: integer square
+ "table", // 50: bit table
+ NULL // 51: unused
};
-
////////////////////////////////////////////////////////////////////////
/// FUNCTION DEFINITIONS ///
////////////////////////////////////////////////////////////////////////
@@ -534,7 +534,12 @@ void Wlc_ObjCollectCopyFanins( Wlc_Ntk_t * p, int iObj, Vec_Int_t * vFanins )
for ( i = 0; i < nInts; i++ )
Vec_IntPush( vFanins, pInts[i] );
}
- else if ( pObj->Type == WLC_OBJ_BIT_SELECT || pObj->Type == WLC_OBJ_TABLE )
+ else if ( pObj->Type == WLC_OBJ_BIT_SELECT )
+ {
+ assert( Vec_IntSize(vFanins) == 1 );
+ Vec_IntPushTwo( vFanins, Wlc_ObjRangeEnd(pObj), Wlc_ObjRangeBeg(pObj) );
+ }
+ else if ( pObj->Type == WLC_OBJ_TABLE )
{
assert( Vec_IntSize(vFanins) == 1 );
Vec_IntPush( vFanins, pObj->Fanins[1] );
diff --git a/src/base/wlc/wlcReadSmt.c b/src/base/wlc/wlcReadSmt.c
index 2c158a48..4ef0f537 100644
--- a/src/base/wlc/wlcReadSmt.c
+++ b/src/base/wlc/wlcReadSmt.c
@@ -409,7 +409,7 @@ int Smt_PrsBuildNode( Wlc_Ntk_t * pNtk, Smt_Prs_t * p, int iNode, int RangeOut,
if ( Type == WLC_OBJ_BIT_SELECT )
{
assert( Value1 >= 0 && Value2 >= 0 && Value1 >= Value2 );
- Vec_IntPush( vFanins, (Value1 << 16) | Value2 );
+ Vec_IntPushTwo( vFanins, Value1, Value2 );
}
else if ( Type == WLC_OBJ_ROTATE_R || Type == WLC_OBJ_ROTATE_L )
{
diff --git a/src/base/wlc/wlcReadVer.c b/src/base/wlc/wlcReadVer.c
index 7347299c..30525df4 100644
--- a/src/base/wlc/wlcReadVer.c
+++ b/src/base/wlc/wlcReadVer.c
@@ -43,10 +43,9 @@ struct Wlc_Prs_t_
Mem_Flex_t * pMemTable;
Vec_Ptr_t * vTables;
int nConsts;
- int nNonZeroCount;
- int nNonZeroEnd;
- int nNonZeroBeg;
- int nNonZeroLine;
+ int nNonZero[4];
+ int nNegative[4];
+ int nReverse[4];
char sError[WLV_PRS_MAX_LINE];
};
@@ -473,7 +472,7 @@ static inline char * Wlc_PrsFindRange( char * pStr, int * End, int * Beg )
if ( pStr[0] != '[' )
return pStr;
pStr = Wlc_PrsSkipSpaces( pStr+1 );
- if ( !Wlc_PrsIsDigit(pStr) )
+ if ( !Wlc_PrsIsDigit(pStr) && pStr[0] != '-' )
return NULL;
*End = *Beg = atoi( pStr );
if ( Wlc_PrsFindSymbol( pStr, ':' ) == NULL )
@@ -486,16 +485,13 @@ static inline char * Wlc_PrsFindRange( char * pStr, int * End, int * Beg )
{
pStr = Wlc_PrsFindSymbol( pStr, ':' );
pStr = Wlc_PrsSkipSpaces( pStr+1 );
- if ( !Wlc_PrsIsDigit(pStr) )
+ if ( !Wlc_PrsIsDigit(pStr) && pStr[0] != '-' )
return NULL;
*Beg = atoi( pStr );
pStr = Wlc_PrsFindSymbol( pStr, ']' );
if ( pStr == NULL )
return NULL;
}
- if ( *End < *Beg )
- return NULL;
- assert( *End >= *Beg );
return pStr + 1;
}
static inline char * Wlc_PrsFindWord( char * pStr, char * pWord, int * fFound )
@@ -770,7 +766,7 @@ static inline int Wlc_PrsFindDefinition( Wlc_Prs_t * p, char * pStr, Vec_Int_t *
pStr = Wlc_PrsFindRange( pStr, &End, &Beg );
if ( pStr == NULL )
return Wlc_PrsWriteErrorMessage( p, pLine, "Non-standard range." );
- Vec_IntPush( vFanins, (End << 16) | Beg );
+ Vec_IntPushTwo( vFanins, End, Beg );
Type = WLC_OBJ_BIT_SELECT;
}
else
@@ -834,13 +830,31 @@ int Wlc_PrsReadDeclaration( Wlc_Prs_t * p, char * pStart )
pStart = Wlc_PrsFindRange( pStart, &End, &Beg );
if ( pStart == NULL )
return Wlc_PrsWriteErrorMessage( p, pLine, "Non-standard range." );
- if ( Beg != 0 )
+ if ( End != 0 && Beg != 0 )
+ {
+ if ( p->nNonZero[0]++ == 0 )
+ {
+ p->nNonZero[1] = End;
+ p->nNonZero[2] = Beg;
+ p->nNonZero[3] = Wlc_PrsFindLine(p, pStart);
+ }
+ }
+ if ( End < 0 || Beg < 0 )
{
- if ( p->nNonZeroCount++ == 0 )
+ if ( p->nNegative[0]++ == 0 )
{
- p->nNonZeroEnd = End;
- p->nNonZeroBeg = Beg;
- p->nNonZeroLine = Wlc_PrsFindLine(p, pStart);
+ p->nNegative[1] = End;
+ p->nNegative[2] = Beg;
+ p->nNegative[3] = Wlc_PrsFindLine(p, pStart);
+ }
+ }
+ if ( End < Beg )
+ {
+ if ( p->nReverse[0]++ == 0 )
+ {
+ p->nReverse[1] = End;
+ p->nReverse[2] = Beg;
+ p->nReverse[3] = Wlc_PrsFindLine(p, pStart);
}
}
while ( 1 )
@@ -1140,7 +1154,10 @@ startword:
if ( nValues != Vec_IntSize(p->vFanins) - 1 )
return Wlc_PrsWriteErrorMessage( p, pStart, "The number of values in the case statement is wrong.", pName );
if ( Wlc_ObjRange(pObj) == 1 )
- return Wlc_PrsWriteErrorMessage( p, pStart, "Always-statement with 1-bit control is not bit-blasted correctly.", pName );
+ {
+// return Wlc_PrsWriteErrorMessage( p, pStart, "Always-statement with 1-bit control is not bit-blasted correctly.", pName );
+ printf( "Warning: Case-statement with 1-bit control is treated as a 2:1 MUX (correct for unsigned signals only).\n" );
+ }
pObj = Wlc_NtkObj( p->pNtk, NameIdOut );
Wlc_ObjUpdateType( p->pNtk, pObj, WLC_OBJ_MUX );
Wlc_ObjAddFanins( p->pNtk, pObj, p->vFanins );
@@ -1210,10 +1227,20 @@ startword:
return Wlc_PrsWriteErrorMessage( p, pStart, "Cannot read line beginning with %s.", pName );
}
}
- if ( p->nNonZeroCount )
+ if ( p->nNonZero[0] )
+ {
+ printf( "Warning: Input file contains %d objects with non-zero-based ranges.\n", p->nNonZero[0] );
+ printf( "For example, signal with range [%d:%d] is declared in line %d.\n", p->nNonZero[1], p->nNonZero[2], p->nNonZero[3] );
+ }
+ if ( p->nNegative[0] )
+ {
+ printf( "Warning: Input file contains %d objects with negative ranges.\n", p->nNegative[0] );
+ printf( "For example, signal with range [%d:%d] is declared in line %d.\n", p->nNegative[1], p->nNegative[2], p->nNegative[3] );
+ }
+ if ( p->nReverse[0] )
{
- printf( "Warning: %d objects in the input file have non-zero-based ranges.\n", p->nNonZeroCount );
- printf( "In particular, a signal with range [%d:%d] is declared in line %d.\n", p->nNonZeroEnd, p->nNonZeroBeg, p->nNonZeroLine );
+ printf( "Warning: Input file contains %d objects with reversed ranges.\n", p->nReverse[0] );
+ printf( "For example, signal with range [%d:%d] is declared in line %d.\n", p->nReverse[1], p->nReverse[2], p->nReverse[3] );
}
return 1;
}
diff --git a/src/base/wlc/wlcWriteVer.c b/src/base/wlc/wlcWriteVer.c
index 8fa0ddf6..01f41af1 100644
--- a/src/base/wlc/wlcWriteVer.c
+++ b/src/base/wlc/wlcWriteVer.c
@@ -165,7 +165,7 @@ void Wlc_WriteVerInt( FILE * pFile, Wlc_Ntk_t * p, int fNoFlops )
Wlc_ObjFanin1(p, pObj)->Mark = 1;
Wlc_NtkForEachObj( p, pObj, i )
{
- int nDigits = Abc_Base10Log(pObj->End+1) + Abc_Base10Log(pObj->Beg+1);
+ int nDigits = Abc_Base10Log(Abc_AbsInt(pObj->End)+1) + Abc_Base10Log(Abc_AbsInt(pObj->Beg)+1) + (int)(pObj->End < 0) + (int)(pObj->Beg < 0);
if ( pObj->Mark )
{
pObj->Mark = 0;