source: rtems/cpukit/score/src/objectgetnext.c @ 9b4422a2

4.115
Last change on this file since 9b4422a2 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.4 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_next
31 *
32 * Like _Objects_Get, but considers the 'id' as a "hint" and
33 * finds next valid one after that point.
34 * Mostly used for monitor and debug traversal of an object.
35 *
36 * Input parameters:
37 *   information - pointer to entry in table for this class
38 *   id          - object id to search for
39 *   location    - address of where to store the location
40 *   next_id     - address to store next id to try
41 *
42 * Output parameters:
43 *   returns     - address of object if local
44 *   location    - one of the following:
45 *                  OBJECTS_ERROR  - invalid object ID
46 *                  OBJECTS_REMOTE - remote object
47 *                  OBJECTS_LOCAL  - local object
48 *   next_id     - will contain a reasonable "next" id to continue traversal
49 *
50 * NOTE:
51 *      assumes can add '1' to an id to get to next index.
52 */
53
54Objects_Control *
55_Objects_Get_next(
56    Objects_Information *information,
57    Objects_Id           id,
58    Objects_Locations   *location_p,
59    Objects_Id          *next_id_p
60)
61{
62    Objects_Control *object;
63    Objects_Id       next_id;
64
65    if ( !information )
66      return NULL;
67
68    if ( !location_p )
69      return NULL;
70
71    if ( !next_id_p )
72      return NULL;
73
74    if (_Objects_Get_index(id) == OBJECTS_ID_INITIAL_INDEX)
75        next_id = information->minimum_id;
76    else
77        next_id = id;
78
79    do {
80        /* walked off end of list? */
81        if (_Objects_Get_index(next_id) > information->maximum)
82        {
83            *location_p = OBJECTS_ERROR;
84            goto final;
85        }
86
87        /* try to grab one */
88        object = _Objects_Get(information, next_id, location_p);
89
90        next_id++;
91
92    } while (*location_p != OBJECTS_LOCAL);
93
94    *next_id_p = next_id;
95    return object;
96
97final:
98    *next_id_p = OBJECTS_ID_FINAL;
99    return 0;
100}
Note: See TracBrowser for help on using the repository browser.