• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright 2022, The Android Open Source Project
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 //     http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14 
15 //! Exception handlers.
16 
17 use core::arch::asm;
18 use vmbase::{eprintln, power::reboot};
19 
20 #[no_mangle]
sync_exception_current(_elr: u64, _spsr: u64)21 extern "C" fn sync_exception_current(_elr: u64, _spsr: u64) {
22     eprintln!("sync_exception_current");
23     print_esr();
24     reboot();
25 }
26 
27 #[no_mangle]
irq_current(_elr: u64, _spsr: u64)28 extern "C" fn irq_current(_elr: u64, _spsr: u64) {
29     eprintln!("irq_current");
30     reboot();
31 }
32 
33 #[no_mangle]
fiq_current(_elr: u64, _spsr: u64)34 extern "C" fn fiq_current(_elr: u64, _spsr: u64) {
35     eprintln!("fiq_current");
36     reboot();
37 }
38 
39 #[no_mangle]
serr_current(_elr: u64, _spsr: u64)40 extern "C" fn serr_current(_elr: u64, _spsr: u64) {
41     eprintln!("serr_current");
42     print_esr();
43     reboot();
44 }
45 
46 #[no_mangle]
sync_lower(_elr: u64, _spsr: u64)47 extern "C" fn sync_lower(_elr: u64, _spsr: u64) {
48     eprintln!("sync_lower");
49     print_esr();
50     reboot();
51 }
52 
53 #[no_mangle]
irq_lower(_elr: u64, _spsr: u64)54 extern "C" fn irq_lower(_elr: u64, _spsr: u64) {
55     eprintln!("irq_lower");
56     reboot();
57 }
58 
59 #[no_mangle]
fiq_lower(_elr: u64, _spsr: u64)60 extern "C" fn fiq_lower(_elr: u64, _spsr: u64) {
61     eprintln!("fiq_lower");
62     reboot();
63 }
64 
65 #[no_mangle]
serr_lower(_elr: u64, _spsr: u64)66 extern "C" fn serr_lower(_elr: u64, _spsr: u64) {
67     eprintln!("serr_lower");
68     print_esr();
69     reboot();
70 }
71 
72 #[inline]
print_esr()73 fn print_esr() {
74     let mut esr: u64;
75     unsafe {
76         asm!("mrs {esr}, esr_el1", esr = out(reg) esr);
77     }
78     eprintln!("esr={:#08x}", esr);
79 }
80