summaryrefslogblamecommitdiffstats
path: root/cpukit/include/rtems/score/schedulersimple.h
blob: 155027f3d314bf0752264aedbed2ee806440160d (plain) (tree)
1
2
3
4
5
6
7
8
   
        
  
                                     
  


                                                                            


   



                                                                       
                                         




                                      






                                          
   



                                                                
                                                                           
  
     
   
 

                                             




                                       




                                                                        
                                                                             

                                                                            
                                      

                                                                             
                                                                    
                                                                       
                                                                  
                                                                        
                                                  


   
                                   


                




                                    


                                                  
                           

   
                                       
  


                                                    
   
                                                                        

   




                                                                
  

                                                      
   
                                

                                     
  
 






                                                                            
                             
                                     

                                      
  
 






                                                       
                             
                                     

                                      

  






                                                       
                               
                                     

                                      

  






                                                  
                                       
                                     

                                      

  
         




                  
      
                         
/**
 * @file
 *
 * @ingroup RTEMSScoreSchedulerSimple
 *
 * @brief This header file provides interfaces of the
 *   @ref RTEMSScoreSchedulerSimple which are used by the implementation and
 *   the @ref RTEMSImplApplConfig.
 */

/*
 *  Copyright (C) 2011 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.
 */

#ifndef _RTEMS_SCORE_SCHEDULERSIMPLE_H
#define _RTEMS_SCORE_SCHEDULERSIMPLE_H

#include <rtems/score/scheduler.h>
#include <rtems/score/schedulerpriority.h>

#ifdef __cplusplus
extern "C" {
#endif

/**
 * @defgroup RTEMSScoreSchedulerSimple Simple Priority Scheduler
 *
 * @ingroup RTEMSScoreScheduler
 *
 * @brief This group contains the Simple Priority Scheduler implementation.
 *
 * @{
 */

#define SCHEDULER_SIMPLE_MAXIMUM_PRIORITY 255

/**
 *  Entry points for Scheduler Simple
 */
#define SCHEDULER_SIMPLE_ENTRY_POINTS \
  { \
    _Scheduler_simple_Initialize,         /* initialize entry point */ \
    _Scheduler_simple_Schedule,           /* schedule entry point */ \
    _Scheduler_simple_Yield,              /* yield entry point */ \
    _Scheduler_simple_Block,              /* block entry point */ \
    _Scheduler_simple_Unblock,            /* unblock entry point */ \
    _Scheduler_simple_Update_priority,    /* update priority entry point */ \
    _Scheduler_default_Map_priority,      /* map priority entry point */ \
    _Scheduler_default_Unmap_priority,    /* unmap priority entry point */ \
    SCHEDULER_DEFAULT_SMP_OPERATIONS \
    _Scheduler_default_Node_initialize,   /* node initialize entry point */ \
    _Scheduler_default_Node_destroy,      /* node destroy entry point */ \
    _Scheduler_default_Release_job,       /* new period of task */ \
    _Scheduler_default_Cancel_job,        /* cancel period of task */ \
    _Scheduler_default_Tick,              /* tick entry point */ \
    _Scheduler_default_Start_idle         /* start idle entry point */ \
    SCHEDULER_OPERATION_DEFAULT_GET_SET_AFFINITY \
  }

/**
 * @brief Simple scheduler context.
 */
typedef struct {
  /**
   * @brief Basic scheduler context.
   */
  Scheduler_Context Base;

  /**
   * @brief One ready queue for all ready threads.
   */
  Chain_Control Ready;
} Scheduler_simple_Context;

/**
 * @brief Initializes simple scheduler.
 *
 * This routine initializes the simple scheduler.
 *
 * @param scheduler The scheduler to be initialized.
 */
void _Scheduler_simple_Initialize( const Scheduler_Control *scheduler );

/**
 * @brief Schedules threads.
 *
 * This routine sets the heir thread to be the next ready thread
 * on the ready queue by getting the first node in the scheduler
 * information.
 *
 * @param scheduler The scheduler instance.
 * @param the_thread causing the scheduling operation.
 */
void _Scheduler_simple_Schedule(
  const Scheduler_Control *scheduler,
  Thread_Control          *the_thread
);

/**
 * @brief Performs the yield of a thread.
 *
 * @param scheduler The scheduler instance.
 * @param[in, out] the_thread The thread that performed the yield operation.
 * @param node The scheduler node of @a the_thread.
 */
void _Scheduler_simple_Yield(
  const Scheduler_Control *scheduler,
  Thread_Control          *the_thread,
  Scheduler_Node          *node
);

/**
 * @brief Blocks the thread.
 *
 * @param scheduler The scheduler instance.
 * @param[in, out] the_thread The thread to block.
 * @param[in, out] node The @a thread's scheduler node.
 */
void _Scheduler_simple_Block(
  const Scheduler_Control *scheduler,
  Thread_Control          *the_thread,
  Scheduler_Node          *node
);

/**
 * @brief Unblocks the thread.
 *
 * @param scheduler The scheduler instance.
 * @param[in, out] the_thread The thread to unblock.
 * @param[in, out] node The @a thread's scheduler node.
 */
void _Scheduler_simple_Unblock(
  const Scheduler_Control *scheduler,
  Thread_Control          *the_thread,
  Scheduler_Node          *node
);

/**
 * @brief Updates the priority of the node.
 *
 * @param scheduler The scheduler instance.
 * @param the_thread The thread for the operation.
 * @param node The thread's scheduler node.
 */
void _Scheduler_simple_Update_priority(
  const Scheduler_Control *scheduler,
  Thread_Control          *the_thread,
  Scheduler_Node          *node
);

/** @} */

#ifdef __cplusplus
}
#endif

#endif
/* end of include file */