summaryrefslogblamecommitdiffstats
path: root/cpukit/libcsupport/src/__times.c
blob: b92fd6362b725581c04018eba469cb5e546a05a8 (plain) (tree)
1
2
3
4
5
6
7
8
9

         
  




                            
                            
                                                    
  

                                                           
                                         

   



                   




                                                             





                      
                         
                                
                                          
                                    
      
                                   
 


                                           



                    
                       
                            
 

                                                   
 
    


                                                                        
                                             

    
                                                                



                                                                  

     
                                            
     
                                 
                                           
                                         

                     
                  



                                                         
        
 





                                            
                        
                                  
                  
                            

                         

                                                 

       

                                                
        
                           


                       
               
  
 
   

                                                   






                        
                         


                  


                                                              
                 
                                              


                    
                        
 
      
/**
 *  @file
 *
 *  @brief Get Process Times
 *  @ingroup libcsupport
 */

/*
 *  COPYRIGHT (c) 1989-2013.
 *  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.org/license/LICENSE.
 */

#if HAVE_CONFIG_H
#include "config.h"
#endif

/*
 *  Needed to get the prototype for this newlib helper method
 */
#define _COMPILING_NEWLIB

#include <rtems.h>

#include <sys/times.h>
#include <time.h>
#include <sys/time.h>
#include <errno.h>
#include <rtems/seterr.h>
#include <rtems/score/todimpl.h>
#ifndef __RTEMS_USE_TICKS_FOR_STATISTICS__
  #include <rtems/score/timestamp.h>
#endif
#include <rtems/score/threadimpl.h>

/**
 *  POSIX 1003.1b 4.5.2 - Get Process Times
 */
clock_t _times(
   struct tms  *ptms
)
{
  rtems_interval ticks;
  Thread_Control *executing;

  if ( !ptms )
    rtems_set_errno_and_return_minus_one( EFAULT );

  /*
   *  This call does not depend on TOD being initialized and can't fail.
   */

  ticks = rtems_clock_get_ticks_since_boot();

  /*
   *  RTEMS technically has no notion of system versus user time
   *  since there is no separation of OS from application tasks.
   *  But we can at least make a distinction between the number
   *  of ticks since boot and the number of ticks executed by this
   *  this thread.
   */

  #ifndef __RTEMS_USE_TICKS_FOR_STATISTICS__
    {
      Timestamp_Control per_tick;
      uint32_t          ticks_of_executing;
      uint32_t          fractional_ticks;

      _Timestamp_Set(
        &per_tick,
        rtems_configuration_get_microseconds_per_tick() /
            TOD_MICROSECONDS_PER_SECOND,
        (rtems_configuration_get_nanoseconds_per_tick() %
            TOD_NANOSECONDS_PER_SECOND)
      );

      _Thread_Disable_dispatch();
      executing = _Thread_Executing;
      _Thread_Update_cpu_time_used(
        executing,
        &_Thread_Time_of_last_context_switch
      );
      _Timestamp_Divide(
        &executing->cpu_time_used,
        &per_tick,
        &ticks_of_executing,
        &fractional_ticks
      );
      _Thread_Enable_dispatch();
      ptms->tms_utime = ticks_of_executing / 100;
    }
  #else
    executing = _Thread_Get_executing();
    ptms->tms_utime  = executing->cpu_time_used;
  #endif
  ptms->tms_stime  = ticks;
  ptms->tms_cutime = 0;
  ptms->tms_cstime = 0;

  return ticks;
} 

/**
 *  times() system call wrapper for _times() above.
 */
clock_t times(
   struct tms  *ptms
)
{
  return _times( ptms );
}

#if defined(RTEMS_NEWLIB)

#include <reent.h>

/**
 *  This is the Newlib dependent reentrant version of times().
 */
clock_t _times_r(
   struct _reent *ptr __attribute__((unused)),
   struct tms  *ptms
)
{
  return _times( ptms );
}
#endif