source: rtems/cpukit/score/src/objectget.c @ 2d7ae960

4.115
Last change on this file since 2d7ae960 was 9b4422a2, checked in by Joel Sherrill <joel.sherrill@…>, on 05/03/12 at 15:09:24

Remove All CVS Id Strings Possible Using a Script

Script does what is expected and tries to do it as
smartly as possible.

+ remove occurrences of two blank comment lines

next to each other after Id string line removed.

+ remove entire comment blocks which only exited to

contain CVS Ids

+ If the processing left a blank line at the top of

a file, it was removed.

  • Property mode set to 100644
File size: 2.8 KB
Line 
1/*
2 *  Object Handler
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
13#if HAVE_CONFIG_H
14#include "config.h"
15#endif
16
17#include <rtems/system.h>
18#include <rtems/score/address.h>
19#include <rtems/score/chain.h>
20#include <rtems/score/object.h>
21#if defined(RTEMS_MULTIPROCESSING)
22#include <rtems/score/objectmp.h>
23#endif
24#include <rtems/score/thread.h>
25#include <rtems/score/wkspace.h>
26#include <rtems/score/sysstate.h>
27#include <rtems/score/isr.h>
28
29/*
30 * _Objects_Get
31 *
32 * This routine sets the object pointer for the given
33 * object id based on the given object information structure.
34 *
35 * Input parameters:
36 *   information - pointer to entry in table for this class
37 *   id          - object id to search for
38 *   location    - address of where to store the location
39 *
40 * Output parameters:
41 *   returns  - address of object if local
42 *   location - one of the following:
43 *                  OBJECTS_ERROR  - invalid object ID
44 *                  OBJECTS_REMOTE - remote object
45 *                  OBJECTS_LOCAL  - local object
46 */
47
48Objects_Control *_Objects_Get(
49  Objects_Information *information,
50  Objects_Id           id,
51  Objects_Locations   *location
52)
53{
54  Objects_Control *the_object;
55  uint32_t         index;
56
57  /*
58   *  Extract the index portion of an Id in a way that produces a valid
59   *  index for objects within this class and an invalid value for objects
60   *  outside this class.
61   *
62   *  If the Id matches the api, class, and node but index portion is 0,
63   *  then the subtraction will underflow and the addition of 1 will
64   *  result in a 0 index.  The zeroth element in the local_table is
65   *  always NULL.
66   *
67   *  If the Id is valid but the object has not been created yet, then
68   *  the local_table entry will be NULL.
69   */
70  index = id - information->minimum_id + 1;
71
72  /*
73   *  If the index is less than maximum, then it is OK to use it to
74   *  index into the local_table array.
75   */
76  if ( index <= information->maximum ) {
77    _Thread_Disable_dispatch();
78    if ( (the_object = information->local_table[ index ]) != NULL ) {
79      *location = OBJECTS_LOCAL;
80      return the_object;
81    }
82
83    /*
84     *  Valid Id for this API, Class and Node but the object has not
85     *  been allocated yet.
86     */
87    _Thread_Enable_dispatch();
88    *location = OBJECTS_ERROR;
89    return NULL;
90  }
91
92  /*
93   *  Object Id is not within this API and Class on this node.  So
94   *  it may be global in a multiprocessing system.  But it is clearly
95   *  invalid on a single processor system.
96   */
97  *location = OBJECTS_ERROR;
98
99#if defined(RTEMS_MULTIPROCESSING)
100  _Objects_MP_Is_remote( information, id, location, &the_object );
101  return the_object;
102#else
103  return NULL;
104#endif
105}
Note: See TracBrowser for help on using the repository browser.