/** * @file * * @brief Constants and Structures Associated * with the CBS library in RTEMS * * This include file contains all the constants and structures associated * with the CBS library in RTEMS. */ /* * Copyright (C) 2011 Petr Benes. * 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 CONFIGURE_SCHEDULER_CBS #error "cbs.h available only with CONFIGURE_SCHEDULER_CBS" #endif #ifndef _RTEMS_CBS_H #define _RTEMS_CBS_H #include #ifdef __cplusplus extern "C" { #endif /* Return codes. */ #define RTEMS_CBS_OK SCHEDULER_CBS_OK #define RTEMS_CBS_ERROR_GENERIC SCHEDULER_CBS_ERROR_GENERIC #define RTEMS_CBS_ERROR_NO_MEMORY SCHEDULER_CBS_ERROR_NO_MEMORY #define RTEMS_CBS_ERROR_INVALID_PARAMETER SCHEDULER_CBS_ERROR_INVALID_PARAM #define RTEMS_CBS_ERROR_UNAUTHORIZED SCHEDULER_CBS_ERROR_UNAUTHORIZED #define RTEMS_CBS_ERROR_UNIMPLEMENTED SCHEDULER_CBS_ERROR_UNIMPLEMENTED #define RTEMS_CBS_ERROR_MISSING_COMPONENT SCHEDULER_CBS_ERROR_MISSING_COMPONENT #define RTEMS_CBS_ERROR_INCONSISTENT_STATE SCHEDULER_CBS_ERROR_INCONSISTENT_STATE #define RTEMS_CBS_ERROR_SYSTEM_OVERLOAD SCHEDULER_CBS_ERROR_SYSTEM_OVERLOAD #define RTEMS_CBS_ERROR_INTERNAL_ERROR SCHEDULER_CBS_ERROR_INTERNAL_ERROR #define RTEMS_CBS_ERROR_NOT_FOUND SCHEDULER_CBS_ERROR_NOT_FOUND #define RTEMS_CBS_ERROR_FULL SCHEDULER_CBS_ERROR_FULL #define RTEMS_CBS_ERROR_EMPTY SCHEDULER_CBS_ERROR_EMPTY #define RTEMS_CBS_ERROR_NOSERVER SCHEDULER_CBS_ERROR_NOSERVER /** Callback function invoked when a budget overrun of a task occurs. */ typedef Scheduler_CBS_Budget_overrun rtems_cbs_budget_overrun; /** Server id. */ typedef Scheduler_CBS_Server_id rtems_cbs_server_id; /** Server parameters. */ typedef Scheduler_CBS_Parameters rtems_cbs_parameters; /** * @brief Initialize the CBS library. * * Initializes the CBS library. * * @return status code. */ RTEMS_INLINE_ROUTINE int rtems_cbs_initialize ( void ) { return _Scheduler_CBS_Initialize(); } /** * @brief Cleanup resources associated to the CBS Library * * Cleanup resources associated to the CBS Library. * * @return status code. */ RTEMS_INLINE_ROUTINE int rtems_cbs_cleanup ( void ) { return _Scheduler_CBS_Cleanup(); } /** * @brief Create a new server with specified parameters. * * Create a new server with specified parameters. * * @return status code. */ RTEMS_INLINE_ROUTINE int rtems_cbs_create_server ( rtems_cbs_parameters *params, rtems_cbs_budget_overrun budget_overrun_callback, rtems_cbs_server_id *server_id ) { return _Scheduler_CBS_Create_server( params, budget_overrun_callback, server_id ); } /** * @brief Attach a task to an already existing server. * * Attach a task to an already existing server. * * @return status code. */ RTEMS_INLINE_ROUTINE int rtems_cbs_attach_thread ( rtems_cbs_server_id server_id, rtems_id task_id ) { return _Scheduler_CBS_Attach_thread( server_id, task_id ); } /** * @brief Detach from the CBS server. * * Detach from the CBS Server. * * @return status code. */ RTEMS_INLINE_ROUTINE int rtems_cbs_detach_thread ( rtems_cbs_server_id server_id, rtems_id task_id ) { return _Scheduler_CBS_Detach_thread( server_id, task_id ); } /** * @brief Detach all tasks from a server and destroy it. * * Detach all tasks from a server and destroy it. * * @return status code. */ RTEMS_INLINE_ROUTINE int rtems_cbs_destroy_server ( rtems_cbs_server_id server_id ) { return _Scheduler_CBS_Destroy_server( server_id ); } /** * @brief Get CBS server id. * * Get a thread server id, or RTEMS_CBS_E_NOT_FOUND if it is not * attached to any server. * * @return status code. */ RTEMS_INLINE_ROUTINE int rtems_cbs_get_server_id ( rtems_id task_id, rtems_cbs_server_id *server_id ) { return _Scheduler_CBS_Get_server_id( task_id, server_id ); } /** * @brief Get CBS parameters. * * Retrieve CBS scheduling parameters. * * @return status code. */ RTEMS_INLINE_ROUTINE int rtems_cbs_get_parameters ( rtems_cbs_server_id server_id, rtems_cbs_parameters *params ) { return _Scheduler_CBS_Get_parameters( server_id, params ); } /** * @brief Set CBS parameters. * * Change CBS scheduling parameters. * * @return status code. */ RTEMS_INLINE_ROUTINE int rtems_cbs_set_parameters ( rtems_cbs_server_id server_id, rtems_cbs_parameters *params ) { return _Scheduler_CBS_Set_parameters( server_id, params ); } /** * @brief Get the CBS get execution time. * * Retrieve time info relative to the current server. * * @return status code. */ RTEMS_INLINE_ROUTINE int rtems_cbs_get_execution_time ( rtems_cbs_server_id server_id, time_t *exec_time, time_t *abs_time ) { return _Scheduler_CBS_Get_execution_time( server_id, exec_time, abs_time ); } /** * @brief Get the remaining CBS budget. * * Retrieve remaining budget for the current server instance. * * @return status code. */ RTEMS_INLINE_ROUTINE int rtems_cbs_get_remaining_budget ( rtems_cbs_server_id server_id, time_t *remaining_budget ) { return _Scheduler_CBS_Get_remaining_budget( server_id, remaining_budget ); } /** * @brief Get the approved CBS budget. * * Retrieve the budget that has been approved for the subsequent * server instances. * * @return status code. */ RTEMS_INLINE_ROUTINE int rtems_cbs_get_approved_budget ( rtems_cbs_server_id server_id, time_t *appr_budget ) { return _Scheduler_CBS_Get_approved_budget( server_id, appr_budget ); } #ifdef __cplusplus } #endif #endif /* end of include file */