source: rtems/c/src/exec/posix/src/mqueuenotify.c @ 53092d1

4.104.114.84.95
Last change on this file since 53092d1 was 53092d1, checked in by Joel Sherrill <joel.sherrill@…>, on 04/26/02 at 23:39:01

2001-04-26 Joel Sherrill <joel@…>

  • include/rtems/posix/mqueue.h, inline/rtems/posix/mqueue.inl, src/mqueue.c, src/mqueueclose.c, src/mqueuecreatesupp.c, src/mqueuegetattr.c, src/mqueuenotify.c, src/mqueueopen.c, src/mqueuerecvsupp.c, src/mqueuesendsupp.c, src/mqueuesetattr.c: Per PR81 reworked to add a message queue descriptor separate from the underlying message queue. This allows non-blocking to follow the "open" not the underlying queue.
  • Property mode set to 100644
File size: 2.7 KB
Line 
1/*
2 *  NOTE:  The structure of the routines is identical to that of POSIX
3 *         Message_queues to leave the option of having unnamed message
4 *         queues at a future date.  They are currently not part of the
5 *         POSIX standard but unnamed message_queues are.  This is also
6 *         the reason for the apparently unnecessary tracking of
7 *         the process_shared attribute.  [In addition to the fact that
8 *         it would be trivial to add pshared to the mq_attr structure
9 *         and have process private message queues.]
10 *
11 *         This code ignores the O_RDONLY/O_WRONLY/O_RDWR flag at open
12 *         time.
13 *
14 *  $Id$
15 */
16
17#if HAVE_CONFIG_H
18#include "config.h"
19#endif
20
21#include <stdarg.h>
22
23#include <pthread.h>
24#include <limits.h>
25#include <errno.h>
26#include <fcntl.h>
27#include <mqueue.h>
28#include <sys/types.h>
29#include <signal.h>
30
31#include <rtems/system.h>
32#include <rtems/score/watchdog.h>
33#include <rtems/seterr.h>
34#include <rtems/posix/mqueue.h>
35#include <rtems/posix/time.h>
36
37/*PAGE
38 *
39 *  _POSIX_Message_queue_Notify_handler
40 *
41 */
42
43void _POSIX_Message_queue_Notify_handler(
44  void    *user_data
45)
46{
47  POSIX_Message_queue_Control *the_mq;
48
49  the_mq = user_data;
50
51  kill( getpid(), the_mq->notification.sigev_signo );
52
53  _CORE_message_queue_Set_notify( &the_mq->Message_queue, NULL, NULL );
54}
55
56/*PAGE
57 *
58 *  15.2.6 Notify Process that a Message is Available on a Queue,
59 *         P1003.1b-1993, p. 280
60 */
61
62int mq_notify(
63  mqd_t                  mqdes,
64  const struct sigevent *notification
65)
66{
67  POSIX_Message_queue_Control    *the_mq;
68  POSIX_Message_queue_Control_fd *the_mq_fd;
69  Objects_Locations               location;
70 
71  the_mq_fd = _POSIX_Message_queue_Get_fd( mqdes, &location );
72  switch ( location ) {
73    case OBJECTS_ERROR:
74      rtems_set_errno_and_return_minus_one( EBADF );
75    case OBJECTS_REMOTE:
76      _Thread_Dispatch();
77      return POSIX_MP_NOT_IMPLEMENTED();
78      rtems_set_errno_and_return_minus_one( EINVAL );
79    case OBJECTS_LOCAL:
80      the_mq = the_mq_fd->Queue;
81
82      if ( notification ) {
83        if ( _CORE_message_queue_Is_notify_enabled( &the_mq->Message_queue ) ) {
84          _Thread_Enable_dispatch();
85          rtems_set_errno_and_return_minus_one( EBUSY );
86        }
87
88        _CORE_message_queue_Set_notify( &the_mq->Message_queue, NULL, NULL );
89
90        the_mq->notification = *notification;
91     
92        _CORE_message_queue_Set_notify(
93          &the_mq->Message_queue,
94          _POSIX_Message_queue_Notify_handler,
95          the_mq
96        );
97      } else {
98
99        _CORE_message_queue_Set_notify( &the_mq->Message_queue, NULL, NULL );
100
101      }
102
103      _Thread_Enable_dispatch();
104      return 0;
105  }
106  return POSIX_BOTTOM_REACHED();
107}
108
Note: See TracBrowser for help on using the repository browser.