forked from Imagelibrary/rtems
* sptests/spintrcritical09/init.c, sptests/spintrcritical10/init.c, sptests/spintrcritical11/init.c: Fixed potentially infinite loops. * sp20/system.h: Increased micro seconds per tick in order to be more independent of the console output speed.
61 lines
1.5 KiB
C
61 lines
1.5 KiB
C
/*
|
|
* COPYRIGHT (c) 1989-2009.
|
|
* On-Line Applications Research Corporation (OAR).
|
|
*
|
|
* The license and distribution terms for this file may be
|
|
* found in the file LICENSE in this distribution or at
|
|
* http://www.rtems.com/license/LICENSE.
|
|
*
|
|
* $Id$
|
|
*/
|
|
|
|
#define __RTEMS_VIOLATE_KERNEL_VISIBILITY__ 1
|
|
#include <tmacros.h>
|
|
#include <intrcritical.h>
|
|
|
|
rtems_id Main_task;
|
|
|
|
rtems_task Init(
|
|
rtems_task_argument ignored
|
|
)
|
|
{
|
|
rtems_status_code sc;
|
|
rtems_event_set out;
|
|
int resets;
|
|
|
|
puts( "\n\n*** TEST INTERRUPT CRITICAL SECTION 10 ***" );
|
|
|
|
puts( "Init - Test may not be able to detect case is hit reliably" );
|
|
puts( "Init - Trying to generate timeout while blocking on event" );
|
|
|
|
Main_task = rtems_task_self();
|
|
|
|
interrupt_critical_section_test_support_initialize( NULL );
|
|
|
|
for (resets=0 ; resets< 2 ;) {
|
|
if ( interrupt_critical_section_test_support_delay() )
|
|
resets++;
|
|
|
|
sc = rtems_event_receive( 0x01, RTEMS_DEFAULT_OPTIONS, 1, &out );
|
|
fatal_directive_status( sc, RTEMS_TIMEOUT, "event_receive timeout" );
|
|
}
|
|
|
|
puts( "*** END OF TEST INTERRUPT CRITICAL SECTION 10 ***" );
|
|
rtems_test_exit(0);
|
|
}
|
|
|
|
/* configuration information */
|
|
|
|
#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
|
|
#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER
|
|
|
|
#define CONFIGURE_MAXIMUM_TASKS 1
|
|
#define CONFIGURE_MAXIMUM_TIMERS 1
|
|
#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
|
|
#define CONFIGURE_MICROSECONDS_PER_TICK 1000
|
|
|
|
#define CONFIGURE_INIT
|
|
#include <rtems/confdefs.h>
|
|
|
|
/* global variables */
|