Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
A
abc
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
abc
Commits
a6f363d4
Commit
a6f363d4
authored
Mar 01, 2012
by
Alan Mishchenko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Created a communication bridge.
parent
325ac583
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
183 additions
and
8 deletions
+183
-8
src/misc/util/abc_global.h
+14
-2
src/misc/util/utilBridge.c
+111
-6
src/misc/util/utilFile.c
+58
-0
No files found.
src/misc/util/abc_global.h
View file @
a6f363d4
...
...
@@ -256,16 +256,28 @@ enum Abc_VerbLevel
ABC_VERBOSE
=
2
};
extern
int
Gia_ManToBridgeText
(
FILE
*
pFile
,
int
Size
,
unsigned
char
*
pBuffer
);
// string printing
extern
char
*
vnsprintf
(
const
char
*
format
,
va_list
args
);
extern
char
*
nsprintf
(
const
char
*
format
,
...);
static
inline
void
Abc_Print
(
int
level
,
const
char
*
format
,
...
)
{
extern
int
in_bridge_mode
;
va_list
args
;
// if ( level > -2 )
// return;
if
(
level
==
ABC_ERROR
)
printf
(
"Error: "
);
else
if
(
level
==
ABC_WARNING
)
printf
(
"Warning: "
);
va_start
(
args
,
format
);
if
(
in_bridge_mode
)
{
unsigned
char
*
tmp
=
vnsprintf
(
format
,
args
);
Gia_ManToBridgeText
(
stdout
,
strlen
(
tmp
),
tmp
);
free
(
tmp
);
}
else
vprintf
(
format
,
args
);
va_end
(
args
);
}
...
...
src/misc/util/utilBridge.c
View file @
a6f363d4
...
...
@@ -29,7 +29,6 @@
ABC_NAMESPACE_IMPL_START
////////////////////////////////////////////////////////////////////////
/// DECLARATIONS ///
////////////////////////////////////////////////////////////////////////
...
...
@@ -37,7 +36,10 @@ ABC_NAMESPACE_IMPL_START
extern
void
Gia_WriteAigerEncodeStr
(
Vec_Str_t
*
vStr
,
unsigned
x
);
extern
unsigned
Gia_ReadAigerDecode
(
unsigned
char
**
ppPos
);
extern
void
Gia_WriteAigerEncodeStr
(
Vec_Str_t
*
vStr
,
unsigned
x
);
// this variable determines where the output goes
int
in_bridge_mode
=
0
;
////////////////////////////////////////////////////////////////////////
/// FUNCTION DEFINITIONS ///
...
...
@@ -54,7 +56,7 @@ extern unsigned Gia_ReadAigerDecode( unsigned char ** ppPos );
SeeAlso []
***********************************************************************/
Vec_Str_t
*
Gia_ManToBridgeVec
(
FILE
*
pFile
,
Gia_Man_t
*
p
)
Vec_Str_t
*
Gia_ManToBridgeVec
(
Gia_Man_t
*
p
)
{
Vec_Str_t
*
vBuffer
;
Gia_Obj_t
*
pObj
;
...
...
@@ -126,13 +128,113 @@ Vec_Str_t * Gia_ManToBridgeVec( FILE * pFile, Gia_Man_t * p )
SeeAlso []
***********************************************************************/
int
Gia_ManToBridge
(
FILE
*
pFile
,
Gia_Man_t
*
pMan
)
void
Gia_CreateHeader
(
FILE
*
pFile
,
int
Type
,
int
Size
,
unsigned
char
*
pBuffer
)
{
fprintf
(
pFile
,
"%.6d"
,
Type
);
fprintf
(
pFile
,
" "
);
fprintf
(
pFile
,
"%.16d"
,
Size
);
fprintf
(
pFile
,
" "
);
fwrite
(
pBuffer
,
Size
,
1
,
pFile
);
fflush
(
pFile
);
}
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
#define BRIDGE_TEXT_MESSAGE 999996
#define BRIDGE_RESULTS 101
#define BRIDGE_ABS_NETLIST 107
#define BRIDGE_BAD_ABS 105
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
int
Gia_ManToBridgeText
(
FILE
*
pFile
,
int
Size
,
unsigned
char
*
pBuffer
)
{
Gia_CreateHeader
(
pFile
,
BRIDGE_TEXT_MESSAGE
,
Size
,
pBuffer
);
return
1
;
}
int
Gia_ManToBridgeAbsNetlist
(
FILE
*
pFile
,
Gia_Man_t
*
p
)
{
Vec_Str_t
*
vBuffer
;
vBuffer
=
Gia_ManToBridgeVec
(
p
File
,
pMan
);
fwrite
(
Vec_StrArray
(
vBuffer
),
1
,
Vec_StrSize
(
vBuffer
),
pFile
);
vBuffer
=
Gia_ManToBridgeVec
(
p
);
Gia_CreateHeader
(
pFile
,
BRIDGE_ABS_NETLIST
,
Vec_StrSize
(
vBuffer
),
(
unsigned
char
*
)
Vec_StrArray
(
vBuffer
)
);
Vec_StrFree
(
vBuffer
);
return
0
;
return
1
;
}
int
Gia_ManToBridgeBadAbs
(
FILE
*
pFile
)
{
Gia_CreateHeader
(
pFile
,
BRIDGE_BAD_ABS
,
0
,
NULL
);
return
1
;
}
void
Gia_ManFromBridgeHolds
(
FILE
*
pFile
)
{
fputc
(
(
char
)
3
,
pFile
);
// true
fputc
(
(
char
)
1
,
pFile
);
// size of vector (Armin's encoding)
fputc
(
(
char
)
0
,
pFile
);
// number of the property (Armin's encoding)
fputc
(
(
char
)
0
,
pFile
);
// no invariant
}
void
Gia_ManFromBridgeUnknown
(
FILE
*
pFile
)
{
fputc
(
(
char
)
0
,
pFile
);
// undef
fputc
(
(
char
)
1
,
pFile
);
// size of vector (Armin's encoding)
fputc
(
(
char
)
0
,
pFile
);
// number of the property (Armin's encoding)
}
void
Gia_ManFromBridgeCex
(
FILE
*
pFile
,
Abc_Cex_t
*
pCex
)
{
int
i
,
f
,
iBit
;
Vec_Str_t
*
vStr
=
Vec_StrAlloc
(
1000
);
Vec_StrPush
(
vStr
,
(
char
)
2
);
// false
Vec_StrPush
(
vStr
,
(
char
)
1
);
// size of vector (Armin's encoding)
Vec_StrPush
(
vStr
,
(
char
)
0
);
// number of the property (Armin's encoding)
Vec_StrPush
(
vStr
,
(
char
)
1
);
// size of vector (Armin's encoding)
Gia_WriteAigerEncodeStr
(
vStr
,
pCex
->
iFrame
);
// depth
Gia_WriteAigerEncodeStr
(
vStr
,
1
);
// concrete
Gia_WriteAigerEncodeStr
(
vStr
,
pCex
->
iFrame
);
// n frames
iBit
=
pCex
->
nRegs
;
for
(
f
=
0
;
f
<=
pCex
->
iFrame
;
f
++
)
{
Gia_WriteAigerEncodeStr
(
vStr
,
pCex
->
nPis
);
// num of inputs
for
(
i
=
0
;
i
<
pCex
->
nPis
;
i
++
)
Vec_StrPush
(
vStr
,
(
char
)(
Abc_InfoHasBit
(
pCex
->
pData
,
iBit
++
)
?
3
:
2
)
);
// value
}
assert
(
iBit
==
pCex
->
nBits
);
Vec_StrPush
(
vStr
,
(
char
)
1
);
// the number of frames (for a concrete counter-example)
for
(
i
=
0
;
i
<
pCex
->
nRegs
;
i
++
)
Vec_StrPush
(
vStr
,
(
char
)
2
);
// always zero ??????????????
fwrite
(
Vec_StrArray
(
vStr
),
Vec_StrSize
(
vStr
),
1
,
pFile
);
Vec_StrFree
(
vStr
);
}
int
Gia_ManToBridgeResult
(
FILE
*
pFile
,
int
Result
,
Abc_Cex_t
*
pCex
)
{
if
(
Result
==
0
)
// sat
Gia_ManFromBridgeCex
(
pFile
,
pCex
);
else
if
(
Result
==
1
)
// unsat
Gia_ManFromBridgeHolds
(
pFile
);
else
if
(
Result
==
-
1
)
// undef
Gia_ManFromBridgeUnknown
(
pFile
);
else
assert
(
0
);
return
1
;
}
...
...
@@ -222,6 +324,7 @@ Gia_Man_t * Gia_ManFromBridgeReadBody( int Size, unsigned char * pBuffer, Vec_I
for
(
i
=
0
;
i
<
nFlops
;
i
++
)
{
iFan0
=
Gia_ReadAigerDecode
(
&
pBuffer
);
assert
(
(
iFan0
&
3
)
==
2
);
Vec_IntPush
(
vInits
,
iFan0
&
3
);
// 0 = X value; 1 = not used; 2 = false; 3 = true
iFan0
>>=
2
;
iFan0
=
Abc_LitNotCond
(
Vec_IntEntry
(
vLits
,
iFan0
>>
1
),
iFan0
&
1
);
...
...
@@ -360,6 +463,8 @@ void Gia_ManFromBridgeTest( char * pFileName )
Gia_ManStop
(
p
);
}
////////////////////////////////////////////////////////////////////////
/// END OF FILE ///
////////////////////////////////////////////////////////////////////////
...
...
src/misc/util/utilFile.c
View file @
a6f363d4
...
...
@@ -154,6 +154,64 @@ int main(int argc, char** argv)
}
*/
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
char
*
vnsprintf
(
const
char
*
format
,
va_list
args
)
{
unsigned
n
;
char
*
ret
;
va_list
args_copy
;
static
FILE
*
dummy_file
=
NULL
;
if
(
!
dummy_file
)
{
#if !defined(_MSC_VER)
dummy_file
=
fopen
(
"/dev/null"
,
"wb"
);
#else
dummy_file
=
fopen
(
"NUL"
,
"wb"
);
#endif
}
#if defined(__va_copy)
__va_copy
(
args_copy
,
args
);
#else
#if defined(va_copy)
va_copy
(
args_copy
,
args
);
#else
args_copy
=
args
;
#endif
#endif
n
=
vfprintf
(
dummy_file
,
format
,
args
);
ret
=
ABC_ALLOC
(
char
,
n
+
1
);
ret
[
n
]
=
(
char
)
255
;
args
=
args_copy
;
vsprintf
(
ret
,
format
,
args
);
#if !defined(__va_copy) && defined(va_copy)
va_end
(
args_copy
);
#endif
assert
(
ret
[
n
]
==
0
);
return
ret
;
}
char
*
nsprintf
(
const
char
*
format
,
...)
{
char
*
ret
;
va_list
args
;
va_start
(
args
,
format
);
ret
=
vnsprintf
(
format
,
args
);
va_end
(
args
);
return
ret
;
}
////////////////////////////////////////////////////////////////////////
/// END OF FILE ///
////////////////////////////////////////////////////////////////////////
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment