1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/cpu/lpc2387/include/cpu.h
Benjamin Valentin 76e19602a2 cpu/lpc2387: rename cpu_woke_from_backup()
The function would always return `true` after early boot, so it
is not very useful for applications.

Now it will only (but always) return true when we woke from Deep Sleep
*after* early boot. This makes it behave the same ways as the function
of the same name on SAME54.

Rename the existing function to cpu_backup_ram_is_initialized() to better
match it's semantics.
2020-02-10 23:04:47 +01:00

83 lines
1.6 KiB
C

/*
* Copyright (C) 2013, Freie Universitaet Berlin (FUB). All rights reserved.
*
* 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.
*/
#ifndef CPU_H
#define CPU_H
/**
* @defgroup cpu_lpc2387 NXP LPC2387
* @ingroup cpu
* @brief NXP LPC2387 specific code
* @{
*/
#include <stdio.h>
#include <stdbool.h>
#include "lpc2387.h"
#include "arm_cpu.h"
#ifdef __cplusplus
extern "C" {
#endif
extern uintptr_t __stack_start; /**< end of user stack memory space */
/**
* @brief Scale lpc2387 cpu speed
*/
void lpc2387_pclk_scale(uint32_t source, uint32_t target, uint32_t *pclksel, uint32_t *prescale);
/**
* @brief Initialize lpc2387 cpu clocks
*/
void cpu_init_clks(void);
/**
* @brief install lpc2387 irq
*/
bool install_irq(int IntNumber, void (*HandlerAddr)(void), int Priority);
#ifdef MODULE_PERIPH
void gpio_init_ports(void);
#endif
/**
* @brief Prints the current content of the link register (lr)
*/
static inline void cpu_print_last_instruction(void)
{
register uint32_t *lr_ptr;
__asm__ __volatile__("mov %0, lr" : "=r"(lr_ptr));
printf("%p\n", (void*) lr_ptr);
}
/**
* @brief Returns true if the CPU woke from Deep Sleep
*/
static inline bool cpu_woke_from_backup(void) {
return RSIR == 0;
}
/**
* @brief Returns true if the backup RAM has been initialized
*/
bool cpu_backup_ram_is_initialized(void);
/**
* @brief The CPU has RAM that is retained in the deepest sleep mode.
*/
#define CPU_HAS_BACKUP_RAM (1)
#ifdef __cplusplus
}
#endif
/** @} */
#endif /* CPU_H */