blob: b5a406c062e7eb86b3588aa00a62b3e5038ebfc2 [file] [log] [blame]
/*
* 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
);
#else
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();
#endif
}
enum vreg_voltage vreg_get_voltage(void) {
#if PICO_RP2040
return (vreg_and_chip_reset_hw->vreg & VREG_AND_CHIP_RESET_VREG_VSEL_BITS) >> VREG_AND_CHIP_RESET_VREG_VSEL_LSB;
#else
return (powman_hw->vreg & POWMAN_VREG_VSEL_BITS) >> POWMAN_VREG_VSEL_LSB;
#endif
}
void vreg_disable_voltage_limit(void) {
#if PICO_RP2040
// The voltage limit can't be disabled on RP2040 (was implemented by hard-wiring the LDO controls)
#else
hw_set_bits(&powman_hw->vreg_ctrl, POWMAN_PASSWORD_BITS | POWMAN_VREG_CTRL_DISABLE_VOLTAGE_LIMIT_BITS);
#endif
}