OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [freertos-6.1.1/] [Source/] [portable/] [IAR/] [V850ES/] [ISR_Support.h] - Blame information for rev 609

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 572 jeremybenn
/*
2
    FreeRTOS V6.1.1 - Copyright (C) 2011 Real Time Engineers Ltd.
3
 
4
    ***************************************************************************
5
    *                                                                         *
6
    * If you are:                                                             *
7
    *                                                                         *
8
    *    + New to FreeRTOS,                                                   *
9
    *    + Wanting to learn FreeRTOS or multitasking in general quickly       *
10
    *    + Looking for basic training,                                        *
11
    *    + Wanting to improve your FreeRTOS skills and productivity           *
12
    *                                                                         *
13
    * then take a look at the FreeRTOS books - available as PDF or paperback  *
14
    *                                                                         *
15
    *        "Using the FreeRTOS Real Time Kernel - a Practical Guide"        *
16
    *                  http://www.FreeRTOS.org/Documentation                  *
17
    *                                                                         *
18
    * A pdf reference manual is also available.  Both are usually delivered   *
19
    * to your inbox within 20 minutes to two hours when purchased between 8am *
20
    * and 8pm GMT (although please allow up to 24 hours in case of            *
21
    * exceptional circumstances).  Thank you for your support!                *
22
    *                                                                         *
23
    ***************************************************************************
24
 
25
    This file is part of the FreeRTOS distribution.
26
 
27
    FreeRTOS is free software; you can redistribute it and/or modify it under
28
    the terms of the GNU General Public License (version 2) as published by the
29
    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.
30
    ***NOTE*** The exception to the GPL is included to allow you to distribute
31
    a combined work that includes FreeRTOS without being obliged to provide the
32
    source code for proprietary components outside of the FreeRTOS kernel.
33
    FreeRTOS is distributed in the hope that it will be useful, but WITHOUT
34
    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
35
    FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
36
    more details. You should have received a copy of the GNU General Public
37
    License and the FreeRTOS license exception along with FreeRTOS; if not it
38
    can be viewed here: http://www.freertos.org/a00114.html and also obtained
39
    by writing to Richard Barry, contact details for whom are available on the
40
    FreeRTOS WEB site.
41
 
42
    1 tab == 4 spaces!
43
 
44
    http://www.FreeRTOS.org - Documentation, latest information, license and
45
    contact details.
46
 
47
    http://www.SafeRTOS.com - A version that is certified for use in safety
48
    critical systems.
49
 
50
    http://www.OpenRTOS.com - Commercial support, development, porting,
51
    licensing and training services.
52
*/
53
 
54
        EXTERN pxCurrentTCB
55
        EXTERN usCriticalNesting
56
 
57
#include "FreeRTOSConfig.h"
58
 
59
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
60
; Context save and restore macro definitions
61
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
62
 
63
portSAVE_CONTEXT MACRO
64
 
65
    add     -0x0C,sp                    ; prepare stack to save necessary values
66
    st.w    lp,8[sp]                    ; store LP to stack
67
    stsr    0,r31
68
    st.w    lp,4[sp]                    ; store EIPC to stack
69
    stsr    1,lp
70
    st.w    lp,0[sp]                     ; store EIPSW to stack
71
#if configDATA_MODE == 1                                        ; Using the Tiny data model
72
    prepare {r20,r21,r22,r23,r24,r25,r26,r27,r28,r29,r30},76,sp ; save general purpose registers
73
    sst.w   r19,72[ep]
74
    sst.w   r18,68[ep]
75
    sst.w   r17,64[ep]
76
    sst.w   r16,60[ep]
77
    sst.w   r15,56[ep]
78
    sst.w   r14,52[ep]
79
    sst.w   r13,48[ep]
80
    sst.w   r12,44[ep]
81
    sst.w   r11,40[ep]
82
    sst.w   r10,36[ep]
83
    sst.w   r9,32[ep]
84
    sst.w   r8,28[ep]
85
    sst.w   r7,24[ep]
86
    sst.w   r6,20[ep]
87
    sst.w   r5,16[ep]
88
    sst.w   r4,12[ep]
