| /** |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| |
| #include <console/console.h> |
| #include <hal/hal_system.h> |
| #include "os/os.h" |
| |
| #include <stdint.h> |
| #include <unistd.h> |
| |
| int os_die_line; |
| const char *os_die_module; |
| |
| void __assert_func(const char *file, int line, const char *func, const char *e); |
| |
| void |
| __assert_func(const char *file, int line, const char *func, const char *e) |
| { |
| int sr; |
| |
| OS_ENTER_CRITICAL(sr); |
| (void)sr; |
| os_die_line = line; |
| os_die_module = file; |
| console_blocking_mode(); |
| console_printf("Assert %s; failed in %s:%d\n", e ? e : "", file, line); |
| system_reset(); |
| } |
| |
| struct exception_frame { |
| uint32_t r0; |
| uint32_t r1; |
| uint32_t r2; |
| uint32_t r3; |
| uint32_t r12; |
| uint32_t lr; |
| uint32_t pc; |
| uint32_t psr; |
| }; |
| |
| struct trap_frame { |
| struct exception_frame *ef; |
| uint32_t r4; |
| uint32_t r5; |
| uint32_t r6; |
| uint32_t r7; |
| uint32_t r8; |
| uint32_t r9; |
| uint32_t r10; |
| uint32_t r11; |
| uint32_t lr; /* this LR holds EXC_RETURN */ |
| }; |
| |
| void |
| os_default_irq(struct trap_frame *tf) |
| { |
| console_blocking_mode(); |
| console_printf("Unhandled interrupt (%ld), exception sp 0x%08lx\n", |
| SCB->ICSR & SCB_ICSR_VECTACTIVE_Msk, (uint32_t)tf->ef); |
| console_printf(" r0:0x%08lx r1:0x%08lx r2:0x%08lx r3:0x%08lx\n", |
| tf->ef->r0, tf->ef->r1, tf->ef->r2, tf->ef->r3); |
| console_printf(" r4:0x%08lx r5:0x%08lx r6:0x%08lx r7:0x%08lx\n", |
| tf->r4, tf->r5, tf->r6, tf->r7); |
| console_printf(" r8:0x%08lx r9:0x%08lx r10:0x%08lx r11:0x%08lx\n", |
| tf->r8, tf->r9, tf->r10, tf->r11); |
| console_printf("r12:0x%08lx lr:0x%08lx pc:0x%08lx psr:0x%08lx\n", |
| tf->ef->r12, tf->ef->lr, tf->ef->pc, tf->ef->psr); |
| console_printf("ICSR:0x%08lx ",SCB->ICSR); |
| system_reset(); |
| } |
| |