NRF com

Dependencies:   mbed nRF24L01P

Committer:
vmihalcut
Date:
Mon May 27 06:06:31 2013 +0000
Revision:
0:fdfe93cb9255
NRF24L01 receiver

Who changed what in which revision?

UserRevisionLine numberNew contents of line
vmihalcut 0:fdfe93cb9255 1 /*----------------------------------------------------------------------------
vmihalcut 0:fdfe93cb9255 2 * RL-ARM - RTX
vmihalcut 0:fdfe93cb9255 3 *----------------------------------------------------------------------------
vmihalcut 0:fdfe93cb9255 4 * Name: HAL_CM3.C
vmihalcut 0:fdfe93cb9255 5 * Purpose: Hardware Abstraction Layer for Cortex-M3
vmihalcut 0:fdfe93cb9255 6 * Rev.: V4.60
vmihalcut 0:fdfe93cb9255 7 *----------------------------------------------------------------------------
vmihalcut 0:fdfe93cb9255 8 *
vmihalcut 0:fdfe93cb9255 9 * Copyright (c) 1999-2009 KEIL, 2009-2012 ARM Germany GmbH
vmihalcut 0:fdfe93cb9255 10 * All rights reserved.
vmihalcut 0:fdfe93cb9255 11 * Redistribution and use in source and binary forms, with or without
vmihalcut 0:fdfe93cb9255 12 * modification, are permitted provided that the following conditions are met:
vmihalcut 0:fdfe93cb9255 13 * - Redistributions of source code must retain the above copyright
vmihalcut 0:fdfe93cb9255 14 * notice, this list of conditions and the following disclaimer.
vmihalcut 0:fdfe93cb9255 15 * - Redistributions in binary form must reproduce the above copyright
vmihalcut 0:fdfe93cb9255 16 * notice, this list of conditions and the following disclaimer in the
vmihalcut 0:fdfe93cb9255 17 * documentation and/or other materials provided with the distribution.
vmihalcut 0:fdfe93cb9255 18 * - Neither the name of ARM nor the names of its contributors may be used
vmihalcut 0:fdfe93cb9255 19 * to endorse or promote products derived from this software without
vmihalcut 0:fdfe93cb9255 20 * specific prior written permission.
vmihalcut 0:fdfe93cb9255 21 *
vmihalcut 0:fdfe93cb9255 22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
vmihalcut 0:fdfe93cb9255 23 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
vmihalcut 0:fdfe93cb9255 24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
vmihalcut 0:fdfe93cb9255 25 * ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS AND CONTRIBUTORS BE
vmihalcut 0:fdfe93cb9255 26 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
vmihalcut 0:fdfe93cb9255 27 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
vmihalcut 0:fdfe93cb9255 28 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
vmihalcut 0:fdfe93cb9255 29 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
vmihalcut 0:fdfe93cb9255 30 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
vmihalcut 0:fdfe93cb9255 31 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
vmihalcut 0:fdfe93cb9255 32 * POSSIBILITY OF SUCH DAMAGE.
vmihalcut 0:fdfe93cb9255 33 *---------------------------------------------------------------------------*/
vmihalcut 0:fdfe93cb9255 34
vmihalcut 0:fdfe93cb9255 35 #include "rt_TypeDef.h"
vmihalcut 0:fdfe93cb9255 36 #include "RTX_Conf.h"
vmihalcut 0:fdfe93cb9255 37 #include "rt_System.h"
vmihalcut 0:fdfe93cb9255 38 #include "rt_HAL_CM.h"
vmihalcut 0:fdfe93cb9255 39 #include "rt_Task.h"
vmihalcut 0:fdfe93cb9255 40 #include "rt_MemBox.h"
vmihalcut 0:fdfe93cb9255 41
vmihalcut 0:fdfe93cb9255 42
vmihalcut 0:fdfe93cb9255 43 /*----------------------------------------------------------------------------
vmihalcut 0:fdfe93cb9255 44 * Functions
vmihalcut 0:fdfe93cb9255 45 *---------------------------------------------------------------------------*/
vmihalcut 0:fdfe93cb9255 46
vmihalcut 0:fdfe93cb9255 47
vmihalcut 0:fdfe93cb9255 48 /*--------------------------- rt_set_PSP ------------------------------------*/
vmihalcut 0:fdfe93cb9255 49
vmihalcut 0:fdfe93cb9255 50 __asm void rt_set_PSP (U32 stack) {
vmihalcut 0:fdfe93cb9255 51 MSR PSP,R0
vmihalcut 0:fdfe93cb9255 52 BX LR
vmihalcut 0:fdfe93cb9255 53 }
vmihalcut 0:fdfe93cb9255 54
vmihalcut 0:fdfe93cb9255 55
vmihalcut 0:fdfe93cb9255 56 /*--------------------------- rt_get_PSP ------------------------------------*/
vmihalcut 0:fdfe93cb9255 57
vmihalcut 0:fdfe93cb9255 58 __asm U32 rt_get_PSP (void) {
vmihalcut 0:fdfe93cb9255 59 MRS R0,PSP
vmihalcut 0:fdfe93cb9255 60 BX LR
vmihalcut 0:fdfe93cb9255 61 }
vmihalcut 0:fdfe93cb9255 62
vmihalcut 0:fdfe93cb9255 63
vmihalcut 0:fdfe93cb9255 64 /*--------------------------- os_set_env ------------------------------------*/
vmihalcut 0:fdfe93cb9255 65
vmihalcut 0:fdfe93cb9255 66 __asm void os_set_env (void) {
vmihalcut 0:fdfe93cb9255 67 /* Switch to Unprivileged/Privileged Thread mode, use PSP. */
vmihalcut 0:fdfe93cb9255 68 MOV R0,SP ; PSP = MSP
vmihalcut 0:fdfe93cb9255 69 MSR PSP,R0
vmihalcut 0:fdfe93cb9255 70 LDR R0,=__cpp(&os_flags)
vmihalcut 0:fdfe93cb9255 71 LDRB R0,[R0]
vmihalcut 0:fdfe93cb9255 72 LSLS R0,#31
vmihalcut 0:fdfe93cb9255 73 MOVNE R0,#0x02 ; Privileged Thread mode, use PSP
vmihalcut 0:fdfe93cb9255 74 MOVEQ R0,#0x03 ; Unprivileged Thread mode, use PSP
vmihalcut 0:fdfe93cb9255 75 MSR CONTROL,R0
vmihalcut 0:fdfe93cb9255 76 BX LR
vmihalcut 0:fdfe93cb9255 77
vmihalcut 0:fdfe93cb9255 78 ALIGN
vmihalcut 0:fdfe93cb9255 79 }
vmihalcut 0:fdfe93cb9255 80
vmihalcut 0:fdfe93cb9255 81
vmihalcut 0:fdfe93cb9255 82 /*--------------------------- _alloc_box ------------------------------------*/
vmihalcut 0:fdfe93cb9255 83
vmihalcut 0:fdfe93cb9255 84 __asm void *_alloc_box (void *box_mem) {
vmihalcut 0:fdfe93cb9255 85 /* Function wrapper for Unprivileged/Privileged mode. */
vmihalcut 0:fdfe93cb9255 86 LDR R12,=__cpp(rt_alloc_box)
vmihalcut 0:fdfe93cb9255 87 MRS R3,IPSR
vmihalcut 0:fdfe93cb9255 88 LSLS R3,#24
vmihalcut 0:fdfe93cb9255 89 BXNE R12
vmihalcut 0:fdfe93cb9255 90 MRS R3,CONTROL
vmihalcut 0:fdfe93cb9255 91 LSLS R3,#31
vmihalcut 0:fdfe93cb9255 92 BXEQ R12
vmihalcut 0:fdfe93cb9255 93 SVC 0
vmihalcut 0:fdfe93cb9255 94 BX LR
vmihalcut 0:fdfe93cb9255 95
vmihalcut 0:fdfe93cb9255 96 ALIGN
vmihalcut 0:fdfe93cb9255 97 }
vmihalcut 0:fdfe93cb9255 98
vmihalcut 0:fdfe93cb9255 99
vmihalcut 0:fdfe93cb9255 100 /*--------------------------- _free_box -------------------------------------*/
vmihalcut 0:fdfe93cb9255 101
vmihalcut 0:fdfe93cb9255 102 __asm int _free_box (void *box_mem, void *box) {
vmihalcut 0:fdfe93cb9255 103 /* Function wrapper for Unprivileged/Privileged mode. */
vmihalcut 0:fdfe93cb9255 104 LDR R12,=__cpp(rt_free_box)
vmihalcut 0:fdfe93cb9255 105 MRS R3,IPSR
vmihalcut 0:fdfe93cb9255 106 LSLS R3,#24
vmihalcut 0:fdfe93cb9255 107 BXNE R12
vmihalcut 0:fdfe93cb9255 108 MRS R3,CONTROL
vmihalcut 0:fdfe93cb9255 109 LSLS R3,#31
vmihalcut 0:fdfe93cb9255 110 BXEQ R12
vmihalcut 0:fdfe93cb9255 111 SVC 0
vmihalcut 0:fdfe93cb9255 112 BX LR
vmihalcut 0:fdfe93cb9255 113
vmihalcut 0:fdfe93cb9255 114 ALIGN
vmihalcut 0:fdfe93cb9255 115 }
vmihalcut 0:fdfe93cb9255 116
vmihalcut 0:fdfe93cb9255 117
vmihalcut 0:fdfe93cb9255 118 /*-------------------------- SVC_Handler ------------------------------------*/
vmihalcut 0:fdfe93cb9255 119
vmihalcut 0:fdfe93cb9255 120 __asm void SVC_Handler (void) {
vmihalcut 0:fdfe93cb9255 121 PRESERVE8
vmihalcut 0:fdfe93cb9255 122
vmihalcut 0:fdfe93cb9255 123 IMPORT SVC_Count
vmihalcut 0:fdfe93cb9255 124 IMPORT SVC_Table
vmihalcut 0:fdfe93cb9255 125 IMPORT rt_stk_check
vmihalcut 0:fdfe93cb9255 126
vmihalcut 0:fdfe93cb9255 127 MRS R0,PSP ; Read PSP
vmihalcut 0:fdfe93cb9255 128 LDR R1,[R0,#24] ; Read Saved PC from Stack
vmihalcut 0:fdfe93cb9255 129 LDRB R1,[R1,#-2] ; Load SVC Number
vmihalcut 0:fdfe93cb9255 130 CBNZ R1,SVC_User
vmihalcut 0:fdfe93cb9255 131
vmihalcut 0:fdfe93cb9255 132 LDM R0,{R0-R3,R12} ; Read R0-R3,R12 from stack
vmihalcut 0:fdfe93cb9255 133 BLX R12 ; Call SVC Function
vmihalcut 0:fdfe93cb9255 134
vmihalcut 0:fdfe93cb9255 135 MRS R12,PSP ; Read PSP
vmihalcut 0:fdfe93cb9255 136 STM R12,{R0-R2} ; Store return values
vmihalcut 0:fdfe93cb9255 137
vmihalcut 0:fdfe93cb9255 138 LDR R3,=__cpp(&os_tsk)
vmihalcut 0:fdfe93cb9255 139 LDM R3,{R1,R2} ; os_tsk.run, os_tsk.new
vmihalcut 0:fdfe93cb9255 140 CMP R1,R2
vmihalcut 0:fdfe93cb9255 141 BEQ SVC_Exit ; no task switch
vmihalcut 0:fdfe93cb9255 142
vmihalcut 0:fdfe93cb9255 143 CBZ R1,SVC_Next ; Runtask deleted?
vmihalcut 0:fdfe93cb9255 144 STMDB R12!,{R4-R11} ; Save Old context
vmihalcut 0:fdfe93cb9255 145 STR R12,[R1,#TCB_TSTACK] ; Update os_tsk.run->tsk_stack
vmihalcut 0:fdfe93cb9255 146
vmihalcut 0:fdfe93cb9255 147 PUSH {R2,R3}
vmihalcut 0:fdfe93cb9255 148 BL rt_stk_check ; Check for Stack overflow
vmihalcut 0:fdfe93cb9255 149 POP {R2,R3}
vmihalcut 0:fdfe93cb9255 150
vmihalcut 0:fdfe93cb9255 151 SVC_Next
vmihalcut 0:fdfe93cb9255 152 STR R2,[R3] ; os_tsk.run = os_tsk.new
vmihalcut 0:fdfe93cb9255 153
vmihalcut 0:fdfe93cb9255 154 LDR R12,[R2,#TCB_TSTACK] ; os_tsk.new->tsk_stack
vmihalcut 0:fdfe93cb9255 155 LDMIA R12!,{R4-R11} ; Restore New Context
vmihalcut 0:fdfe93cb9255 156 MSR PSP,R12 ; Write PSP
vmihalcut 0:fdfe93cb9255 157
vmihalcut 0:fdfe93cb9255 158 SVC_Exit
vmihalcut 0:fdfe93cb9255 159 MVN LR,#:NOT:0xFFFFFFFD ; set EXC_RETURN value
vmihalcut 0:fdfe93cb9255 160 BX LR
vmihalcut 0:fdfe93cb9255 161
vmihalcut 0:fdfe93cb9255 162 /*------------------- User SVC ------------------------------*/
vmihalcut 0:fdfe93cb9255 163
vmihalcut 0:fdfe93cb9255 164 SVC_User
vmihalcut 0:fdfe93cb9255 165 PUSH {R4,LR} ; Save Registers
vmihalcut 0:fdfe93cb9255 166 LDR R2,=SVC_Count
vmihalcut 0:fdfe93cb9255 167 LDR R2,[R2]
vmihalcut 0:fdfe93cb9255 168 CMP R1,R2
vmihalcut 0:fdfe93cb9255 169 BHI SVC_Done ; Overflow
vmihalcut 0:fdfe93cb9255 170
vmihalcut 0:fdfe93cb9255 171 LDR R4,=SVC_Table-4
vmihalcut 0:fdfe93cb9255 172 LDR R4,[R4,R1,LSL #2] ; Load SVC Function Address
vmihalcut 0:fdfe93cb9255 173
vmihalcut 0:fdfe93cb9255 174 LDM R0,{R0-R3,R12} ; Read R0-R3,R12 from stack
vmihalcut 0:fdfe93cb9255 175 BLX R4 ; Call SVC Function
vmihalcut 0:fdfe93cb9255 176
vmihalcut 0:fdfe93cb9255 177 MRS R12,PSP
vmihalcut 0:fdfe93cb9255 178 STM R12,{R0-R3} ; Function return values
vmihalcut 0:fdfe93cb9255 179 SVC_Done
vmihalcut 0:fdfe93cb9255 180 POP {R4,PC} ; RETI
vmihalcut 0:fdfe93cb9255 181
vmihalcut 0:fdfe93cb9255 182 ALIGN
vmihalcut 0:fdfe93cb9255 183 }
vmihalcut 0:fdfe93cb9255 184
vmihalcut 0:fdfe93cb9255 185
vmihalcut 0:fdfe93cb9255 186 /*-------------------------- PendSV_Handler ---------------------------------*/
vmihalcut 0:fdfe93cb9255 187
vmihalcut 0:fdfe93cb9255 188 __asm void PendSV_Handler (void) {
vmihalcut 0:fdfe93cb9255 189 PRESERVE8
vmihalcut 0:fdfe93cb9255 190
vmihalcut 0:fdfe93cb9255 191 BL __cpp(rt_pop_req)
vmihalcut 0:fdfe93cb9255 192
vmihalcut 0:fdfe93cb9255 193 Sys_Switch
vmihalcut 0:fdfe93cb9255 194 LDR R3,=__cpp(&os_tsk)
vmihalcut 0:fdfe93cb9255 195 LDM R3,{R1,R2} ; os_tsk.run, os_tsk.new
vmihalcut 0:fdfe93cb9255 196 CMP R1,R2
vmihalcut 0:fdfe93cb9255 197 BEQ Sys_Exit
vmihalcut 0:fdfe93cb9255 198
vmihalcut 0:fdfe93cb9255 199 MRS R12,PSP ; Read PSP
vmihalcut 0:fdfe93cb9255 200 STMDB R12!,{R4-R11} ; Save Old context
vmihalcut 0:fdfe93cb9255 201 STR R12,[R1,#TCB_TSTACK] ; Update os_tsk.run->tsk_stack
vmihalcut 0:fdfe93cb9255 202
vmihalcut 0:fdfe93cb9255 203 PUSH {R2,R3}
vmihalcut 0:fdfe93cb9255 204 BL rt_stk_check ; Check for Stack overflow
vmihalcut 0:fdfe93cb9255 205 POP {R2,R3}
vmihalcut 0:fdfe93cb9255 206
vmihalcut 0:fdfe93cb9255 207 STR R2,[R3] ; os_tsk.run = os_tsk.new
vmihalcut 0:fdfe93cb9255 208
vmihalcut 0:fdfe93cb9255 209 LDR R12,[R2,#TCB_TSTACK] ; os_tsk.new->tsk_stack
vmihalcut 0:fdfe93cb9255 210 LDMIA R12!,{R4-R11} ; Restore New Context
vmihalcut 0:fdfe93cb9255 211 MSR PSP,R12 ; Write PSP
vmihalcut 0:fdfe93cb9255 212
vmihalcut 0:fdfe93cb9255 213 Sys_Exit
vmihalcut 0:fdfe93cb9255 214 MVN LR,#:NOT:0xFFFFFFFD ; set EXC_RETURN value
vmihalcut 0:fdfe93cb9255 215 BX LR ; Return to Thread Mode
vmihalcut 0:fdfe93cb9255 216
vmihalcut 0:fdfe93cb9255 217 ALIGN
vmihalcut 0:fdfe93cb9255 218 }
vmihalcut 0:fdfe93cb9255 219
vmihalcut 0:fdfe93cb9255 220
vmihalcut 0:fdfe93cb9255 221 /*-------------------------- SysTick_Handler --------------------------------*/
vmihalcut 0:fdfe93cb9255 222
vmihalcut 0:fdfe93cb9255 223 __asm void SysTick_Handler (void) {
vmihalcut 0:fdfe93cb9255 224 PRESERVE8
vmihalcut 0:fdfe93cb9255 225
vmihalcut 0:fdfe93cb9255 226 BL __cpp(rt_systick)
vmihalcut 0:fdfe93cb9255 227 B Sys_Switch
vmihalcut 0:fdfe93cb9255 228
vmihalcut 0:fdfe93cb9255 229 ALIGN
vmihalcut 0:fdfe93cb9255 230 }
vmihalcut 0:fdfe93cb9255 231
vmihalcut 0:fdfe93cb9255 232
vmihalcut 0:fdfe93cb9255 233 /*-------------------------- OS_Tick_Handler --------------------------------*/
vmihalcut 0:fdfe93cb9255 234
vmihalcut 0:fdfe93cb9255 235 __asm void OS_Tick_Handler (void) {
vmihalcut 0:fdfe93cb9255 236 PRESERVE8
vmihalcut 0:fdfe93cb9255 237
vmihalcut 0:fdfe93cb9255 238 BL __cpp(os_tick_irqack)
vmihalcut 0:fdfe93cb9255 239 BL __cpp(rt_systick)
vmihalcut 0:fdfe93cb9255 240 B Sys_Switch
vmihalcut 0:fdfe93cb9255 241
vmihalcut 0:fdfe93cb9255 242 ALIGN
vmihalcut 0:fdfe93cb9255 243 }
vmihalcut 0:fdfe93cb9255 244
vmihalcut 0:fdfe93cb9255 245
vmihalcut 0:fdfe93cb9255 246 /*----------------------------------------------------------------------------
vmihalcut 0:fdfe93cb9255 247 * end of file
vmihalcut 0:fdfe93cb9255 248 *---------------------------------------------------------------------------*/
vmihalcut 0:fdfe93cb9255 249