📄 coremsg.inl
字号:
/** * @file rtems/score/coremsg.inl * * This include file contains the static inline implementation of all * inlined routines in the Core Message Handler. *//* * COPYRIGHT (c) 1989-2004. * 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: coremsg.inl,v 1.19 2005/09/01 16:32:06 joel Exp $ */#ifndef _RTEMS_SCORE_COREMSG_INL#define _RTEMS_SCORE_COREMSG_INL/** * @addtogroup ScoreMessageQueue * @{ */#include <string.h> /* needed for memcpy */ /** * This routine sends a message to the end of the specified message queue. */ RTEMS_INLINE_ROUTINE CORE_message_queue_Status _CORE_message_queue_Send( CORE_message_queue_Control *the_message_queue, void *buffer, uint32_t size, Objects_Id id, CORE_message_queue_API_mp_support_callout api_message_queue_mp_support, boolean wait, Watchdog_Interval timeout){ return _CORE_message_queue_Submit( the_message_queue, buffer, size, id,#if defined(RTEMS_MULTIPROCESSING) api_message_queue_mp_support,#else NULL,#endif CORE_MESSAGE_QUEUE_SEND_REQUEST, wait, /* sender may block */ timeout /* timeout interval */ );} /** * This routine sends a message to the front of the specified message queue. */ RTEMS_INLINE_ROUTINE CORE_message_queue_Status _CORE_message_queue_Urgent( CORE_message_queue_Control *the_message_queue, void *buffer, uint32_t size, Objects_Id id, CORE_message_queue_API_mp_support_callout api_message_queue_mp_support, boolean wait, Watchdog_Interval timeout){ return _CORE_message_queue_Submit( the_message_queue, buffer, size, id,#if defined(RTEMS_MULTIPROCESSING) api_message_queue_mp_support,#else NULL,#endif CORE_MESSAGE_QUEUE_URGENT_REQUEST, wait, /* sender may block */ timeout /* timeout interval */ );}/** * This routine copies the contents of the source message buffer * to the destination message buffer. */RTEMS_INLINE_ROUTINE void _CORE_message_queue_Copy_buffer ( void *source, void *destination, uint32_t size){ memcpy(destination, source, size);}/** * This function allocates a message buffer from the inactive * message buffer chain. */RTEMS_INLINE_ROUTINE CORE_message_queue_Buffer_control *_CORE_message_queue_Allocate_message_buffer ( CORE_message_queue_Control *the_message_queue){ return (CORE_message_queue_Buffer_control *) _Chain_Get( &the_message_queue->Inactive_messages );}/** * This routine frees a message buffer to the inactive * message buffer chain. */RTEMS_INLINE_ROUTINE void _CORE_message_queue_Free_message_buffer ( CORE_message_queue_Control *the_message_queue, CORE_message_queue_Buffer_control *the_message){ _Chain_Append( &the_message_queue->Inactive_messages, &the_message->Node );}/** * This function removes the first message from the_message_queue * and returns a pointer to it. */RTEMS_INLINE_ROUTINE CORE_message_queue_Buffer_control *_CORE_message_queue_Get_pending_message ( CORE_message_queue_Control *the_message_queue){ return (CORE_message_queue_Buffer_control *) _Chain_Get_unprotected( &the_message_queue->Pending_messages );}/** * This function returns TRUE if the priority attribute is * enabled in the attribute_set and FALSE otherwise. */ RTEMS_INLINE_ROUTINE boolean _CORE_message_queue_Is_priority( CORE_message_queue_Attributes *the_attribute){ return (the_attribute->discipline == CORE_MESSAGE_QUEUE_DISCIPLINES_PRIORITY);}/** * This routine places the_message at the rear of the outstanding * messages on the_message_queue. */RTEMS_INLINE_ROUTINE void _CORE_message_queue_Append_unprotected ( CORE_message_queue_Control *the_message_queue, CORE_message_queue_Buffer_control *the_message){ _Chain_Append_unprotected( &the_message_queue->Pending_messages, &the_message->Node );}/** * This routine places the_message at the front of the outstanding * messages on the_message_queue. */RTEMS_INLINE_ROUTINE void _CORE_message_queue_Prepend_unprotected ( CORE_message_queue_Control *the_message_queue, CORE_message_queue_Buffer_control *the_message){ _Chain_Prepend_unprotected( &the_message_queue->Pending_messages, &the_message->Node );}/** * This function returns TRUE if the_message_queue is TRUE and FALSE otherwise. */RTEMS_INLINE_ROUTINE boolean _CORE_message_queue_Is_null ( CORE_message_queue_Control *the_message_queue){ return ( the_message_queue == NULL );}/** * This function returns TRUE if notification is enabled on this message * queue and FALSE otherwise. */ RTEMS_INLINE_ROUTINE boolean _CORE_message_queue_Is_notify_enabled ( CORE_message_queue_Control *the_message_queue){ return (the_message_queue->notify_handler != NULL);} /** * This routine initializes the notification information for the_message_queue. */ RTEMS_INLINE_ROUTINE void _CORE_message_queue_Set_notify ( CORE_message_queue_Control *the_message_queue, CORE_message_queue_Notify_Handler the_handler, void *the_argument){ the_message_queue->notify_handler = the_handler; the_message_queue->notify_argument = the_argument;}/**@}*/#endif/* end of include file */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -