1
0
Fork 0
mirror of https://github.com/betaflight/betaflight.git synced 2025-07-15 12:25:20 +03:00
betaflight/lib/main/pico-sdk/rp2_common/hardware_vreg/vreg.c
J Blackman 2dd6f95aad
Adding RP2350 SDK and target framework (#13988)
* Adding RP2350 SDK and target framework

* Spacing

* Removing board definitions
2024-10-23 01:02:48 +02:00

50 lines
1.3 KiB
C

/*
* Copyright (c) 2020 Raspberry Pi (Trading) Ltd.
*
* SPDX-License-Identifier: BSD-3-Clause
*/
#include "pico.h"
#include "hardware/vreg.h"
void vreg_set_voltage(enum vreg_voltage voltage) {
#if PICO_RP2040
hw_write_masked(
&vreg_and_chip_reset_hw->vreg,
((uint)voltage) << VREG_AND_CHIP_RESET_VREG_VSEL_LSB,
VREG_AND_CHIP_RESET_VREG_VSEL_BITS
);
#elif PICO_RP2350
hw_set_bits(&powman_hw->vreg_ctrl, POWMAN_PASSWORD_BITS | POWMAN_VREG_CTRL_UNLOCK_BITS);
// Wait for any prior change to finish before making a new change
while (powman_hw->vreg & POWMAN_VREG_UPDATE_IN_PROGRESS_BITS)
tight_loop_contents();
hw_write_masked(
&powman_hw->vreg,
POWMAN_PASSWORD_BITS | ((uint)voltage << POWMAN_VREG_VSEL_LSB),
POWMAN_PASSWORD_BITS | POWMAN_VREG_VSEL_BITS
);
while (powman_hw->vreg & POWMAN_VREG_UPDATE_IN_PROGRESS_BITS)
tight_loop_contents();
#else
panic_unsupported();
#endif
}
void vreg_disable_voltage_limit(void) {
#if PICO_RP2040
// The voltage limit can't be disabled on RP2040 (was implemented by
// hardwiring the LDO controls)
return;
#elif PICO_RP2350
hw_set_bits(&powman_hw->vreg_ctrl, POWMAN_PASSWORD_BITS | POWMAN_VREG_CTRL_DISABLE_VOLTAGE_LIMIT_BITS);
#else
panic_unsupported();
#endif
}