source: rtems/cpukit/rtems/src/msgqurgent.c @ a2e3f33

4.115
Last change on this file since a2e3f33 was a2e3f33, checked in by Sebastian Huber <sebastian.huber@…>, on 07/24/13 at 11:50:54

score: Create object implementation header

Move implementation specific parts of object.h and object.inl into new
header file objectimpl.h. The object.h contains now only the
application visible API.

  • Property mode set to 100644
File size: 2.2 KB
Line 
1/**
2 *  @file
3 *
4 *  @brief RTEMS Urgent Message Queue
5 *  @ingroup ClassicMessageQueue
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/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#if defined(RTEMS_MULTIPROCESSING)
34#define MESSAGE_QUEUE_MP_HANDLER _Message_queue_Core_message_queue_mp_support
35#else
36#define MESSAGE_QUEUE_MP_HANDLER NULL
37#endif
38
39rtems_status_code rtems_message_queue_urgent(
40  rtems_id    id,
41  const void *buffer,
42  size_t      size
43)
44{
45  register Message_queue_Control  *the_message_queue;
46  Objects_Locations                location;
47  CORE_message_queue_Status        status;
48
49  if ( !buffer )
50    return RTEMS_INVALID_ADDRESS;
51
52  the_message_queue = _Message_queue_Get( id, &location );
53  switch ( location ) {
54
55    case OBJECTS_LOCAL:
56      status = _CORE_message_queue_Urgent(
57        &the_message_queue->message_queue,
58        buffer,
59        size,
60        id,
61        MESSAGE_QUEUE_MP_HANDLER,
62        false,   /* sender does not block */
63        0        /* no timeout */
64      );
65      _Objects_Put( &the_message_queue->Object );
66
67      /*
68       *  Since this API does not allow for blocking sends, we can directly
69       *  return the returned status.
70       */
71
72      return _Message_queue_Translate_core_message_queue_return_code(status);
73
74#if defined(RTEMS_MULTIPROCESSING)
75    case OBJECTS_REMOTE:
76      return _Message_queue_MP_Send_request_packet(
77        MESSAGE_QUEUE_MP_URGENT_REQUEST,
78        id,
79        buffer,
80        &size,
81        0,                               /* option_set */
82        MPCI_DEFAULT_TIMEOUT
83      );
84#endif
85
86    case OBJECTS_ERROR:
87      break;
88  }
89
90  return RTEMS_INVALID_ID;
91}
Note: See TracBrowser for help on using the repository browser.