source: rtems/cpukit/rtems/src/msgqflush.c @ cc18d7b

4.115
Last change on this file since cc18d7b was cc18d7b, checked in by Sebastian Huber <sebastian.huber@…>, on 04/30/15 at 11:12:54

score: Fine grained locking for message queues

Aggregate several critical sections into a bigger one. Sending and
receiving messages is now protected by an ISR lock. Thread dispatching
is only disabled in case a blocking operation is necessary. The message
copy procedure is done inside the critical section (interrupts
disabled). Thus this change may have a negative impact on the interrupt
latency in case very large messages are transferred.

Update #2273.

  • Property mode set to 100644
File size: 2.3 KB
Line 
1/**
2 * @file
3 *
4 * @brief rtems_message_queue_flush
5 * @ingroup ClassicMessageQueue Message Queues
6 */
7
8/*
9 *  COPYRIGHT (c) 1989-2014.
10 *  On-Line Applications Research Corporation (OAR).
11 *
12 *  The license and distribution terms for this file may be
13 *  found in the file LICENSE in this distribution or at
14 *  http://www.rtems.org/license/LICENSE.
15 */
16
17#if HAVE_CONFIG_H
18#include "config.h"
19#endif
20
21#include <rtems/system.h>
22#include <rtems/score/chain.h>
23#include <rtems/score/isr.h>
24#include <rtems/score/coremsgimpl.h>
25#include <rtems/score/thread.h>
26#include <rtems/score/wkspace.h>
27#include <rtems/rtems/status.h>
28#include <rtems/rtems/attrimpl.h>
29#include <rtems/rtems/messageimpl.h>
30#include <rtems/rtems/options.h>
31#include <rtems/rtems/support.h>
32
33/*
34 *  rtems_message_queue_flush
35 *
36 *  This directive removes all pending messages from a queue and returns
37 *  the number of messages removed.  If no messages were present then
38 *  a count of zero is returned.
39 *
40 *  Input parameters:
41 *    id    - queue id
42 *    count - return area for count
43 *
44 *  Output parameters:
45 *    count             - number of messages removed ( 0 = empty queue )
46 *    RTEMS_SUCCESSFUL - if successful
47 *    error code        - if unsuccessful
48 */
49
50rtems_status_code rtems_message_queue_flush(
51  rtems_id  id,
52  uint32_t *count
53)
54{
55  Message_queue_Control          *the_message_queue;
56  Objects_Locations               location;
57  ISR_lock_Context                lock_context;
58
59  if ( !count )
60    return RTEMS_INVALID_ADDRESS;
61
62  the_message_queue = _Message_queue_Get_interrupt_disable(
63    id,
64    &location,
65    &lock_context
66  );
67  switch ( location ) {
68
69    case OBJECTS_LOCAL:
70      *count = _CORE_message_queue_Flush(
71        &the_message_queue->message_queue,
72        &lock_context
73      );
74      return RTEMS_SUCCESSFUL;
75
76#if defined(RTEMS_MULTIPROCESSING)
77    case OBJECTS_REMOTE:
78      _Thread_Executing->Wait.return_argument = count;
79
80      return
81        _Message_queue_MP_Send_request_packet(
82          MESSAGE_QUEUE_MP_FLUSH_REQUEST,
83          id,
84          0,                               /* buffer not used */
85          0,                               /* size */
86          0,                               /* option_set not used */
87          MPCI_DEFAULT_TIMEOUT
88        );
89#endif
90
91    case OBJECTS_ERROR:
92      break;
93  }
94
95  return RTEMS_INVALID_ID;
96}
Note: See TracBrowser for help on using the repository browser.