source: rtems/cpukit/rtems/src/msgqcreate.c @ 17bbadd

Last change on this file since 17bbadd was 17bbadd, checked in by Joel Sherrill <joel.sherrill@…>, on 05/06/04 at 19:20:04

2004-05-06 Joel Sherrill <joel@…>

PR 618/rtems

  • include/rtems/rtems/status.h, src/clockget.c, src/clockset.c, src/dpmemcreate.c, src/dpmemexternal2internal.c, src/dpmeminternal2external.c, src/eventmp.c, src/eventreceive.c, src/eventsend.c, src/msgqbroadcast.c, src/msgqcreate.c, src/msgqflush.c, src/msgqgetnumberpending.c, src/msgqreceive.c, src/msgqsubmit.c, src/partcreate.c, src/partdelete.c, src/partgetbuffer.c, src/ratemoncancel.c, src/ratemoncreate.c, src/ratemondelete.c, src/ratemongetstatus.c, src/ratemonident.c, src/ratemonperiod.c, src/regioncreate.c, src/regiondelete.c, src/regionextend.c, src/regiongetsegment.c, src/regiongetsegmentsize.c, src/regionreturnsegment.c, src/semcreate.c, src/semdelete.c, src/semflush.c, src/semident.c, src/taskcreate.c, src/taskgetnote.c, src/taskmode.c, src/taskrestart.c, src/taskresume.c, src/tasksetnote.c, src/tasksuspend.c, src/taskvariableadd.c, src/taskvariabledelete.c, src/taskvariableget.c, src/taskwakewhen.c, src/timercreate.c, src/timerdelete.c, src/timerfireafter.c, src/timerfirewhen.c, src/timerserverfireafter.c, src/timerserverfirewhen.c: Add NULL checks.
  • Property mode set to 100644
File size: 4.2 KB
Line 
1/*
2 *  Message Queue Manager
3 *
4 *
5 *  COPYRIGHT (c) 1989-1999.
6 *  On-Line Applications Research Corporation (OAR).
7 *
8 *  The license and distribution terms for this file may be
9 *  found in the file LICENSE in this distribution or at
10 *  http://www.rtems.com/license/LICENSE.
11 *
12 *  $Id$
13 */
14
15#include <rtems/system.h>
16#include <rtems/score/sysstate.h>
17#include <rtems/score/chain.h>
18#include <rtems/score/isr.h>
19#include <rtems/score/coremsg.h>
20#include <rtems/score/object.h>
21#include <rtems/score/states.h>
22#include <rtems/score/thread.h>
23#include <rtems/score/wkspace.h>
24#if defined(RTEMS_MULTIPROCESSING)
25#include <rtems/score/mpci.h>
26#endif
27#include <rtems/rtems/status.h>
28#include <rtems/rtems/attr.h>
29#include <rtems/rtems/message.h>
30#include <rtems/rtems/options.h>
31#include <rtems/rtems/support.h>
32
33/*PAGE
34 *
35 *  rtems_message_queue_create
36 *
37 *  This directive creates a message queue by allocating and initializing
38 *  a message queue data structure.
39 *
40 *  Input parameters:
41 *    name             - user defined queue name
42 *    count            - maximum message and reserved buffer count
43 *    max_message_size - maximum size of each message
44 *    attribute_set    - process method
45 *    id               - pointer to queue
46 *
47 *  Output parameters:
48 *    id                - queue id
49 *    RTEMS_SUCCESSFUL  - if successful
50 *    error code        - if unsuccessful
51 */
52
53rtems_status_code rtems_message_queue_create(
54  rtems_name          name,
55  unsigned32          count,
56  unsigned32          max_message_size,
57  rtems_attribute     attribute_set,
58  Objects_Id         *id
59)
60{
61  register Message_queue_Control *the_message_queue;
62  CORE_message_queue_Attributes   the_msgq_attributes;
63#if defined(RTEMS_MULTIPROCESSING)
64  boolean                         is_global;
65#endif
66
67  if ( !rtems_is_name_valid( name ) )
68    return RTEMS_INVALID_NAME;
69
70  if ( !id )
71    return RTEMS_INVALID_ADDRESS;
72
73#if defined(RTEMS_MULTIPROCESSING)
74  if ( (is_global = _Attributes_Is_global( attribute_set ) ) &&
75       !_System_state_Is_multiprocessing )
76    return RTEMS_MP_NOT_CONFIGURED;
77#endif
78
79  if ( count == 0 )
80      return RTEMS_INVALID_NUMBER;
81
82  if ( max_message_size == 0 )
83      return RTEMS_INVALID_SIZE;
84
85#if defined(RTEMS_MULTIPROCESSING)
86#if 1
87  /*
88   * I am not 100% sure this should be an error.
89   * It seems reasonable to create a que with a large max size,
90   * and then just send smaller msgs from remote (or all) nodes.
91   */
92 
93  if ( is_global && (_MPCI_table->maximum_packet_size < max_message_size) )
94    return RTEMS_INVALID_SIZE;
95#endif
96#endif
97       
98  _Thread_Disable_dispatch();              /* protects object pointer */
99
100  the_message_queue = _Message_queue_Allocate( count, max_message_size );
101
102  if ( !the_message_queue ) {
103    _Thread_Enable_dispatch();
104    return RTEMS_TOO_MANY;
105  }
106
107#if defined(RTEMS_MULTIPROCESSING)
108  if ( is_global &&
109    !( _Objects_MP_Allocate_and_open( &_Message_queue_Information,
110                              name, the_message_queue->Object.id, FALSE ) ) ) {
111    _Message_queue_Free( the_message_queue );
112    _Thread_Enable_dispatch();
113    return RTEMS_TOO_MANY;
114  }
115#endif
116
117  the_message_queue->attribute_set = attribute_set;
118
119  if (_Attributes_Is_priority( attribute_set ) )
120    the_msgq_attributes.discipline = CORE_MESSAGE_QUEUE_DISCIPLINES_PRIORITY;
121  else
122    the_msgq_attributes.discipline = CORE_MESSAGE_QUEUE_DISCIPLINES_FIFO;
123
124  if ( ! _CORE_message_queue_Initialize(
125           &the_message_queue->message_queue,
126           &the_msgq_attributes,
127           count,
128           max_message_size
129         ) ) {
130#if defined(RTEMS_MULTIPROCESSING)
131    if ( is_global )
132        _Objects_MP_Close(
133          &_Message_queue_Information, the_message_queue->Object.id);
134#endif
135
136    _Message_queue_Free( the_message_queue );
137    _Thread_Enable_dispatch();
138    return RTEMS_TOO_MANY;
139  }
140
141  _Objects_Open(
142    &_Message_queue_Information,
143    &the_message_queue->Object,
144    (Objects_Name) name
145  );
146
147  *id = the_message_queue->Object.id;
148
149#if defined(RTEMS_MULTIPROCESSING)
150  if ( is_global )
151    _Message_queue_MP_Send_process_packet(
152      MESSAGE_QUEUE_MP_ANNOUNCE_CREATE,
153      the_message_queue->Object.id,
154      name,
155      0
156    );
157#endif
158
159  _Thread_Enable_dispatch();
160  return RTEMS_SUCCESSFUL;
161}
Note: See TracBrowser for help on using the repository browser.