From 641b44c225c71af51285f9a1b408a4f4c2844f8b Mon Sep 17 00:00:00 2001 From: Sebastian Huber Date: Fri, 20 May 2016 14:21:12 +0200 Subject: rtems: _Message_queue_Get_interrupt_disable() Use _Objects_Get_local() for _Message_queue_Get_interrupt_disable() to get rid of the location parameter. Move remote object handling to message queue MPCI support. --- cpukit/rtems/src/msgqbroadcast.c | 69 +++++++++++++--------------------------- 1 file changed, 22 insertions(+), 47 deletions(-) (limited to 'cpukit/rtems/src/msgqbroadcast.c') diff --git a/cpukit/rtems/src/msgqbroadcast.c b/cpukit/rtems/src/msgqbroadcast.c index 7bd7e3b810..5aab1b1117 100644 --- a/cpukit/rtems/src/msgqbroadcast.c +++ b/cpukit/rtems/src/msgqbroadcast.c @@ -18,17 +18,7 @@ #include "config.h" #endif -#include -#include -#include -#include -#include -#include -#include -#include #include -#include -#include rtems_status_code rtems_message_queue_broadcast( rtems_id id, @@ -37,54 +27,39 @@ rtems_status_code rtems_message_queue_broadcast( uint32_t *count ) { - Message_queue_Control *the_message_queue; - Objects_Locations location; - CORE_message_queue_Status core_status; - ISR_lock_Context lock_context; + Message_queue_Control *the_message_queue; + ISR_lock_Context lock_context; + CORE_message_queue_Status status; - if ( !buffer ) + if ( buffer == NULL ) { return RTEMS_INVALID_ADDRESS; + } - if ( !count ) + if ( count == NULL ) { return RTEMS_INVALID_ADDRESS; + } the_message_queue = _Message_queue_Get_interrupt_disable( id, - &location, &lock_context ); - switch ( location ) { - - case OBJECTS_LOCAL: - core_status = _CORE_message_queue_Broadcast( - &the_message_queue->message_queue, - buffer, - size, - _Message_queue_Core_message_queue_mp_support, - id, - count, - &lock_context - ); - return - _Message_queue_Translate_core_message_queue_return_code( core_status ); + if ( the_message_queue == NULL ) { #if defined(RTEMS_MULTIPROCESSING) - case OBJECTS_REMOTE: - _Thread_Executing->Wait.return_argument = count; - - return - _Message_queue_MP_Send_request_packet( - MESSAGE_QUEUE_MP_BROADCAST_REQUEST, - id, - buffer, - &size, - 0, /* option_set not used */ - MPCI_DEFAULT_TIMEOUT - ); + _Message_queue_MP_Broadcast( id, buffer, size, count ); +#else + return RTEMS_INVALID_ID; #endif - - case OBJECTS_ERROR: - break; } - return RTEMS_INVALID_ID; + + status = _CORE_message_queue_Broadcast( + &the_message_queue->message_queue, + buffer, + size, + _Message_queue_Core_message_queue_mp_support, + id, + count, + &lock_context + ); + return _Message_queue_Translate_core_message_queue_return_code( status ); } -- cgit v1.2.3