forked from Imagelibrary/rtems
* fileio/system.h, ticker/system.h, ticker/ticker.scn: Convert calls to legacy routine rtems_clock_get( RTEMS_CLOCK_GET_xxx, ..) to rtems_clock_get_xxx().
116 lines
2.8 KiB
C
116 lines
2.8 KiB
C
/* system.h
|
|
*
|
|
* This include file contains information that is included in every
|
|
* function in the test set.
|
|
*
|
|
* COPYRIGHT (c) 1989-2008.
|
|
* 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$
|
|
*/
|
|
|
|
#include <rtems.h>
|
|
#include <inttypes.h>
|
|
#include "../../support/include/buffer_test_io.h"
|
|
|
|
/* functions */
|
|
|
|
rtems_task Init(
|
|
rtems_task_argument argument
|
|
);
|
|
|
|
rtems_task Test_task(
|
|
rtems_task_argument argument
|
|
);
|
|
|
|
/* global variables */
|
|
|
|
/*
|
|
* Keep the names and IDs in global variables so another task can use them.
|
|
*/
|
|
|
|
extern rtems_id Task_id[ 4 ]; /* array of task ids */
|
|
extern rtems_name Task_name[ 4 ]; /* array of task names */
|
|
|
|
|
|
/* configuration information */
|
|
|
|
#include <bsp.h> /* for device driver prototypes */
|
|
|
|
#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER
|
|
#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
|
|
|
|
#define CONFIGURE_MAXIMUM_TASKS 4
|
|
|
|
#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
|
|
|
|
#define CONFIGURE_EXTRA_TASK_STACKS (3 * RTEMS_MINIMUM_STACK_SIZE)
|
|
|
|
#include <rtems/confdefs.h>
|
|
|
|
/*
|
|
* Handy macros and static inline functions
|
|
*/
|
|
|
|
/*
|
|
* Macro to hide the ugliness of printing the time.
|
|
*/
|
|
|
|
#define print_time(_s1, _tb, _s2) \
|
|
do { \
|
|
printf( "%s%02" PRId32 ":%02" PRId32 ":%02" PRId32 " %02" PRId32 "/%02" PRId32 "/%04" PRId32 "%s", \
|
|
_s1, (_tb)->hour, (_tb)->minute, (_tb)->second, \
|
|
(_tb)->month, (_tb)->day, (_tb)->year, _s2 ); \
|
|
} while ( 0 )
|
|
|
|
/*
|
|
* Macro to print an task name that is composed of ASCII characters.
|
|
*
|
|
*/
|
|
|
|
#define put_name( _name, _crlf ) \
|
|
do { \
|
|
uint32_t c0, c1, c2, c3; \
|
|
\
|
|
c0 = ((_name) >> 24) & 0xff; \
|
|
c1 = ((_name) >> 16) & 0xff; \
|
|
c2 = ((_name) >> 8) & 0xff; \
|
|
c3 = (_name) & 0xff; \
|
|
putchar( (char)c0 ); \
|
|
if ( c1 ) putchar( (char)c1 ); \
|
|
if ( c2 ) putchar( (char)c2 ); \
|
|
if ( c3 ) putchar( (char)c3 ); \
|
|
if ( (_crlf) ) \
|
|
putchar( '\n' ); \
|
|
} while (0)
|
|
|
|
/*
|
|
* static inline routine to make obtaining ticks per second easier.
|
|
*/
|
|
|
|
static inline uint32_t get_ticks_per_second( void )
|
|
{
|
|
return rtems_clock_get_ticks_per_second();
|
|
}
|
|
|
|
/*
|
|
* This allows us to view the "Test_task" instantiations as a set
|
|
* of numbered tasks by eliminating the number of application
|
|
* tasks created.
|
|
*
|
|
* In reality, this is too complex for the purposes of this
|
|
* example. It would have been easier to pass a task argument. :)
|
|
* But it shows how rtems_id's can sometimes be used.
|
|
*/
|
|
|
|
#define task_number( tid ) \
|
|
( rtems_object_id_get_index( tid ) - \
|
|
rtems_configuration_get_rtems_api_configuration()-> \
|
|
number_of_initialization_tasks )
|
|
|
|
/* end of include file */
|