source: rtems/c/src/lib/libbsp/powerpc/mpc55xxevb/startup/exc-vector-base.S @ 3ce66aa

4.11
Last change on this file since 3ce66aa was 3ce66aa, checked in by Sebastian Huber <sebastian.huber@…>, on Nov 19, 2012 at 8:02:12 AM

bsp/mpc55xx: Set PPC_EXC_CONFIG_USE_FIXED_HANDLER

  • Property mode set to 100644
File size: 3.1 KB
Line 
1/**
2 * @file
3 *
4 * @ingroup mpc55xx_asm
5 *
6 * @brief Exception minimum prologues.
7 */
8
9/*
10 * Copyright (c) 2011-2012 embedded brains GmbH.  All rights reserved.
11 *
12 *  embedded brains GmbH
13 *  Obere Lagerstr. 30
14 *  82178 Puchheim
15 *  Germany
16 *  <rtems@embedded-brains.de>
17 *
18 * The license and distribution terms for this file may be
19 * found in the file LICENSE in this distribution or at
20 * http://www.rtems.com/license/LICENSE.
21 */
22
23/**
24 * @defgroup mpc55xx_asm Assembler files
25 *
26 * @ingroup mpc55xx
27 */
28
29#include <bspopts.h>
30
31#include <bsp/vectors.h>
32
33        .globl mpc55xx_exc_vector_base
34
35        .section ".bsp_text", "ax"
36
37#if 5510 <= MPC55XX_CHIP_TYPE && MPC55XX_CHIP_TYPE <= 5517
38        .align 12
39#else
40        .align 16
41#endif
42
43mpc55xx_exc_vector_base:
44
45        stw     r1, ppc_exc_lock_crit@sdarel(r13)
46        stw     r4, ppc_exc_vector_register_crit@sdarel(r13)
47        li      r4, -32767
48        b       ppc_exc_wrap_bookE_crit
49        stwu    r1, -EXC_GENERIC_SIZE(r1)
50        stw     r4, GPR4_OFFSET(r1)
51        li      r4, 2
52        b       ppc_exc_wrap_nopush_bookE_crit
53        stwu    r1, -EXC_GENERIC_SIZE(r1)
54        stw     r4, GPR4_OFFSET(r1)
55        li      r4, 3
56        b       ppc_exc_wrap_nopush_std
57        stwu    r1, -EXC_GENERIC_SIZE(r1)
58        stw     r4, GPR4_OFFSET(r1)
59        li      r4, 4
60        b       ppc_exc_wrap_nopush_std
61        stwu    r1, -PPC_EXC_MINIMAL_FRAME_SIZE(r1)
62#ifndef PPC_EXC_CONFIG_USE_FIXED_HANDLER
63        stw     r4, PPC_EXC_VECTOR_PROLOGUE_OFFSET(r1)
64        li      r4, -32763
65#endif
66        b       ppc_exc_wrap_async_normal
67#ifdef PPC_EXC_CONFIG_USE_FIXED_HANDLER
68        nop
69        nop
70#endif
71        stwu    r1, -EXC_GENERIC_SIZE(r1)
72        stw     r4, GPR4_OFFSET(r1)
73        li      r4, 6
74        b       ppc_exc_wrap_nopush_std
75        stwu    r1, -EXC_GENERIC_SIZE(r1)
76        stw     r4, GPR4_OFFSET(r1)
77        li      r4, 7
78        b       ppc_exc_wrap_nopush_std
79        stwu    r1, -EXC_GENERIC_SIZE(r1)
80        stw     r4, GPR4_OFFSET(r1)
81        li      r4, 8
82        b       ppc_exc_wrap_nopush_std
83        stwu    r1, -EXC_GENERIC_SIZE(r1)
84        stw     r4, GPR4_OFFSET(r1)
85        li      r4, 12
86        b       ppc_exc_wrap_nopush_std
87        stwu    r1, -EXC_GENERIC_SIZE(r1)
88        stw     r4, GPR4_OFFSET(r1)
89        li      r4, 24
90        b       ppc_exc_wrap_nopush_std
91        stwu    r1, -PPC_EXC_MINIMAL_FRAME_SIZE(r1)
92#ifndef PPC_EXC_CONFIG_USE_FIXED_HANDLER
93        stw     r4, PPC_EXC_VECTOR_PROLOGUE_OFFSET(r1)
94        li      r4, -32752
95#endif
96        b       ppc_exc_wrap_async_normal
97#ifdef PPC_EXC_CONFIG_USE_FIXED_HANDLER
98        nop
99        nop
100#endif
101        stwu    r1, -PPC_EXC_MINIMAL_FRAME_SIZE(r1)
102#ifndef PPC_EXC_CONFIG_USE_FIXED_HANDLER
103        stw     r4, PPC_EXC_VECTOR_PROLOGUE_OFFSET(r1)
104        li      r4, -32749
105#endif
106        b       ppc_exc_wrap_async_normal
107#ifdef PPC_EXC_CONFIG_USE_FIXED_HANDLER
108        nop
109        nop
110#endif
111        stw     r1, ppc_exc_lock_crit@sdarel(r13)
112        stw     r4, ppc_exc_vector_register_crit@sdarel(r13)
113        li      r4, -32748
114        b       ppc_exc_wrap_bookE_crit
115        stwu    r1, -EXC_GENERIC_SIZE(r1)
116        stw     r4, GPR4_OFFSET(r1)
117        li      r4, 18
118        b       ppc_exc_wrap_nopush_std
119        stwu    r1, -EXC_GENERIC_SIZE(r1)
120        stw     r4, GPR4_OFFSET(r1)
121        li      r4, 17
122        b       ppc_exc_wrap_nopush_std
123        stwu    r1, -EXC_GENERIC_SIZE(r1)
124        stw     r4, GPR4_OFFSET(r1)
125        li      r4, 13
126        b       ppc_exc_wrap_nopush_bookE_crit
127        stwu    r1, -EXC_GENERIC_SIZE(r1)
128        stw     r4, GPR4_OFFSET(r1)
129        li      r4, 10
130        b       ppc_exc_wrap_nopush_std
131        stwu    r1, -EXC_GENERIC_SIZE(r1)
132        stw     r4, GPR4_OFFSET(r1)
133        li      r4, 25
134        b       ppc_exc_wrap_nopush_std
135        stwu    r1, -EXC_GENERIC_SIZE(r1)
136        stw     r4, GPR4_OFFSET(r1)
137        li      r4, 26
138        b       ppc_exc_wrap_nopush_std
139        stwu    r1, -EXC_GENERIC_SIZE(r1)
140        stw     r4, GPR4_OFFSET(r1)
141        li      r4, 15
142        b       ppc_exc_wrap_nopush_std
Note: See TracBrowser for help on using the repository browser.