2021-01-02 15:36:29 +01:00
|
|
|
|
/*
|
|
|
|
|
* Copyright (C) 2014 Freie Universität Berlin, Hinnerk van Bruinehsen
|
|
|
|
|
* 2017 RWTH Aachen, Josua Arndt
|
|
|
|
|
* 2018 Matthew Blue
|
2023-06-29 17:18:21 +02:00
|
|
|
|
* 2021-2023 Gerson Fernando Budke
|
2023-06-22 11:24:30 +02:00
|
|
|
|
* 2023 Hugues Larrive
|
2021-01-02 15:36:29 +01:00
|
|
|
|
*
|
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
|
* directory for more details.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @ingroup cpu_atmega_common
|
|
|
|
|
* @{
|
|
|
|
|
*
|
|
|
|
|
* @file
|
|
|
|
|
* @brief Implementation of the CPU initialization
|
|
|
|
|
*
|
|
|
|
|
* @author Hinnerk van Bruinehsen <h.v.bruinehsen@fu-berlin.de>
|
|
|
|
|
* @author Steffen Robertz <steffen.robertz@rwth-aachen.de>
|
|
|
|
|
* @author Josua Arndt <jarndt@ias.rwth-aachen.de>
|
|
|
|
|
* @author Matthew Blue <matthew.blue.neuro@gmail.com>
|
|
|
|
|
* @author Francisco Acosta <francisco.acosta@inria.fr>
|
|
|
|
|
* @author Gerson Fernando Budke <nandojve@gmail.com>
|
2023-06-22 11:24:30 +02:00
|
|
|
|
* @author Hugues Larrive <hugues.larrive@pm.me>
|
2021-01-02 15:36:29 +01:00
|
|
|
|
*
|
|
|
|
|
* @}
|
|
|
|
|
*/
|
|
|
|
|
|
2021-08-27 17:06:50 +02:00
|
|
|
|
#include "board.h"
|
2021-01-02 15:36:29 +01:00
|
|
|
|
#include "cpu.h"
|
2023-06-29 17:18:21 +02:00
|
|
|
|
#include "irq_arch.h"
|
2021-01-02 15:36:29 +01:00
|
|
|
|
#include "panic.h"
|
2023-07-12 14:52:05 +02:00
|
|
|
|
#include "sys/bus.h"
|
2021-01-02 15:36:29 +01:00
|
|
|
|
|
|
|
|
|
#define ENABLE_DEBUG 0
|
|
|
|
|
#include "debug.h"
|
|
|
|
|
|
2021-08-27 17:06:50 +02:00
|
|
|
|
#ifndef CPU_ATMEGA_CLK_SCALE_INIT
|
|
|
|
|
#define CPU_ATMEGA_CLK_SCALE_INIT CPU_ATMEGA_CLK_SCALE_DIV1
|
|
|
|
|
#endif
|
|
|
|
|
|
2021-01-02 15:36:29 +01:00
|
|
|
|
extern uint8_t mcusr_mirror;
|
|
|
|
|
extern uint8_t soft_rst;
|
|
|
|
|
|
2021-01-02 18:40:07 +01:00
|
|
|
|
void avr8_reset_cause(void)
|
2021-01-02 15:36:29 +01:00
|
|
|
|
{
|
|
|
|
|
if (mcusr_mirror & (1 << PORF)) {
|
|
|
|
|
DEBUG("Power-on reset.\n");
|
|
|
|
|
}
|
|
|
|
|
if (mcusr_mirror & (1 << EXTRF)) {
|
|
|
|
|
DEBUG("External reset!\n");
|
|
|
|
|
}
|
|
|
|
|
if (mcusr_mirror & (1 << BORF)) {
|
|
|
|
|
DEBUG("Brownout reset!\n");
|
|
|
|
|
}
|
|
|
|
|
if (mcusr_mirror & (1 << WDRF)) {
|
|
|
|
|
if (soft_rst & 0xAA) {
|
|
|
|
|
DEBUG("Software reset!\n");
|
|
|
|
|
} else {
|
|
|
|
|
DEBUG("Watchdog reset!\n");
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-06-22 11:24:30 +02:00
|
|
|
|
#if defined(JTRF)
|
2021-01-02 15:36:29 +01:00
|
|
|
|
if (mcusr_mirror & (1 << JTRF)) {
|
|
|
|
|
DEBUG("JTAG reset!\n");
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-27 17:06:50 +02:00
|
|
|
|
void __attribute__((weak)) avr8_clk_init(void)
|
|
|
|
|
{
|
2023-06-22 11:24:30 +02:00
|
|
|
|
#if defined(CLKPR)
|
2021-08-27 17:06:50 +02:00
|
|
|
|
atmega_set_prescaler(CPU_ATMEGA_CLK_SCALE_INIT);
|
2023-06-22 11:24:30 +02:00
|
|
|
|
#endif
|
2021-08-27 17:06:50 +02:00
|
|
|
|
}
|
|
|
|
|
|
2021-01-02 15:36:29 +01:00
|
|
|
|
/* This is a vector which is aliased to __vector_default,
|
|
|
|
|
* the vector executed when an ISR fires with no accompanying
|
|
|
|
|
* ISR handler. This may be used along with the ISR() macro to
|
|
|
|
|
* create a catch-all for undefined but used ISRs for debugging
|
|
|
|
|
* purposes.
|
|
|
|
|
* SCIRQS – Symbol Counter Interrupt Status Register
|
|
|
|
|
* BATMON – Battery Monitor Control and Status Register
|
|
|
|
|
* IRQ_STATUS /1 – Transceiver Interrupt Status Register
|
|
|
|
|
* EIFR – External Interrupt Flag Register
|
|
|
|
|
* PCIFR – Pin Change Interrupt Flag Register
|
|
|
|
|
*/
|
2023-06-29 17:18:21 +02:00
|
|
|
|
ISR(BADISR_vect, ISR_NAKED)
|
2021-01-02 15:36:29 +01:00
|
|
|
|
{
|
2021-01-02 18:40:07 +01:00
|
|
|
|
avr8_reset_cause();
|
2021-01-02 15:36:29 +01:00
|
|
|
|
|
2023-06-22 11:24:30 +02:00
|
|
|
|
#if defined(TRX_CTRL_0) /* megaRF */
|
|
|
|
|
printf("IRQ_STATUS %#02x\n", (unsigned int)IRQ_STATUS);
|
|
|
|
|
|
|
|
|
|
#if defined(IRQ_STATUS1)
|
|
|
|
|
printf("IRQ_STATUS1 %#02x\n", (unsigned int)IRQ_STATUS1);
|
|
|
|
|
#endif
|
2021-01-02 15:36:29 +01:00
|
|
|
|
|
|
|
|
|
printf("SCIRQS %#02x\nBATMON %#02x\n", (unsigned int)SCIRQS, (unsigned int)BATMON);
|
|
|
|
|
|
|
|
|
|
printf("EIFR %#02x\nPCIFR %#02x\n", (unsigned int)EIFR, (unsigned int)PCIFR);
|
|
|
|
|
#endif
|
|
|
|
|
#ifdef LED_PANIC
|
|
|
|
|
/* Use LED light to signal ERROR. */
|
|
|
|
|
LED_PANIC;
|
|
|
|
|
#endif
|
|
|
|
|
|
2021-09-30 15:25:21 +02:00
|
|
|
|
core_panic(PANIC_GENERAL_ERROR, "BADISR");
|
2021-01-02 15:36:29 +01:00
|
|
|
|
}
|
|
|
|
|
|
2023-06-22 11:24:30 +02:00
|
|
|
|
#if defined(BAT_LOW_vect)
|
2023-07-12 14:52:05 +02:00
|
|
|
|
static inline void bat_low_handler(void)
|
|
|
|
|
{
|
|
|
|
|
DEBUG("BAT_LOW\n");
|
|
|
|
|
|
|
|
|
|
#if MODULE_SYS_BUS_POWER
|
|
|
|
|
msg_bus_t *bus = sys_bus_get(SYS_BUS_POWER);
|
|
|
|
|
msg_bus_post(bus, SYS_BUS_POWER_EVENT_LOW_VOLTAGE, NULL);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
AVR8_ISR(BAT_LOW_vect, bat_low_handler);
|
2021-01-02 15:36:29 +01:00
|
|
|
|
#endif
|