2018-05-24 11:35:24 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2018 Freie Universität Berlin
|
2020-03-07 17:04:06 +01:00
|
|
|
* Copyright (C) 2020 Inria
|
|
|
|
* Copyright (C) 2020 Koen Zandberg <koen@bergzand.net>
|
2018-05-24 11:35:24 +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_nrf5x_common
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief nrfx compatibility layer
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
2020-03-07 17:04:06 +01:00
|
|
|
* @author Koen Zandberg <koen@bergzand.net>
|
2018-05-24 11:35:24 +02:00
|
|
|
*/
|
|
|
|
|
2022-03-22 08:53:37 +01:00
|
|
|
#ifndef NRFX_RIOT_H
|
|
|
|
#define NRFX_RIOT_H
|
2018-05-24 11:35:24 +02:00
|
|
|
|
2021-10-20 11:34:39 +02:00
|
|
|
#include "kernel_defines.h"
|
2018-05-24 11:35:24 +02:00
|
|
|
#include "cpu_conf.h"
|
2020-03-07 17:04:06 +01:00
|
|
|
#include "periph_conf.h"
|
2018-05-24 11:35:24 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-03-07 17:04:06 +01:00
|
|
|
/**
|
|
|
|
* @brief Enable the internal DC/DC power converter for the NRF5x MCU.
|
|
|
|
*
|
2021-02-12 10:57:19 +01:00
|
|
|
* In most cases, the internal DC/DC converter is more efficient compared to the
|
|
|
|
* LDO regulator. The downside of the DC/DC converter is that it requires an
|
|
|
|
* external LC filter to be present on the board. Per default, the DC/DC
|
|
|
|
* converter is enabled if an LC filter is present (VDD_LC_FILTER_REGx feature).
|
|
|
|
*
|
|
|
|
* Independent of the presence of the LC filter, the DC/DC converter(s) can be
|
|
|
|
* disabled by blacklisting the VDD_LC_FILTER_REGx feature, e.g. build using
|
|
|
|
* `FEATURES_BLACKLIST=VDD_LC_FILTER_REG1 make all`.
|
2020-03-07 17:04:06 +01:00
|
|
|
*/
|
|
|
|
static inline void nrfx_dcdc_init(void)
|
|
|
|
{
|
2021-02-12 10:57:19 +01:00
|
|
|
if (IS_ACTIVE(MODULE_VDD_LC_FILTER_REG1)) {
|
|
|
|
NRF_POWER->DCDCEN = 1;
|
|
|
|
}
|
2021-01-20 12:41:32 +01:00
|
|
|
|
2021-02-14 00:06:34 +01:00
|
|
|
#ifdef POWER_DCDCEN0_DCDCEN_Msk
|
2021-02-12 10:57:19 +01:00
|
|
|
/* on CPUs that support high voltage power supply via VDDH and thus use a
|
|
|
|
* two stage regulator, we also try to enable the DC/DC converter for the
|
|
|
|
* first stage */
|
|
|
|
if (IS_ACTIVE(MODULE_VDD_LC_FILTER_REG0) &&
|
|
|
|
(NRF_POWER->MAINREGSTATUS == POWER_MAINREGSTATUS_MAINREGSTATUS_High)) {
|
2021-01-20 12:41:32 +01:00
|
|
|
NRF_POWER->DCDCEN0 = 1;
|
|
|
|
}
|
|
|
|
#endif
|
2020-03-07 17:04:06 +01:00
|
|
|
}
|
2018-05-24 11:35:24 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2022-03-22 08:53:37 +01:00
|
|
|
#endif /* NRFX_RIOT_H */
|
2018-05-24 11:35:24 +02:00
|
|
|
/** @} */
|