source: rtems/cpukit/rtems/src/msgqflush.c @ 7f04cb18

4.115
Last change on this file since 7f04cb18 was 7f04cb18, checked in by Sebastian Huber <sebastian.huber@…>, on 07/25/13 at 07:10:38

score: Create mpci implementation header

Move implementation specific parts of mpci.h into new header file
mpciimpl.h. The mpci.h contains now only the application visible API.

  • 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-2007.
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.com/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/object.h>
26#include <rtems/score/thread.h>
27#include <rtems/score/wkspace.h>
28#include <rtems/rtems/status.h>
29#include <rtems/rtems/attrimpl.h>
30#include <rtems/rtems/messageimpl.h>
31#include <rtems/rtems/options.h>
32#include <rtems/rtems/support.h>
33
34/*
35 *  rtems_message_queue_flush
36 *
37 *  This directive removes all pending messages from a queue and returns
38 *  the number of messages removed.  If no messages were present then
39 *  a count of zero is returned.
40 *
41 *  Input parameters:
42 *    id    - queue id
43 *    count - return area for count
44 *
45 *  Output parameters:
46 *    count             - number of messages removed ( 0 = empty queue )
47 *    RTEMS_SUCCESSFUL - if successful
48 *    error code        - if unsuccessful
49 */
50
51rtems_status_code rtems_message_queue_flush(
52  rtems_id  id,
53  uint32_t *count
54)
55{
56  register Message_queue_Control *the_message_queue;
57  Objects_Locations               location;
58
59  if ( !count )
60    return RTEMS_INVALID_ADDRESS;
61
62  the_message_queue = _Message_queue_Get( id, &location );
63  switch ( location ) {
64
65    case OBJECTS_LOCAL:
66      *count = _CORE_message_queue_Flush( &the_message_queue->message_queue );
67      _Objects_Put( &the_message_queue->Object );
68      return RTEMS_SUCCESSFUL;
69
70#if defined(RTEMS_MULTIPROCESSING)
71    case OBJECTS_REMOTE:
72      _Thread_Executing->Wait.return_argument = count;
73
74      return
75        _Message_queue_MP_Send_request_packet(
76          MESSAGE_QUEUE_MP_FLUSH_REQUEST,
77          id,
78          0,                               /* buffer not used */
79          0,                               /* size */
80          0,                               /* option_set not used */
81          MPCI_DEFAULT_TIMEOUT
82        );
83#endif
84
85    case OBJECTS_ERROR:
86      break;
87  }
88
89  return RTEMS_INVALID_ID;
90}
Note: See TracBrowser for help on using the repository browser.