rtems_task Semaphore_task( rtems_task_argument argument ) { uint32_t count; rtems_status_code status; uint32_t yield_count; puts( "Getting SMID of semaphore" ); while ( FOREVER ) { status = rtems_semaphore_ident( Semaphore_name[ 1 ], RTEMS_SEARCH_ALL_NODES, &Semaphore_id[ 1 ] ); if ( status == RTEMS_SUCCESSFUL ) break; puts( "rtems_semaphore_ident FAILED!!" ); rtems_task_wake_after(2); } yield_count = 100; while ( Stop_Test == false ) { for ( count=SEMAPHORE_DOT_COUNT ; Stop_Test == false && count ; count-- ) { status = rtems_semaphore_obtain( Semaphore_id[ 1 ], RTEMS_DEFAULT_OPTIONS, RTEMS_NO_TIMEOUT ); directive_failed( status, "rtems_semaphore_obtain" ); status = rtems_semaphore_release( Semaphore_id[ 1 ] ); directive_failed( status, "rtems_semaphore_release" ); if ( Stop_Test == false ) if ( Multiprocessing_configuration.node == 1 && --yield_count == 0 ) { status = rtems_task_wake_after( RTEMS_YIELD_PROCESSOR ); directive_failed( status, "rtems_task_wake_after" ); yield_count = 100; } } put_dot( 's' ); } Exit_test(); }
rtems_task Partition_task( rtems_task_argument argument ) { uint32_t count; rtems_status_code status; uint32_t yield_count; void *buffer; puts( "Getting ID of partition" ); while ( FOREVER ) { status = rtems_partition_ident( Partition_name[ 1 ], RTEMS_SEARCH_ALL_NODES, &Partition_id[ 1 ] ); if ( status == RTEMS_SUCCESSFUL ) break; puts( "rtems_partition_ident FAILED!!" ); rtems_task_wake_after(2); } yield_count = 100; while ( Stop_Test == false ) { for ( count=PARTITION_DOT_COUNT ; Stop_Test == false && count ; count-- ) { status = rtems_partition_get_buffer( Partition_id[ 1 ], &buffer ); directive_failed( status, "rtems_partition_get_buffer" ); status = rtems_partition_return_buffer( Partition_id[ 1 ], buffer ); directive_failed( status, "rtems_partition_return_buffer" ); if (Stop_Test == false) if ( Multiprocessing_configuration.node == 1 && --yield_count == 0 ) { status = rtems_task_wake_after( 1 ); directive_failed( status, "rtems_task_wake_after" ); yield_count = 100; } } put_dot( 'p' ); } Exit_test(); }
rtems_task Delayed_events_task( rtems_task_argument argument ) { uint32_t count; uint32_t previous_mode; rtems_status_code status; rtems_event_set events; status = rtems_task_mode( RTEMS_PREEMPT | RTEMS_TIMESLICE, RTEMS_PREEMPT_MASK | RTEMS_TIMESLICE_MASK, &previous_mode ); directive_failed( status, "rtems_task_mode" ); status = rtems_timer_create( Timer_name[ 1 ], &Timer_id[ 1 ] ); directive_failed( status, "rtems_timer_create" ); while ( Stop_Test == FALSE ) { for ( count=DELAYED_EVENT_DOT_COUNT; Stop_Test == FALSE && count; count-- ){ status = rtems_timer_fire_after( Timer_id[ 1 ], 1, Delayed_send_event, NULL ); directive_failed( status, "rtems_timer_reset" ); status = rtems_event_receive( RTEMS_EVENT_16, RTEMS_DEFAULT_OPTIONS, RTEMS_NO_TIMEOUT, &events ); directive_failed( status, "rtems_event_receive" ); } put_dot('.'); } Exit_test(); }
rtems_task Test_task( rtems_task_argument argument ) { rtems_status_code status; uint32_t count; uint32_t remote_node; rtems_id remote_tid; rtems_event_set event_out; remote_node = ((Multiprocessing_configuration.node == 1) ? 2 : 1); puts( "About to go to sleep!" ); status = rtems_task_wake_after( rtems_clock_get_ticks_per_second() ); directive_failed( status, "rtems_task_wake_after" ); puts( "Waking up!" ); puts_nocr( "Remote task's name is : " ); put_name( Task_name[ remote_node ], TRUE ); puts( "Getting TID of remote task" ); while ( FOREVER ) { status = rtems_task_ident( Task_name[ remote_node ], RTEMS_SEARCH_ALL_NODES, &remote_tid ); if ( status == RTEMS_SUCCESSFUL ) break; puts( "rtems_task_ident FAILED!!" ); rtems_task_wake_after(2); } if ( Multiprocessing_configuration.node == 1 ) { puts( "Sending events to remote task" ); while ( Stop_Test == false ) { for ( count=EVENT_TASK_DOT_COUNT; Stop_Test == false && count; count-- ) { status = rtems_event_send( remote_tid, RTEMS_EVENT_16 ); directive_failed( status, "rtems_event_send" ); } put_dot( 'e' ); } } puts( "Receiving events from remote task" ); while ( Stop_Test == false ) { for ( count=EVENT_TASK_DOT_COUNT ; Stop_Test == false && count ; count-- ) { status = rtems_event_receive( RTEMS_EVENT_16, RTEMS_DEFAULT_OPTIONS, RTEMS_NO_TIMEOUT, &event_out ); directive_failed( status, "rtems_event_receive" ); } put_dot( 'e' ); } Exit_test(); }
rtems_task Message_queue_task( rtems_task_argument index ) { rtems_status_code status; uint32_t count; uint32_t yield_count; uint32_t *buffer_count; uint32_t *overflow_count; size_t size; Msg_buffer[ index ][0] = 0; Msg_buffer[ index ][1] = 0; Msg_buffer[ index ][2] = 0; Msg_buffer[ index ][3] = 0; puts( "Getting ID of msg queue" ); while ( FOREVER ) { status = rtems_message_queue_ident( Queue_name[ 1 ], RTEMS_SEARCH_ALL_NODES, &Queue_id[ 1 ] ); if ( status == RTEMS_SUCCESSFUL ) break; puts( "rtems_message_queue_ident FAILED!!" ); rtems_task_wake_after(2); } if ( Multiprocessing_configuration.node == 1 ) { status = rtems_message_queue_send( Queue_id[ 1 ], (long (*)[4])Msg_buffer[ index ], 16 ); directive_failed( status, "rtems_message_queue_send" ); overflow_count = &Msg_buffer[ index ][0]; buffer_count = &Msg_buffer[ index ][1]; } else { overflow_count = &Msg_buffer[ index ][2]; buffer_count = &Msg_buffer[ index ][3]; } while ( Stop_Test == false ) { yield_count = 100; for ( count=MESSAGE_DOT_COUNT ; Stop_Test == false && count ; count-- ) { status = rtems_message_queue_receive( Queue_id[ 1 ], Msg_buffer[ index ], &size, RTEMS_DEFAULT_OPTIONS, RTEMS_NO_TIMEOUT ); directive_failed( status, "rtems_message_queue_receive" ); if ( *buffer_count == (uint32_t)0xffffffff ) { *buffer_count = 0; *overflow_count += 1; } else *buffer_count += 1; status = rtems_message_queue_send( Queue_id[ 1 ], Msg_buffer[ index ], 16 ); directive_failed( status, "rtems_message_queue_send" ); if (Stop_Test == false) if ( Multiprocessing_configuration.node == 1 && --yield_count == 0 ) { status = rtems_task_wake_after( RTEMS_YIELD_PROCESSOR ); directive_failed( status, "rtems_task_wake_after" ); yield_count = 100; } } put_dot( 'm' ); } Exit_test(); }