source: rtems/cpukit/score/src/objectgetnoprotection.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: 1.9 KB
Line 
1/*
2 *  Object Handler -- Object Get
3 *
4 *
5 *  COPYRIGHT (c) 1989-2002.
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_no_protection
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_no_protection(
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   * You can't just extract the index portion or you can get tricked
59   * by a value between 1 and maximum.
60   */
61  index = id - information->minimum_id + 1;
62
63  if ( information->maximum >= index ) {
64    if ( (the_object = information->local_table[ index ]) != NULL ) {
65      *location = OBJECTS_LOCAL;
66      return the_object;
67    }
68  }
69
70  /*
71   *  This isn't supported or required yet for Global objects so
72   *  if it isn't local, we don't find it.
73   */
74  *location = OBJECTS_ERROR;
75  return NULL;
76}
Note: See TracBrowser for help on using the repository browser.