Compare commits
No commits in common. "d5bf86c1f580d5fcb313458ee116c7411f860f75" and "ed3fa2ead99e99665b3af224c86cb972743204ca" have entirely different histories.
d5bf86c1f5
...
ed3fa2ead9
12 changed files with 112 additions and 58 deletions
|
@ -1,18 +1,6 @@
|
|||
#include "libChf/src/Chf.h"
|
||||
#include "chf_messages.h"
|
||||
|
||||
ChfTable message_table[] = {
|
||||
{CHF_SET, CHF_S_OK, "" },
|
||||
{CHF_SET, CHF_F_COND_STACK_FULL, "Condition stack is full" },
|
||||
{CHF_SET, CHF_F_HDLR_STACK_FULL, "Handler stack is full" },
|
||||
{CHF_SET, CHF_F_HDLR_STACK_EMPTY, "Handler stack is empty" },
|
||||
{CHF_SET, CHF_F_BAD_STATE, "Wrong Chf state for requested operation" },
|
||||
{CHF_SET, CHF_F_INVALID_ACTION, "Invalid action code from handler (code=<%d>d)" },
|
||||
{CHF_SET, CHF_F_MALLOC, "Dynamic memory allocation failed" },
|
||||
{CHF_SET, CHF_F_NOT_AVAILABLE, "Function not implemented" },
|
||||
{CHF_SET, CHF_F_SETLOCALE, "setlocale() failed" },
|
||||
{CHF_SET, CHF_F_CATOPEN, "catopen() failed" },
|
||||
|
||||
{CPU_CHF_MODULE_ID, CPU_I_CALLED, "Function [%s] called" },
|
||||
{CPU_CHF_MODULE_ID, CPU_I_EXECUTING, "Executing @ PC[%05X]" },
|
||||
{CPU_CHF_MODULE_ID, CPU_I_SHUTDN, "CPU shutdown executed" },
|
||||
|
|
|
@ -259,7 +259,7 @@ static void EmulatorLoop( void )
|
|||
}
|
||||
|
||||
/* Condition handler for the EmulatorLoop */
|
||||
static ChfAction EmulatorLoopHandler( const ChfDescriptor* d, const ChfState s, void* _ctx )
|
||||
static ChfAction EmulatorLoopHandler( const ChfDescriptor* d, const ChfState s, ChfPointer _ctx )
|
||||
{
|
||||
ChfAction act;
|
||||
|
||||
|
@ -515,7 +515,7 @@ void Emulator( void )
|
|||
/* Setup unwind_context */
|
||||
if ( setjmp( unwind_context ) == 0 ) {
|
||||
/* Push condition handler, with NULL context */
|
||||
ChfPushHandler( CPU_CHF_MODULE_ID, EmulatorLoopHandler, &unwind_context, ( void* )NULL );
|
||||
ChfPushHandler( CPU_CHF_MODULE_ID, EmulatorLoopHandler, &unwind_context, ( ChfPointer )NULL );
|
||||
|
||||
/* Activate emulator loop */
|
||||
EmulatorLoop();
|
||||
|
|
|
@ -976,7 +976,7 @@ typedef /* Condition handler */
|
|||
ChfAction (*ChfHandler)(
|
||||
const ChfDescriptor *,
|
||||
const ChfState,
|
||||
void*
|
||||
ChfPointer
|
||||
);
|
||||
@end example
|
||||
|
||||
|
@ -990,7 +990,7 @@ is a pointer to the condition group that is being signaled.
|
|||
@item const ChfState
|
||||
represents the current state of the condition handling facility.
|
||||
|
||||
@item void*
|
||||
@item ChfPointer
|
||||
is a copy of the @code{handler_context} pointer passed to the
|
||||
@code{ChfPushHandler()} invocation that established the condition
|
||||
handler.
|
||||
|
@ -1024,7 +1024,7 @@ of the new condition group allows it to do so.
|
|||
@subsection ChfPushHandler()
|
||||
@cindex Condition handlers
|
||||
@cindex Adding condition handlers
|
||||
@deftypefn Function void ChfPushHandler (ChfHandler new_handler, void *unwind_context, void* handler_context)
|
||||
@deftypefn Function void ChfPushHandler (ChfHandler new_handler, void *unwind_context, ChfPointer handler_context)
|
||||
|
||||
This function pushes the new condition handler @code{new_handler} with
|
||||
its associated @code{siglongjmp()} context, pointed by
|
||||
|
|
|
@ -30,9 +30,9 @@
|
|||
- Added structured condition handling macros: CHF_Try, CHF_Catch, CHF_EndTry
|
||||
|
||||
Revision 1.6 1997/01/15 13:41:20 cibrario
|
||||
Defined the new data type void*, a generic (void *) pointer. Each
|
||||
Defined the new data type ChfPointer, a generic (void *) pointer. Each
|
||||
condition handler can have a private handler context pointer, of type
|
||||
void*, that the function ChfPushHandler() stores and that is passed
|
||||
ChfPointer, that the function ChfPushHandler() stores and that is passed
|
||||
to the handler when it's activated.
|
||||
Fixed a wrong adjustment of the condition handlers stack pointer after
|
||||
an unwind operation.
|
||||
|
@ -66,7 +66,7 @@
|
|||
#define CHF_UNKNOWN_FILE_NAME ( char* )NULL
|
||||
#define CHF_NULL_DESCRIPTOR ( ChfDescriptor* )NULL
|
||||
#define CHF_NULL_CONTEXT ( void* )NULL
|
||||
#define CHF_NULL_POINTER ( void** )NULL
|
||||
#define CHF_NULL_POINTER ( ChfPointer* )NULL
|
||||
#define CHF_NULL_HANDLER ( ChfHandler ) NULL
|
||||
#define CHF_LIBRARY_ID "$Id: Chf.h,v 2.2 2001/01/25 11:56:44 cibrario Exp $"
|
||||
|
||||
|
@ -141,8 +141,11 @@ typedef struct ChfTable_S /* Standalone message table */
|
|||
char* msg_template; /* Message template */
|
||||
} ChfTable;
|
||||
|
||||
typedef /* Generic pointer */
|
||||
void* ChfPointer;
|
||||
|
||||
typedef /* Condition handler */
|
||||
ChfAction ( *ChfHandler )( const ChfDescriptor*, const ChfState, void* );
|
||||
ChfAction ( *ChfHandler )( const ChfDescriptor*, const ChfState, ChfPointer );
|
||||
|
||||
typedef /* Message retrieval 'get_message' function */
|
||||
const char* ( *ChfMrsGet )( void*, const int, const int, const char* default_message );
|
||||
|
@ -233,7 +236,7 @@ void ChfAbort( const int abort_code );
|
|||
/* Push a new handler into the stack */
|
||||
void ChfPushHandler( const int module_id, ChfHandler new_handler, /* Handler to be added */
|
||||
void* unwind_context, /* Unwind context */
|
||||
void* handler_context /* Private handler context */
|
||||
ChfPointer handler_context /* Private handler context */
|
||||
);
|
||||
/* Pop a handler */
|
||||
void ChfPopHandler( const int module_id );
|
||||
|
|
|
@ -49,6 +49,16 @@
|
|||
#define CHF_MODULE_ID CHF_SET
|
||||
#define CHF_TMP_MESSAGE_LENGTH ( 2 * CHF_MAX_MESSAGE_LENGTH )
|
||||
#define CHF_DEF_MESSAGE_LENGTH 40
|
||||
#define CHF_DEF_PARTIAL_MSG_FMT "Code <%d>d"
|
||||
#define CHF_DEF_MID_MSG_FMT "Mid <%d>d"
|
||||
#define CHF_EXTENDED_INFO_FMT "(%s,%)"
|
||||
#define CHF_SEVERITY_NAMES { "S", "I", "W", "E", "F" }
|
||||
#define CHF_UNKNOWN_SEVERITY "?"
|
||||
#define CHF_MESSAGE_SEPARATOR "-"
|
||||
#define CHF_MESSAGE_TERMINATOR "\n"
|
||||
#define CHF_ABORT_HEADER "ChfAbort-F-"
|
||||
#define CHF_ABORT_BAD_CODE_FMT "Bad abort code <%d>d\n"
|
||||
#define CHF_ABORT_GOOD_CODE_FMT "%s\n"
|
||||
|
||||
/* -------------------------------------------------------------------------
|
||||
Abort codes used with ChfAbort()
|
||||
|
@ -73,7 +83,7 @@
|
|||
typedef struct ChfHandlerDescriptor_S {
|
||||
ChfHandler handler;
|
||||
void* unwind_context;
|
||||
void* handler_context;
|
||||
ChfPointer handler_context;
|
||||
} ChfHandlerDescriptor;
|
||||
|
||||
typedef struct ChfContext_S /* CHF Context */
|
||||
|
@ -117,4 +127,15 @@ extern ChfContext _chf_context; /* CHF Context */
|
|||
ChfContext* _ChfGetContext( void );
|
||||
#endif
|
||||
|
||||
/* -------------------------------------------------------------------------
|
||||
Private redirection of stdlib functions needed by Win32
|
||||
------------------------------------------------------------------------- */
|
||||
|
||||
#define ChfStrlen strlen
|
||||
#define ChfStrcpy strcpy
|
||||
#define ChfStrcat strcat
|
||||
#define ChfStrncpy strncpy
|
||||
#define ChfSprintf sprintf
|
||||
#define ChfVsprintf vsprintf
|
||||
|
||||
#endif /*!_CHF_PRIV_H*/
|
||||
|
|
40
src/libChf/src/chf.msf
Normal file
40
src/libChf/src/chf.msf
Normal file
|
@ -0,0 +1,40 @@
|
|||
$ .+
|
||||
$ .
|
||||
$ .identifier : $Id: chf.msf,v 2.2 2001/01/25 12:00:19 cibrario Exp $
|
||||
$ .context :
|
||||
$ .title : $RCSfile: chf.msf,v $
|
||||
$ .kind : Makefile
|
||||
$ .author : Ivan Cibrario B.
|
||||
$ .site : CSTV-CNR
|
||||
$ .creation : 27-May-1996
|
||||
$ .keywords : *
|
||||
$ .description :
|
||||
$ . Message source file for the CHF conditions
|
||||
$ .notes :
|
||||
$ . $Log: chf.msf,v $
|
||||
$ . Revision 2.2 2001/01/25 12:00:19 cibrario
|
||||
$ . Added partial Win32 support (Windows CE only).
|
||||
$ .
|
||||
$ . Revision 2.1 2000/05/26 14:17:21 cibrario
|
||||
$ . Updated documentation block and RCS log message header to prevent
|
||||
$ . gencat warnings on Linux boxes
|
||||
$ .
|
||||
$ . Revision 1.1 1996/05/28 12:57:06 cibrario
|
||||
$ . Initial revision
|
||||
$ .
|
||||
$ .-
|
||||
|
||||
$set 1
|
||||
2 Chf
|
||||
3 Errno
|
||||
|
||||
$set 2
|
||||
1 Condition stack is full
|
||||
2 Handler stack is full
|
||||
3 Handler stack is empty
|
||||
4 Wrong Chf state for requested operation
|
||||
5 Invalid action code from handler (code=<%d>d)
|
||||
6 Dynamic memory allocation failed
|
||||
7 Function not implemented
|
||||
10 setlocale() failed
|
||||
11 catopen() failed
|
|
@ -109,13 +109,13 @@ void ChfAbort( /* Abort application */
|
|||
"Pthread interaction failed" };
|
||||
|
||||
if ( abort_code != CHF_ABORT_SILENT ) {
|
||||
fputs( "ChfAbort-F-", stderr );
|
||||
fputs( CHF_ABORT_HEADER, stderr );
|
||||
|
||||
if ( abort_code < 0 || abort_code >= ( int )( sizeof( message_table ) / sizeof( const char* ) ) )
|
||||
fprintf( stderr, "Bad abort code <%d>d\n", abort_code );
|
||||
fprintf( stderr, CHF_ABORT_BAD_CODE_FMT, abort_code );
|
||||
|
||||
else
|
||||
fprintf( stderr, "%s\n", message_table[ abort_code ] );
|
||||
fprintf( stderr, CHF_ABORT_GOOD_CODE_FMT, message_table[ abort_code ] );
|
||||
}
|
||||
|
||||
if ( chf_context.state == CHF_UNKNOWN || chf_context.options & CHF_ABORT )
|
||||
|
|
|
@ -106,7 +106,7 @@ void ChfGenerate( /* Generate a condition into the stack */
|
|||
new_descriptor->line_number = CHF_UNKNOWN_LINE_NUMBER;
|
||||
new_descriptor->file_name = CHF_UNKNOWN_FILE_NAME;
|
||||
|
||||
strncpy( new_descriptor->message, ChfGetMessage( module_id, CHF_F_COND_STACK_FULL, "Condition stack is full" ),
|
||||
ChfStrncpy( new_descriptor->message, ChfGetMessage( module_id, CHF_F_COND_STACK_FULL, "Condition stack is full" ),
|
||||
CHF_MAX_MESSAGE_LENGTH - 1 );
|
||||
new_descriptor->message[ CHF_MAX_MESSAGE_LENGTH - 1 ] = '\0';
|
||||
|
||||
|
@ -131,16 +131,16 @@ void ChfGenerate( /* Generate a condition into the stack */
|
|||
new_descriptor->file_name = file_name;
|
||||
|
||||
/* Generate the default message */
|
||||
sprintf( def_message, "Code <%d>d", condition_code );
|
||||
ChfSprintf( def_message, CHF_DEF_PARTIAL_MSG_FMT, condition_code );
|
||||
|
||||
/* Generate the partial message associated with the condition using a
|
||||
temporary area
|
||||
*/
|
||||
if ( vsprintf( tmp_message, ChfGetMessage( module_id, condition_code, def_message ), aux_arg ) >= CHF_TMP_MESSAGE_LENGTH )
|
||||
if ( ChfVsprintf( tmp_message, ChfGetMessage( module_id, condition_code, def_message ), aux_arg ) >= CHF_TMP_MESSAGE_LENGTH )
|
||||
ChfAbort( CHF_ABORT_MSG_OVF );
|
||||
|
||||
/* Copy the message into the condition descriptor */
|
||||
strncpy( new_descriptor->message, tmp_message, CHF_MAX_MESSAGE_LENGTH - 1 );
|
||||
ChfStrncpy( new_descriptor->message, tmp_message, CHF_MAX_MESSAGE_LENGTH - 1 );
|
||||
new_descriptor->message[ CHF_MAX_MESSAGE_LENGTH - 1 ] = '\0';
|
||||
|
||||
/* Link the new descriptor with the current descriptor list, if it
|
||||
|
|
|
@ -78,7 +78,7 @@
|
|||
2.1, 19-May-2000, creation
|
||||
|
||||
.- */
|
||||
static ChfAction StructuredHelper( const ChfDescriptor* desc, const ChfState state, void* handler_context )
|
||||
static ChfAction StructuredHelper( const ChfDescriptor* desc, const ChfState state, ChfPointer handler_context )
|
||||
{
|
||||
ChfAction action;
|
||||
const ChfDescriptor* d;
|
||||
|
@ -128,7 +128,7 @@ static ChfAction StructuredHelper( const ChfDescriptor* desc, const ChfState sta
|
|||
.input :
|
||||
ChfHandler new_handler, new condition handler
|
||||
void *unwind_context, handler unwind context pointer
|
||||
void* handler_context, private handler context pointer
|
||||
ChfPointer handler_context, private handler context pointer
|
||||
.output :
|
||||
void
|
||||
.status_codes :
|
||||
|
@ -145,7 +145,7 @@ static ChfAction StructuredHelper( const ChfDescriptor* desc, const ChfState sta
|
|||
|
||||
.- */
|
||||
void ChfPushHandler( /* Push a new handler into the stack */
|
||||
const int module_id, ChfHandler new_handler, void* unwind_context, void* handler_context )
|
||||
const int module_id, ChfHandler new_handler, void* unwind_context, ChfPointer handler_context )
|
||||
{
|
||||
/* Make sure that CHF has been correctly initialized and is idle */
|
||||
if ( chf_context.state == CHF_UNKNOWN )
|
||||
|
|
|
@ -69,8 +69,8 @@ static char rcs_lib_id[] = CHF_LIBRARY_ID;
|
|||
ChfContext _chf_context;
|
||||
|
||||
/* Message separator and severity names for ChfBuildMessage() */
|
||||
static const char separator[] = "-";
|
||||
static const char* severity_name[] = { "S", "I", "W", "E", "F" };
|
||||
static const char separator[] = CHF_MESSAGE_SEPARATOR;
|
||||
static const char* severity_name[] = CHF_SEVERITY_NAMES;
|
||||
|
||||
/* -------------------------------------------------------------------------
|
||||
Multithreading support
|
||||
|
@ -155,7 +155,7 @@ static void DestroyContext( void* context )
|
|||
- added Win32 support
|
||||
|
||||
.- */
|
||||
static ChfAction DefaultHandler( const ChfDescriptor* desc, const ChfState state, void* handler_context )
|
||||
static ChfAction DefaultHandler( const ChfDescriptor* desc, const ChfState state, ChfPointer handler_context )
|
||||
{
|
||||
ChfAction action;
|
||||
const ChfDescriptor* d;
|
||||
|
@ -235,16 +235,16 @@ static ChfAction DefaultHandler( const ChfDescriptor* desc, const ChfState state
|
|||
.- */
|
||||
static char* scopy( char* p, const char* q, char* p_end )
|
||||
{
|
||||
size_t q_len = strlen( q );
|
||||
size_t q_len = ChfStrlen( q );
|
||||
size_t p_avail = p_end - p;
|
||||
|
||||
if ( q_len < p_avail ) {
|
||||
strcpy( p, q );
|
||||
ChfStrcpy( p, q );
|
||||
p += q_len;
|
||||
}
|
||||
|
||||
else if ( p_avail > 1 ) {
|
||||
strncpy( p, q, p_avail - 2 );
|
||||
ChfStrncpy( p, q, p_avail - 2 );
|
||||
p[ p_avail - 1 ] = '\0';
|
||||
p = p_end;
|
||||
}
|
||||
|
@ -374,7 +374,7 @@ char* ChfBuildMessage( /* Build a condition message */
|
|||
tmp_p = scopy( tmp_p, "\t", tmp_end );
|
||||
|
||||
/* The message continues with the module name */
|
||||
sprintf( def_message, "Mid <%d>d", descriptor->module_id );
|
||||
ChfSprintf( def_message, CHF_DEF_MID_MSG_FMT, descriptor->module_id );
|
||||
|
||||
tmp_p = scopy( tmp_p, ChfGetMessage( CHF_MODULE_NAMES_SET, descriptor->module_id, def_message ), tmp_end );
|
||||
|
||||
|
@ -382,7 +382,7 @@ char* ChfBuildMessage( /* Build a condition message */
|
|||
if ( descriptor->line_number != CHF_UNKNOWN_LINE_NUMBER ) {
|
||||
tmp_p = scopy( tmp_p, " ", tmp_end );
|
||||
|
||||
sprintf( def_message, "(%s,%)", descriptor->file_name, descriptor->line_number );
|
||||
ChfSprintf( def_message, CHF_EXTENDED_INFO_FMT, descriptor->file_name, descriptor->line_number );
|
||||
|
||||
tmp_p = scopy( tmp_p, def_message, tmp_end );
|
||||
}
|
||||
|
@ -390,14 +390,16 @@ char* ChfBuildMessage( /* Build a condition message */
|
|||
tmp_p = scopy( tmp_p, separator, tmp_end );
|
||||
|
||||
/* Add the severity code of the message */
|
||||
tmp_p = scopy( tmp_p, ( ( severity = descriptor->severity ) < CHF_SUCCESS || severity > CHF_FATAL ) ? "?" : severity_name[ severity ],
|
||||
tmp_p = scopy( tmp_p,
|
||||
( ( severity = descriptor->severity ) < CHF_SUCCESS || severity > CHF_FATAL ) ? CHF_UNKNOWN_SEVERITY
|
||||
: severity_name[ severity ],
|
||||
tmp_end );
|
||||
|
||||
tmp_p = scopy( tmp_p, separator, tmp_end );
|
||||
|
||||
/* The message ends with the partial message from the descriptor */
|
||||
tmp_p = scopy( tmp_p, descriptor->message, tmp_end );
|
||||
( void )scopy( tmp_p, "\n", tmp_end );
|
||||
( void )scopy( tmp_p, CHF_MESSAGE_TERMINATOR, tmp_end );
|
||||
|
||||
return chf_context.message_buffer;
|
||||
}
|
||||
|
|
|
@ -26,7 +26,7 @@ struct tdata_s {
|
|||
int phase;
|
||||
};
|
||||
|
||||
ChfAction h1( const ChfDescriptor* c, const ChfState s, void* p )
|
||||
ChfAction h1( const ChfDescriptor* c, const ChfState s, ChfPointer p )
|
||||
{
|
||||
struct tdata_s* tdata_p = ( struct tdata_s* )p;
|
||||
ChfAction action;
|
||||
|
@ -42,7 +42,7 @@ ChfAction h1( const ChfDescriptor* c, const ChfState s, void* p )
|
|||
return action;
|
||||
}
|
||||
|
||||
ChfAction h2( const ChfDescriptor* c, const ChfState s, void* p )
|
||||
ChfAction h2( const ChfDescriptor* c, const ChfState s, ChfPointer p )
|
||||
{
|
||||
struct tdata_s* tdata_p = ( struct tdata_s* )p;
|
||||
ChfAction action;
|
||||
|
@ -76,7 +76,7 @@ ChfAction h2( const ChfDescriptor* c, const ChfState s, void* p )
|
|||
return action;
|
||||
}
|
||||
|
||||
ChfAction h3( const ChfDescriptor* c, const ChfState s, void* p )
|
||||
ChfAction h3( const ChfDescriptor* c, const ChfState s, ChfPointer p )
|
||||
{
|
||||
struct tdata_s* tdata_p = ( struct tdata_s* )p;
|
||||
ChfAction action;
|
||||
|
@ -106,7 +106,7 @@ ChfAction h3( const ChfDescriptor* c, const ChfState s, void* p )
|
|||
return action;
|
||||
}
|
||||
|
||||
ChfAction h4( const ChfDescriptor* c, const ChfState s, void* p )
|
||||
ChfAction h4( const ChfDescriptor* c, const ChfState s, ChfPointer p )
|
||||
{
|
||||
struct tdata_s* tdata_p = ( struct tdata_s* )p;
|
||||
ChfAction action;
|
||||
|
@ -159,7 +159,7 @@ void* task( void* arg )
|
|||
printf( "\tThread %d\n", ( int )arg );
|
||||
|
||||
/* Push the handler */
|
||||
ChfPushHandler( h1, NULL, ( void* )( &tdata ) );
|
||||
ChfPushHandler( h1, NULL, ( ChfPointer )( &tdata ) );
|
||||
|
||||
/* Generate a condition group and signal it */
|
||||
CHF_Condition 6, CHF_INFO, ( int )arg ChfEnd;
|
||||
|
@ -190,7 +190,7 @@ void* task( void* arg )
|
|||
|
||||
tdata.phase = 0;
|
||||
if ( setjmp( jb ) == 0 ) {
|
||||
ChfPushHandler( h2, jb, ( void* )( &tdata ) );
|
||||
ChfPushHandler( h2, jb, ( ChfPointer )( &tdata ) );
|
||||
|
||||
/* Generate a condition group and signal it */
|
||||
tdata.phase = 1;
|
||||
|
@ -230,8 +230,8 @@ void* task( void* arg )
|
|||
{
|
||||
tdata.phase = 0;
|
||||
|
||||
ChfPushHandler( h3, NULL, ( void* )&tdata );
|
||||
ChfPushHandler( h4, NULL, ( void* )&tdata );
|
||||
ChfPushHandler( h3, NULL, ( ChfPointer )&tdata );
|
||||
ChfPushHandler( h4, NULL, ( ChfPointer )&tdata );
|
||||
|
||||
tdata.phase = 1;
|
||||
CHF_Condition 6, CHF_INFO, ( int )arg ChfEnd;
|
||||
|
|
|
@ -27,14 +27,14 @@
|
|||
/* Dummy handler; pushed only to verify that the handler stack overflow
|
||||
checks are correct.
|
||||
*/
|
||||
ChfAction h1( const ChfDescriptor* c, const ChfState s, void* p ) { return CHF_RESIGNAL; }
|
||||
ChfAction h1( const ChfDescriptor* c, const ChfState s, ChfPointer p ) { return CHF_RESIGNAL; }
|
||||
|
||||
/* Overflow check handler; it unwinds if the CHF_F_HDLR_STACK_FULL
|
||||
condition is signalled exactly after H_STACK_SIZE-2 invocations
|
||||
of ChfPushHandler(), it resignals a modified condition if the
|
||||
condition is signalled too early
|
||||
*/
|
||||
ChfAction h2( const ChfDescriptor* c, const ChfState s, void* p )
|
||||
ChfAction h2( const ChfDescriptor* c, const ChfState s, ChfPointer p )
|
||||
{
|
||||
int push_count = *( ( int* )p );
|
||||
ChfAction action;
|
||||
|
@ -62,7 +62,7 @@ ChfAction h2( const ChfDescriptor* c, const ChfState s, void* p )
|
|||
of CHF_Condition, it resignals a modified condition if the
|
||||
condition is signalled too early
|
||||
*/
|
||||
ChfAction h3( const ChfDescriptor* c, const ChfState s, void* p )
|
||||
ChfAction h3( const ChfDescriptor* c, const ChfState s, ChfPointer p )
|
||||
{
|
||||
int push_count = *( ( int* )p );
|
||||
ChfAction action;
|
||||
|
@ -100,7 +100,7 @@ void* task( void* arg )
|
|||
int i;
|
||||
|
||||
/* Push the handler */
|
||||
ChfPushHandler( h2, jb, ( void* )( &push_count ) );
|
||||
ChfPushHandler( h2, jb, ( ChfPointer )( &push_count ) );
|
||||
|
||||
/* The sleep() is here to increase contention between threads */
|
||||
sleep( 1 );
|
||||
|
@ -122,7 +122,7 @@ void* task( void* arg )
|
|||
int i;
|
||||
|
||||
/* Push the handler */
|
||||
ChfPushHandler( h3, jb, ( void* )( &push_count ) );
|
||||
ChfPushHandler( h3, jb, ( ChfPointer )( &push_count ) );
|
||||
|
||||
/* The sleep() is here to increase contention between threads */
|
||||
sleep( 1 );
|
||||
|
@ -145,7 +145,7 @@ void* task( void* arg )
|
|||
int i;
|
||||
|
||||
/* Push the handler */
|
||||
ChfPushHandler( h3, jb, ( void* )( &push_count ) );
|
||||
ChfPushHandler( h3, jb, ( ChfPointer )( &push_count ) );
|
||||
|
||||
/* The sleep() is here to increase contention between threads */
|
||||
sleep( 1 );
|
||||
|
|
Loading…
Add table
Reference in a new issue