source: rtems/cpukit/rtems/src/semtranslatereturncode.c @ 7c8d65e

4.104.115
Last change on this file since 7c8d65e was 7c8d65e, checked in by Joel Sherrill <joel.sherrill@…>, on 05/28/09 at 20:38:12

2009-05-28 Joel Sherrill <joel.sherrill@…>

PR 1415/cpukit

  • rtems/src/semcreate.c, rtems/src/semtranslatereturncode.c, score/include/rtems/score/coremutex.h, score/inline/rtems/score/coremutex.inl, score/src/coremutex.c: Address two paths where a task with a priority above the ceiling could obtain a priority ceiling mutex.
  • Property mode set to 100644
File size: 3.7 KB
Line 
1/*
2 *  Semaphore Manager
3 *
4 *  DESCRIPTION:
5 *
6 *  This package is the implementation of the Semaphore Manager.
7 *  This manager utilizes standard Dijkstra counting semaphores to provide
8 *  synchronization and mutual exclusion capabilities.
9 *
10 *  Directives provided are:
11 *
12 *     + create a semaphore
13 *     + get an ID of a semaphore
14 *     + delete a semaphore
15 *     + acquire a semaphore
16 *     + release a semaphore
17 *
18 *  COPYRIGHT (c) 1989-2009.
19 *  On-Line Applications Research Corporation (OAR).
20 *
21 *  The license and distribution terms for this file may be
22 *  found in the file LICENSE in this distribution or at
23 *  http://www.rtems.com/license/LICENSE.
24 *
25 *  $Id$
26 */
27
28#if HAVE_CONFIG_H
29#include "config.h"
30#endif
31
32#include <rtems/system.h>
33#include <rtems/rtems/status.h>
34#include <rtems/rtems/support.h>
35#include <rtems/rtems/attr.h>
36#include <rtems/score/isr.h>
37#include <rtems/score/object.h>
38#include <rtems/rtems/options.h>
39#include <rtems/rtems/sem.h>
40#include <rtems/score/coremutex.h>
41#include <rtems/score/coresem.h>
42#include <rtems/score/states.h>
43#include <rtems/score/thread.h>
44#include <rtems/score/threadq.h>
45#if defined(RTEMS_MULTIPROCESSING)
46#include <rtems/score/mpci.h>
47#endif
48#include <rtems/score/sysstate.h>
49
50#include <rtems/score/interr.h>
51
52/*PAGE
53 *
54 *  _Semaphore_Translate_core_mutex_return_code
55 *
56 *  Input parameters:
57 *    status - mutex status code to translate
58 *
59 *  Output parameters:
60 *    rtems status code - translated RTEMS status code
61 *
62 */
63
64const rtems_status_code _Semaphore_Translate_core_mutex_return_code_[] = {
65  RTEMS_SUCCESSFUL,         /* CORE_MUTEX_STATUS_SUCCESSFUL */
66  RTEMS_UNSATISFIED,        /* CORE_MUTEX_STATUS_UNSATISFIED_NOWAIT */
67  RTEMS_UNSATISFIED,        /* CORE_MUTEX_STATUS_NESTING_NOT_ALLOWED */
68  RTEMS_NOT_OWNER_OF_RESOURCE, /* CORE_MUTEX_STATUS_NOT_OWNER_OF_RESOURCE */
69  RTEMS_OBJECT_WAS_DELETED, /* CORE_MUTEX_WAS_DELETED */
70  RTEMS_TIMEOUT,            /* CORE_MUTEX_TIMEOUT */
71#ifdef __RTEMS_STRICT_ORDER_MUTEX__
72    CORE_MUTEX_RELEASE_NOT_ORDER,
73#endif
74  RTEMS_INVALID_PRIORITY   /* CORE_MUTEX_STATUS_CEILING_VIOLATED */
75};
76
77rtems_status_code _Semaphore_Translate_core_mutex_return_code (
78  uint32_t   status
79)
80{
81  /*
82   *  If this thread is blocking waiting for a result on a remote operation.
83   */
84  #if defined(RTEMS_MULTIPROCESSING)
85    if ( _Thread_Is_proxy_blocking(status) )
86      return RTEMS_PROXY_BLOCKING;
87  #endif
88
89  /*
90   *  Internal consistency check for bad status from SuperCore
91   */
92  #if defined(RTEMS_DEBUG)
93    if ( status > CORE_MUTEX_STATUS_LAST )
94      return RTEMS_INTERNAL_ERROR;
95  #endif
96  return _Semaphore_Translate_core_mutex_return_code_[status];
97}
98
99/*PAGE
100 *
101 *  _Semaphore_Translate_core_semaphore_return_code
102 *
103 *  Input parameters:
104 *    status - semaphore status code to translate
105 *
106 *  Output parameters:
107 *    rtems status code - translated RTEMS status code
108 *
109 */
110
111const rtems_status_code _Semaphore_Translate_core_semaphore_return_code_[] = {
112  RTEMS_SUCCESSFUL,         /* CORE_SEMAPHORE_STATUS_SUCCESSFUL */
113  RTEMS_UNSATISFIED,        /* CORE_SEMAPHORE_STATUS_UNSATISFIED_NOWAIT */
114  RTEMS_OBJECT_WAS_DELETED, /* CORE_SEMAPHORE_WAS_DELETED */
115  RTEMS_TIMEOUT,            /* CORE_SEMAPHORE_TIMEOUT  */
116  RTEMS_INTERNAL_ERROR,     /* CORE_SEMAPHORE_MAXIMUM_COUNT_EXCEEDED */
117};
118
119rtems_status_code _Semaphore_Translate_core_semaphore_return_code (
120  uint32_t   status
121)
122{
123  #if defined(RTEMS_MULTIPROCESSING)
124    if ( _Thread_Is_proxy_blocking(status) )
125      return RTEMS_PROXY_BLOCKING;
126  #endif
127  /*
128   *  Internal consistency check for bad status from SuperCore
129   */
130  #if defined(RTEMS_DEBUG)
131    if ( status > CORE_SEMAPHORE_STATUS_LAST )
132      return RTEMS_INTERNAL_ERROR;
133  #endif
134  return _Semaphore_Translate_core_semaphore_return_code_[status];
135}
Note: See TracBrowser for help on using the repository browser.