source: rtems/cpukit/rtems/src/timercreate.c @ aefc109

4.104.114.84.95
Last change on this file since aefc109 was 08311cc3, checked in by Joel Sherrill <joel.sherrill@…>, on 11/17/99 at 17:51:34

Updated copyright notice.

  • Property mode set to 100644
File size: 1.4 KB
Line 
1/*
2 *  Timer Manager
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.OARcorp.com/rtems/license.html.
11 *
12 *  $Id$
13 */
14
15#include <rtems/system.h>
16#include <rtems/rtems/status.h>
17#include <rtems/rtems/support.h>
18#include <rtems/score/object.h>
19#include <rtems/score/thread.h>
20#include <rtems/rtems/timer.h>
21#include <rtems/score/tod.h>
22#include <rtems/score/watchdog.h>
23
24/*PAGE
25 *
26 *  rtems_timer_create
27 *
28 *  This directive creates a timer and performs some initialization.
29 *
30 *  Input parameters:
31 *    name - timer name
32 *    id   - pointer to timer id
33 *
34 *  Output parameters:
35 *    id                - timer id
36 *    RTEMS_SUCCESSFUL - if successful
37 *    error code        - if unsuccessful
38 */
39
40rtems_status_code rtems_timer_create(
41  rtems_name    name,
42  Objects_Id   *id
43)
44{
45  Timer_Control *the_timer;
46
47  if ( !rtems_is_name_valid( name ) )
48    return RTEMS_INVALID_NAME;
49
50  _Thread_Disable_dispatch();         /* to prevent deletion */
51
52  the_timer = _Timer_Allocate();
53
54  if ( !the_timer ) {
55    _Thread_Enable_dispatch();
56    return RTEMS_TOO_MANY;
57  }
58
59  the_timer->the_class = TIMER_DORMANT;
60
61  _Objects_Open( &_Timer_Information, &the_timer->Object, &name );
62
63  *id = the_timer->Object.id;
64  _Thread_Enable_dispatch();
65  return RTEMS_SUCCESSFUL;
66}
Note: See TracBrowser for help on using the repository browser.