source: rtems/cpukit/score/src/isr.c @ e6f7f81

4.115
Last change on this file since e6f7f81 was 560efeb, checked in by Sebastian Huber <sebastian.huber@…>, on 07/23/13 at 14:20:43

score: Include missing <rtems/score/address.h>

  • Property mode set to 100644
File size: 1.8 KB
Line 
1/**
2 *  @file
3 *
4 *  @brief Initialize the ISR handler
5 *  @ingroup ScoreISR
6 */
7
8/*
9 *  COPYRIGHT (c) 1989-2012.
10 *  On-Line Applications Research Corporation (OAR).
11 *
12 *  The license and distribution terms for this file may be
13 *  found in the file LICENSE in this distribution or at
14 *  http://www.rtems.com/license/LICENSE.
15 */
16
17#if HAVE_CONFIG_H
18#include "config.h"
19#endif
20
21#include <rtems/system.h>
22#include <rtems/score/address.h>
23#include <rtems/score/isr.h>
24#include <rtems/score/stack.h>
25#include <rtems/score/interr.h>
26#include <rtems/score/wkspace.h>
27#include <rtems/config.h>
28
29void _ISR_Handler_initialization( void )
30{
31  _ISR_Nest_level = 0;
32
33#if (CPU_SIMPLE_VECTORED_INTERRUPTS == TRUE)
34  _ISR_Vector_table = _Workspace_Allocate_or_fatal_error(
35     sizeof(ISR_Handler_entry) * ISR_NUMBER_OF_VECTORS
36  );
37
38  _CPU_Initialize_vectors();
39#endif
40
41#if ( CPU_ALLOCATE_INTERRUPT_STACK == TRUE )
42  {
43    size_t stack_size = rtems_configuration_get_interrupt_stack_size();
44
45    if ( !_Stack_Is_enough( stack_size ) )
46      _Internal_error_Occurred(
47        INTERNAL_ERROR_CORE,
48        true,
49        INTERNAL_ERROR_INTERRUPT_STACK_TOO_SMALL
50      );
51
52    _CPU_Interrupt_stack_low = _Workspace_Allocate_or_fatal_error(
53      stack_size
54    );
55
56    _CPU_Interrupt_stack_high = _Addresses_Add_offset(
57      _CPU_Interrupt_stack_low,
58      stack_size
59    );
60  }
61
62#if (CPU_STACK_ALIGNMENT != 0)
63  _CPU_Interrupt_stack_high = (void *)
64    ((uintptr_t) _CPU_Interrupt_stack_high & ~(CPU_STACK_ALIGNMENT - 1));
65#endif
66
67  /* Interrupt stack might have to be aligned and/or setup
68   * in a specific way.
69   */
70#if defined(_CPU_Interrupt_stack_setup)
71  _CPU_Interrupt_stack_setup(_CPU_Interrupt_stack_low, _CPU_Interrupt_stack_high);
72#endif
73
74#endif
75
76#if ( CPU_HAS_HARDWARE_INTERRUPT_STACK == TRUE )
77  _CPU_Install_interrupt_stack();
78#endif
79
80#if defined(RTEMS_SMP)
81  _ISR_SMP_Initialize();
82#endif
83}
Note: See TracBrowser for help on using the repository browser.