89
#else                                                           ; Using the Small/Large data model
90
    prepare {r20,r21,r22,r23,r24,r26,r27,r28,r29,r30},72,sp     ; save general purpose registers
91
    sst.w   r19,68[ep]
92
    sst.w   r18,64[ep]
93
    sst.w   r17,60[ep]
94
    sst.w   r16,56[ep]
95
    sst.w   r15,52[ep]
96
    sst.w   r14,48[ep]
97
    sst.w   r13,44[ep]
98
    sst.w   r12,40[ep]
99
    sst.w   r11,36[ep]
100
    sst.w   r10,32[ep]
101
    sst.w   r9,28[ep]
102
    sst.w   r8,24[ep]
103
    sst.w   r7,20[ep]
104
    sst.w   r6,16[ep]
105
    sst.w   r5,12[ep]
106
#endif /* configDATA_MODE */
107
    sst.w   r2,8[ep]
108
    sst.w   r1,4[ep]
109
    MOVHI   hi1(usCriticalNesting),r0,r1        ; save usCriticalNesting value to stack
110
    ld.w    lw1(usCriticalNesting)[r1],r2
111
    sst.w   r2,0[ep]
112
    MOVHI   hi1(pxCurrentTCB),r0,r1                     ; save SP to top of current TCB
113
    ld.w    lw1(pxCurrentTCB)[r1],r2
114
    st.w    sp,0[r2]
115
    ENDM
116
 
117
 
118
portRESTORE_CONTEXT MACRO
119
 
120
    MOVHI   hi1(pxCurrentTCB),r0,r1                     ; get Stackpointer address
121
    ld.w    lw1(pxCurrentTCB)[r1],sp
122
    MOV     sp,r1
123
    ld.w    0[r1],sp                                             ; load stackpointer
124
    MOV     sp,ep                                                       ; set stack pointer to element pointer
125
    sld.w   0[ep],r1                                             ; load usCriticalNesting value from stack
126
    MOVHI   hi1(usCriticalNesting),r0,r2
127
    st.w    r1,lw1(usCriticalNesting)[r2]
128
    sld.w   4[ep],r1                                            ; restore general purpose registers
129
    sld.w   8[ep],r2
130
#if configDATA_MODE == 1                                        ; Using Tiny data model
131
    sld.w   12[ep],r4
132
    sld.w   16[ep],r5
133
    sld.w   20[ep],r6
134
    sld.w   24[ep],r7
135
    sld.w   28[ep],r8
136
    sld.w   32[ep],r9
137
    sld.w   36[ep],r10
138
    sld.w   40[ep],r11
139
    sld.w   44[ep],r12
140
    sld.w   48[ep],r13
141
    sld.w   52[ep],r14
142
    sld.w   56[ep],r15
143
    sld.w   60[ep],r16
144
    sld.w   64[ep],r17
145
    sld.w   68[ep],r18
146
    sld.w   72[ep],r19
147
    dispose 76,{r20,r21,r22,r23,r24,r25,r26,r27,r28,r29,r30}
148
#else                                                                           ; Using Small/Large data model
149
    sld.w   12[ep],r5
150
    sld.w   16[ep],r6
151
    sld.w   20[ep],r7
152
    sld.w   24[ep],r8
153
    sld.w   28[ep],r9
154
    sld.w   32[ep],r10
155
    sld.w   36[ep],r11
156
    sld.w   40[ep],r12
157
    sld.w   44[ep],r13
158
    sld.w   48[ep],r14
159
    sld.w   52[ep],r15
160
    sld.w   56[ep],r16
161
    sld.w   60[ep],r17
162
    sld.w   64[ep],r18
163
    sld.w   68[ep],r19
164
    dispose 72,{r20,r21,r22,r23,r24,r26,r27,r28,r29,r30}
165
#endif /* configDATA_MODE */
166
    ld.w    0[sp],lp                                             ; restore EIPSW from stack
167
    ldsr    lp,1
168
    ld.w    4[sp],lp                                            ; restore EIPC from stack
169
    ldsr    lp,0
170
    ld.w    8[sp],lp                                            ; restore LP from stack
171
    add     0x0C,sp                                                     ; set SP to right position
172
 
173
    RETI
174
 
175
    ENDM

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.