2018-09-05 02:39:50 +02:00
|
|
|
/*
|
2019-09-05 13:35:58 +02:00
|
|
|
* Copyright (C) 2019 Gunar Schorcht
|
2018-09-05 02:39:50 +02: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_esp8266
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Implementation of the CPU initialization
|
|
|
|
*
|
|
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdarg.h>
|
2018-09-05 02:39:50 +02:00
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "kernel_init.h"
|
|
|
|
#include "periph/init.h"
|
2019-09-05 13:35:58 +02:00
|
|
|
#include "periph/uart.h"
|
2018-09-05 02:39:50 +02:00
|
|
|
|
|
|
|
#include "board.h"
|
2019-09-05 13:35:58 +02:00
|
|
|
|
|
|
|
#include "esp/common_macros.h"
|
|
|
|
#include "esp_log.h"
|
2020-03-19 13:59:45 +01:00
|
|
|
#include "esp_system.h"
|
2018-09-05 02:39:50 +02:00
|
|
|
#include "exceptions.h"
|
2019-09-14 11:18:18 +02:00
|
|
|
#include "stdio_base.h"
|
2018-09-05 02:39:50 +02:00
|
|
|
#include "syscalls.h"
|
|
|
|
#include "thread_arch.h"
|
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
#include "rom_functions.h"
|
2018-09-05 02:39:50 +02:00
|
|
|
#include "sdk/sdk.h"
|
|
|
|
|
|
|
|
#if MODULE_ESP_GDBSTUB
|
2019-09-05 13:35:58 +02:00
|
|
|
#include "gdbstub.h"
|
2018-09-05 02:39:50 +02:00
|
|
|
#endif
|
|
|
|
|
2020-10-22 01:07:14 +02:00
|
|
|
#define ENABLE_DEBUG 0
|
|
|
|
#include "debug.h"
|
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
/* external esp function declarations */
|
|
|
|
extern uint32_t hwrand (void);
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
void esp_riot_init(void)
|
2018-09-05 02:39:50 +02:00
|
|
|
{
|
2020-03-19 13:59:45 +01:00
|
|
|
/* clear RTC bss data */
|
|
|
|
extern uint8_t _rtc_bss_start, _rtc_bss_end;
|
|
|
|
esp_reset_reason_t reset_reason = esp_reset_reason();
|
|
|
|
if (reset_reason != ESP_RST_DEEPSLEEP && reset_reason != ESP_RST_SW) {
|
|
|
|
memset(&_rtc_bss_start, 0, (&_rtc_bss_end - &_rtc_bss_start));
|
|
|
|
}
|
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
/* enable cached read from flash */
|
|
|
|
Cache_Read_Enable_New();
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
/* initialize the ISR stack for usage measurements */
|
|
|
|
thread_isr_stack_init();
|
2018-12-26 15:42:09 +01:00
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
#ifndef MCU_ESP8266
|
|
|
|
/* initialize newlib system calls */
|
2018-09-05 02:39:50 +02:00
|
|
|
syscalls_init ();
|
2019-09-05 13:35:58 +02:00
|
|
|
#endif
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
/* set system frequency if not 80 MHz */
|
|
|
|
if (ESP8266_CPU_FREQUENCY != 80) {
|
|
|
|
system_update_cpu_freq(ESP8266_CPU_FREQUENCY);
|
2018-09-05 02:39:50 +02:00
|
|
|
}
|
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
ets_printf("\n");
|
2019-12-06 18:56:04 +01:00
|
|
|
#ifdef MODULE_ESP_LOG_STARTUP
|
2019-09-05 13:35:58 +02:00
|
|
|
ets_printf("Starting ESP8266 CPU with ID: %08x\n", system_get_chip_id());
|
|
|
|
ets_printf("ESP8266-RTOS-SDK Version %s\n\n", system_get_sdk_version());
|
|
|
|
ets_printf("CPU clock frequency: %d MHz\n", system_get_cpu_freq());
|
|
|
|
extern void heap_stats(void);
|
|
|
|
heap_stats();
|
2019-12-06 18:56:04 +01:00
|
|
|
#endif
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
/* set exception handlers */
|
2018-09-05 02:39:50 +02:00
|
|
|
init_exceptions ();
|
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
/* systemwide UART initialization */
|
|
|
|
extern void uart_system_init (void);
|
|
|
|
uart_system_init();
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
/* init watchdogs */
|
|
|
|
system_wdt_init();
|
2018-09-05 02:39:50 +02:00
|
|
|
|
|
|
|
/* init random number generator */
|
|
|
|
srand(hwrand());
|
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
#if MODULE_MTD
|
2018-09-05 02:39:50 +02:00
|
|
|
/* init flash drive */
|
2019-09-05 13:35:58 +02:00
|
|
|
extern void spi_flash_drive_init (void);
|
|
|
|
spi_flash_drive_init();
|
|
|
|
#endif
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2019-09-14 11:18:18 +02:00
|
|
|
/* initialize stdio*/
|
2019-12-27 10:22:29 +01:00
|
|
|
extern int stdio_is_initialized;
|
2019-09-14 11:18:18 +02:00
|
|
|
stdio_init();
|
2019-12-27 10:22:29 +01:00
|
|
|
stdio_is_initialized = 1;
|
2019-09-14 11:18:18 +02:00
|
|
|
|
2018-09-05 02:39:50 +02:00
|
|
|
/* trigger static peripheral initialization */
|
|
|
|
periph_init();
|
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
/* trigger board initialization */
|
2018-09-05 02:39:50 +02:00
|
|
|
board_init();
|
|
|
|
|
2019-12-06 18:56:04 +01:00
|
|
|
#ifdef MODULE_ESP_LOG_STARTUP
|
2018-09-05 02:39:50 +02:00
|
|
|
/* print the board config */
|
|
|
|
board_print_config();
|
2019-12-27 10:22:29 +01:00
|
|
|
#else
|
|
|
|
/* to have an empty line after the unreadable characters from ROM loader */
|
|
|
|
puts("");
|
2019-12-06 18:56:04 +01:00
|
|
|
#endif
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
/* initialize ESP system event loop */
|
|
|
|
extern void esp_event_handler_init(void);
|
|
|
|
esp_event_handler_init();
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
/* activate software interrupt based context switch */
|
2018-09-05 02:39:50 +02:00
|
|
|
extern void IRAM thread_yield_isr(void* arg);
|
|
|
|
ets_isr_attach(ETS_SOFT_INUM, thread_yield_isr, NULL);
|
|
|
|
ets_isr_unmask(BIT(ETS_SOFT_INUM));
|
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
#ifdef MODULE_ESP_GDBSTUB
|
|
|
|
gdbstub_init();
|
|
|
|
#endif
|
2018-09-05 02:39:50 +02:00
|
|
|
}
|
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
void esp_riot_start(void)
|
2018-09-05 02:39:50 +02:00
|
|
|
{
|
2019-09-05 13:35:58 +02:00
|
|
|
/* does not return */
|
|
|
|
kernel_init();
|
2018-09-05 02:39:50 +02:00
|
|
|
}
|
2019-10-23 00:54:04 +02:00
|
|
|
|
|
|
|
void __wrap_pp_attach(void)
|
|
|
|
{
|
|
|
|
#ifdef MODULE_ESP_WIFI_ANY
|
|
|
|
extern void __real_pp_attach(void);
|
|
|
|
__real_pp_attach();
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
void __wrap_pm_attach(void)
|
|
|
|
{
|
|
|
|
#ifdef MODULE_ESP_WIFI_ANY
|
|
|
|
extern void __real_pm_attach(void);
|
|
|
|
__real_pm_attach();
|
|
|
|
#endif
|
|
|
|
}
|