OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [rtems/] [c/] [src/] [tests/] [tmitrontests/] [tmitronsem01/] [init.c] - Rev 619

Go to most recent revision | Compare with Previous | Blame | View Log

/*  Init
 *
 *  This routine is the initialization task for this test program.
 *  It is called from init_exec and has the responsibility for creating
 *  and starting the tasks that make up the test.  If the time of day
 *  clock is required for the test, it should also be set to a known
 *  value by this function.
 *
 *  Input parameters:  NONE
 *
 *  Output parameters:  NONE
 *
 *  COPYRIGHT (c) 1989-1999.
 *  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.OARcorp.com/rtems/license.html.
 *
 *  $Id: init.c,v 1.2 2001-09-27 12:02:39 chris Exp $
 */
 
#define TEST_INIT
#include "system.h"
#include <timesys.h>
#include <stdio.h>
 
void ITRON_Init( void )
{
  T_CSEM  pk_csem;
  T_RSEM  pk_rsem;
  int     index;
 
  pk_csem.isemcnt = 2;
  pk_csem.maxsem  = 3;
  pk_csem.sematr  = TA_TFIFO;
 
  printf( "\n\n*** TMITRON01 -- ITRON TIMING TEST ***\n" );
 
  /*
   *  time one invocation of cre_sem
   */
 
  Timer_initialize();
    (void) cre_sem( 1, &pk_csem );
  end_time = Read_timer();
  put_time(
    "cre_sem",
    end_time,
    1,
    0,  /* no loop overhead to take out */
    0   /* no calling overhead */
  );
 
  /*
   *  time one invocation of del_sem
   */
 
  Timer_initialize(); 
    (void) del_sem( 1 );
  end_time = Read_timer();
  put_time(
    "del_sem",
    end_time,
    1,
    0,  /* no loop overhead to take out */
    0   /* no calling overhead */
  );
 
  pk_csem.isemcnt = 100;
  pk_csem.maxsem  = 100;
  pk_csem.sematr  = TA_TFIFO;
  (void) cre_sem( 1, &pk_csem );
 
  /*
   *  time preq_sem (available)
   */
 
  Timer_initialize();
    for ( index = 1 ; index<=OPERATION_COUNT ; index++ )
      (void) preq_sem( 1 );
  end_time = Read_timer();
  put_time(
    "preq_sem (available)",
    end_time,
    OPERATION_COUNT,
    0,  /* don't take the loop overhead out */
    0   /* no calling overhead */
  );
 
  /*
   *  time preq_sem (not available)
   */
 
  Timer_initialize();
    for ( index = 1 ; index<=OPERATION_COUNT ; index++ )
      (void) preq_sem( 1 );
  end_time = Read_timer();
  put_time(
    "preq_sem (not available)",
    end_time,
    OPERATION_COUNT,
    0,  /* don't take the loop overhead out */
    0   /* no calling overhead */
  );
 
  /*
   *  time sig_sem (no waiting tasks)
   */
 
  Timer_initialize(); 
    for ( index = 1 ; index<=OPERATION_COUNT ; index++ )
      (void) sig_sem( 1 );
  end_time = Read_timer();
  put_time(
    "sig_sem (no waiting tasks)",
    end_time,
    OPERATION_COUNT,
    0,  /* don't take the loop overhead out */
    0   /* no calling overhead */
  );
 
  /*
   *  time ref_sem
   */
 
  Timer_initialize();
    for ( index = 1 ; index<=OPERATION_COUNT ; index++ )
      (void) ref_sem( 1, &pk_rsem );
  end_time = Read_timer();
  put_time(
    "ref_sem",
    end_time,
    OPERATION_COUNT,
    0,  /* don't take the loop overhead out */
    0   /* no calling overhead */
  );
 
  printf( "\n\nXXX ADD BLOCKING AND PREEMPTING TIME TESTS\n\n" );
 
 
  printf( "*** END OF TMITRON01 -- ITRON TIMING TEST ***\n" );
  exit( 0 );
}
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.