2011-02-01 06:41:42 +01:00
|
|
|
//
|
|
|
|
// Copyright (c) 2011, ARM Limited. All rights reserved.
|
|
|
|
//
|
|
|
|
// This program and the accompanying materials
|
|
|
|
// are licensed and made available under the terms and conditions of the BSD License
|
|
|
|
// which accompanies this distribution. The full text of the license may be found at
|
|
|
|
// http://opensource.org/licenses/bsd-license.php
|
|
|
|
//
|
|
|
|
// THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|
|
|
//
|
|
|
|
//
|
|
|
|
|
|
|
|
#include <AsmMacroIoLib.h>
|
|
|
|
#include <Base.h>
|
|
|
|
#include <AutoGen.h>
|
|
|
|
|
|
|
|
IMPORT SecCommonExceptionEntry
|
|
|
|
EXPORT SecVectorTable
|
|
|
|
|
|
|
|
PRESERVE8
|
|
|
|
AREA SecException, CODE, READONLY, CODEALIGN, ALIGN=5
|
|
|
|
|
2011-07-06 18:07:54 +02:00
|
|
|
//============================================================
|
|
|
|
//Default Exception Handlers
|
|
|
|
//============================================================
|
|
|
|
|
|
|
|
|
|
|
|
SecVectorTable
|
|
|
|
b _DefaultResetHandler
|
|
|
|
b _DefaultUndefined
|
|
|
|
b _DefaultSWI
|
|
|
|
b _DefaultPrefetchAbort
|
|
|
|
b _DefaultDataAbort
|
|
|
|
b _DefaultReserved
|
|
|
|
b _DefaultIrq
|
|
|
|
b _DefaultFiq
|
2011-02-01 06:41:42 +01:00
|
|
|
|
2011-07-06 18:07:54 +02:00
|
|
|
//
|
2011-02-01 06:41:42 +01:00
|
|
|
// Default Exception handlers: There is no plan to return from any of these exceptions.
|
|
|
|
// No context saving at all.
|
2011-07-06 18:07:54 +02:00
|
|
|
//
|
|
|
|
_DefaultResetHandler
|
2011-02-01 06:41:42 +01:00
|
|
|
mov r1, lr
|
2011-07-06 18:07:54 +02:00
|
|
|
cps #0x13 ; Switch to SVC for common stack
|
|
|
|
mov r0, #0
|
|
|
|
blx SecCommonExceptionEntry
|
|
|
|
|
|
|
|
_DefaultUndefined
|
2011-02-01 06:41:42 +01:00
|
|
|
sub r1, LR
|
2011-07-06 18:07:54 +02:00
|
|
|
cps #0x13 ; Switch to SVC for common stack
|
|
|
|
mov r0, #1
|
|
|
|
blx SecCommonExceptionEntry
|
|
|
|
|
|
|
|
_DefaultSWI
|
2011-02-01 06:41:42 +01:00
|
|
|
sub r1, LR, #4
|
2011-07-06 18:07:54 +02:00
|
|
|
cps #0x13 ; Switch to SVC for common stack
|
|
|
|
mov r0, #2
|
|
|
|
blx SecCommonExceptionEntry
|
|
|
|
|
|
|
|
_DefaultPrefetchAbort
|
2011-02-01 06:41:42 +01:00
|
|
|
sub r1, LR, #4
|
2011-07-06 18:07:54 +02:00
|
|
|
cps #0x13 ; Switch to SVC for common stack
|
|
|
|
mov r0, #3
|
|
|
|
blx SecCommonExceptionEntry
|
|
|
|
|
|
|
|
_DefaultDataAbort
|
2011-02-01 06:41:42 +01:00
|
|
|
sub r1, LR, #8
|
2011-07-06 18:07:54 +02:00
|
|
|
cps #0x13 ; Switch to SVC for common stack
|
|
|
|
mov r0, #4
|
|
|
|
blx SecCommonExceptionEntry
|
|
|
|
|
|
|
|
_DefaultReserved
|
2011-02-01 06:41:42 +01:00
|
|
|
mov r1, lr
|
2011-07-06 18:07:54 +02:00
|
|
|
cps #0x13 ; Switch to SVC for common stack
|
|
|
|
mov r0, #5
|
|
|
|
blx SecCommonExceptionEntry
|
|
|
|
|
|
|
|
_DefaultIrq
|
2011-02-01 06:41:42 +01:00
|
|
|
sub r1, LR, #4
|
2011-07-06 18:07:54 +02:00
|
|
|
cps #0x13 ; Switch to SVC for common stack
|
|
|
|
mov r0, #6
|
|
|
|
blx SecCommonExceptionEntry
|
|
|
|
|
|
|
|
_DefaultFiq
|
2011-02-01 06:41:42 +01:00
|
|
|
sub r1, LR, #4
|
2011-07-06 18:07:54 +02:00
|
|
|
cps #0x13 ; Switch to SVC for common stack
|
|
|
|
mov r0, #7
|
|
|
|
blx SecCommonExceptionEntry
|
2011-02-01 06:41:42 +01:00
|
|
|
|
|
|
|
END
|