mirror of
https://github.com/UpsilonNumworks/Upsilon.git
synced 2026-03-30 12:10:03 +02:00
[ion] Power: move clock configuration in sleep mode from Power to Board::initClock
This commit is contained in:
@@ -129,6 +129,81 @@ void initClocks() {
|
||||
apb2enr.setSDIOEN(true);
|
||||
#endif
|
||||
RCC.APB2ENR()->set(apb2enr);
|
||||
|
||||
// AHB1 peripheral clock enable in low-power mode register
|
||||
class RCC::AHB1LPENR ahb1lpenr(0x006190FF); // Reset value
|
||||
ahb1lpenr.setGPIOALPEN(true); // Enable IO port A for Charging/USB plug/Keyboard pins
|
||||
ahb1lpenr.setGPIOBLPEN(true); // Enable IO port B for LED pins
|
||||
ahb1lpenr.setGPIOCLPEN(true); // Enable IO port C for LED/Keyboard pins
|
||||
ahb1lpenr.setGPIODLPEN(false); // Disable IO port D (LCD...)
|
||||
ahb1lpenr.setGPIOELPEN(true); // Enable IO port E for Keyboard/Battery pins
|
||||
ahb1lpenr.setGPIOFLPEN(false); // Disable IO port F
|
||||
ahb1lpenr.setGPIOGLPEN(false); // Disable IO port G
|
||||
ahb1lpenr.setGPIOHLPEN(false); // Disable IO port H
|
||||
ahb1lpenr.setGPIOILPEN(false); // Disable IO port I
|
||||
ahb1lpenr.setCRCLPEN(false);
|
||||
ahb1lpenr.setFLITFLPEN(false);
|
||||
ahb1lpenr.setSRAM1LPEN(false);
|
||||
ahb1lpenr.setDMA1LPEN(false);
|
||||
ahb1lpenr.setDMA2LPEN(false);
|
||||
RCC.AHB1LPENR()->set(ahb1lpenr);
|
||||
|
||||
// AHB2 peripheral clock enable in low-power mode register
|
||||
class RCC::AHB2LPENR ahb2lpenr(0x000000C0); // Reset value
|
||||
ahb2lpenr.setOTGFSLPEN(false);
|
||||
ahb2lpenr.setRNGLPEN(false);
|
||||
RCC.AHB2LPENR()->set(ahb2lpenr);
|
||||
|
||||
// AHB3 peripheral clock enable in low-power mode register
|
||||
class RCC::AHB3LPENR ahb3lpenr(0x00000003); // Reset value
|
||||
ahb3lpenr.setFMCLPEN(false);
|
||||
ahb3lpenr.setQSPILPEN(false);
|
||||
RCC.AHB3LPENR()->set(ahb3lpenr);
|
||||
|
||||
// APB1 peripheral clock enable in low-power mode register
|
||||
class RCC::APB1LPENR apb1lpenr(0x17E6CDFF); // Reset value
|
||||
apb1lpenr.setTIM2LPEN(false);
|
||||
apb1lpenr.setTIM3LPEN(true); // Enable TIM3 in sleep mode for LEDs
|
||||
apb1lpenr.setTIM4LPEN(false);
|
||||
apb1lpenr.setTIM5LPEN(false);
|
||||
apb1lpenr.setTIM6LPEN(false);
|
||||
apb1lpenr.setTIM7LPEN(false);
|
||||
apb1lpenr.setTIM12LPEN(false);
|
||||
apb1lpenr.setTIM13LPEN(false);
|
||||
apb1lpenr.setTIM14LPEN(false);
|
||||
apb1lpenr.setRTCAPBLPEN(false);
|
||||
apb1lpenr.setWWDGLPEN(false);
|
||||
apb1lpenr.setSPI2LPEN(false);
|
||||
apb1lpenr.setSPI3LPEN(false);
|
||||
apb1lpenr.setUSART2LPEN(false);
|
||||
apb1lpenr.setUSART3LPEN(false);
|
||||
apb1lpenr.setI2C1LPEN(false);
|
||||
apb1lpenr.setI2C2LPEN(false);
|
||||
apb1lpenr.setI2C3LPEN(false);
|
||||
apb1lpenr.setCAN1LPEN(false);
|
||||
apb1lpenr.setPWRLPEN(false);
|
||||
apb1lpenr.setI2CFMP1LPEN(false);
|
||||
apb1lpenr.setCAN2LPEN(false);
|
||||
RCC.APB1LPENR()->set(apb1lpenr);
|
||||
|
||||
// APB2 peripheral clock enable in low-power mode register
|
||||
class RCC::APB2LPENR apb2lpenr(0x0117F933); // Reset value
|
||||
apb2lpenr.setTIM1LPEN(false);
|
||||
apb2lpenr.setTIM8LPEN(false);
|
||||
apb2lpenr.setUSART1LPEN(false);
|
||||
apb2lpenr.setUSART6LPEN(false);
|
||||
apb2lpenr.setADC1LPEN(false);
|
||||
apb2lpenr.setSPI1LPEN(false);
|
||||
apb2lpenr.setSPI4LPEN(false);
|
||||
apb2lpenr.setSYSCFGLPEN(false);
|
||||
apb2lpenr.setTIM9LPEN(false);
|
||||
apb2lpenr.setTIM10LPEN(false);
|
||||
apb2lpenr.setTIM11LPEN(false);
|
||||
apb2lpenr.setSPI5LPEN(false);
|
||||
apb2lpenr.setSDIOLPEN(false);
|
||||
apb2lpenr.setEXTITEN(false);
|
||||
apb2lpenr.setDFSDM1LPEN(false);
|
||||
RCC.APB2LPENR()->set(apb2lpenr);
|
||||
}
|
||||
|
||||
void shutdownClocks(bool keepLEDAwake) {
|
||||
|
||||
@@ -221,6 +221,94 @@ void initClocks() {
|
||||
apb2enr.setSYSCFGEN(true);
|
||||
apb2enr.setUSART6EN(true); // TODO if EPSILON_DEVICE_BENCH?
|
||||
RCC.APB2ENR()->set(apb2enr);
|
||||
|
||||
// Configure clocks in sleep mode
|
||||
// AHB1 peripheral clock enable in low-power mode register
|
||||
class RCC::AHB1LPENR ahb1lpenr(0x7EF7B7FF); // Reset value
|
||||
ahb1lpenr.setGPIOALPEN(true); // Enable IO port A for Charging/USB plug/Keyboard pins
|
||||
ahb1lpenr.setGPIOBLPEN(true); // Enable IO port B for LED pins
|
||||
ahb1lpenr.setGPIOCLPEN(true); // Enable IO port C for LED/Keyboard pins
|
||||
ahb1lpenr.setGPIODLPEN(false); // Disable IO port D (LCD...)
|
||||
ahb1lpenr.setGPIOELPEN(true); // Enable IO port E for Keyboard/Battery pins
|
||||
ahb1lpenr.setGPIOFLPEN(false); // Disable IO port F
|
||||
ahb1lpenr.setGPIOGLPEN(false); // Disable IO port G
|
||||
ahb1lpenr.setGPIOHLPEN(false); // Disable IO port H
|
||||
ahb1lpenr.setGPIOILPEN(false); // Disable IO port I
|
||||
ahb1lpenr.setCRCLPEN(false);
|
||||
ahb1lpenr.setFLITFLPEN(false);
|
||||
ahb1lpenr.setSRAM1LPEN(false);
|
||||
ahb1lpenr.setDMA1LPEN(false);
|
||||
ahb1lpenr.setDMA2LPEN(false);
|
||||
ahb1lpenr.setAXILPEN(false);
|
||||
ahb1lpenr.setSRAM2LPEN(false);
|
||||
ahb1lpenr.setBKPSRAMLPEN(false);
|
||||
ahb1lpenr.setDTCMLPEN(false);
|
||||
ahb1lpenr.setOTGHSLPEN(false);
|
||||
ahb1lpenr.setOTGHSULPILPEN(false);
|
||||
RCC.AHB1LPENR()->set(ahb1lpenr);
|
||||
|
||||
// AHB2 peripheral clock enable in low-power mode register
|
||||
class RCC::AHB2LPENR ahb2lpenr(0x000000F1); // Reset value
|
||||
ahb2lpenr.setOTGFSLPEN(false);
|
||||
ahb2lpenr.setRNGLPEN(false);
|
||||
ahb2lpenr.setAESLPEN(false);
|
||||
RCC.AHB2LPENR()->set(ahb2lpenr);
|
||||
|
||||
// AHB3 peripheral clock enable in low-power mode register
|
||||
class RCC::AHB3LPENR ahb3lpenr(0x00000003); // Reset value
|
||||
ahb3lpenr.setFMCLPEN(false);
|
||||
ahb3lpenr.setQSPILPEN(false);
|
||||
RCC.AHB3LPENR()->set(ahb3lpenr);
|
||||
|
||||
// APB1 peripheral clock enable in low-power mode register
|
||||
class RCC::APB1LPENR apb1lpenr(0xFFFFCBFF); // Reset value
|
||||
apb1lpenr.setTIM2LPEN(false);
|
||||
apb1lpenr.setTIM3LPEN(true); // Enable TIM3 in sleep mode for LEDs
|
||||
apb1lpenr.setTIM4LPEN(false);
|
||||
apb1lpenr.setTIM5LPEN(false);
|
||||
apb1lpenr.setTIM6LPEN(false);
|
||||
apb1lpenr.setTIM7LPEN(false);
|
||||
apb1lpenr.setTIM12LPEN(false);
|
||||
apb1lpenr.setTIM13LPEN(false);
|
||||
apb1lpenr.setTIM14LPEN(false);
|
||||
apb1lpenr.setRTCAPBLPEN(false);
|
||||
apb1lpenr.setWWDGLPEN(false);
|
||||
apb1lpenr.setSPI2LPEN(false);
|
||||
apb1lpenr.setSPI3LPEN(false);
|
||||
apb1lpenr.setUSART2LPEN(false);
|
||||
apb1lpenr.setUSART3LPEN(false);
|
||||
apb1lpenr.setI2C1LPEN(false);
|
||||
apb1lpenr.setI2C2LPEN(false);
|
||||
apb1lpenr.setI2C3LPEN(false);
|
||||
apb1lpenr.setCAN1LPEN(false);
|
||||
apb1lpenr.setPWRLPEN(false);
|
||||
apb1lpenr.setLPTIM1LPEN(false);
|
||||
apb1lpenr.setUSART4LPEN(false);
|
||||
apb1lpenr.setUSART5LPEN(false);
|
||||
apb1lpenr.setOTGHSLPEN(false);
|
||||
apb1lpenr.setOTGHSULPILPEN(false);
|
||||
RCC.APB1LPENR()->set(apb1lpenr);
|
||||
|
||||
// APB2 peripheral clock enable in low-power mode register
|
||||
class RCC::APB2LPENR apb2lpenr(0x04F77F33); // Reset value
|
||||
apb2lpenr.setTIM1LPEN(false);
|
||||
apb2lpenr.setTIM8LPEN(false);
|
||||
apb2lpenr.setUSART1LPEN(false);
|
||||
apb2lpenr.setUSART6LPEN(false);
|
||||
apb2lpenr.setADC1LPEN(false);
|
||||
apb2lpenr.setSPI1LPEN(false);
|
||||
apb2lpenr.setSPI4LPEN(false);
|
||||
apb2lpenr.setSYSCFGLPEN(false);
|
||||
apb2lpenr.setTIM9LPEN(false);
|
||||
apb2lpenr.setTIM10LPEN(false);
|
||||
apb2lpenr.setTIM11LPEN(false);
|
||||
apb2lpenr.setSPI5LPEN(false);
|
||||
apb2lpenr.setSDMMC2LPEN(false);
|
||||
apb2lpenr.setADC2LPEN(false);
|
||||
apb2lpenr.setADC3LPEN(false);
|
||||
apb2lpenr.setSAI1LPEN(false);
|
||||
apb2lpenr.setSAI2LPEN(false);
|
||||
RCC.APB2LPENR()->set(apb2lpenr);
|
||||
}
|
||||
|
||||
void shutdownClocks(bool keepLEDAwake) {
|
||||
|
||||
@@ -69,124 +69,6 @@ void sleepConfiguration() {
|
||||
while (!PWR.CSR1()->getVOSRDY()) {}
|
||||
#endif
|
||||
|
||||
// AHB1 peripheral clock enable in low-power mode register
|
||||
#if REGS_RCC_CONFIG_F730
|
||||
class RCC::AHB1LPENR ahb1lpenr(0x7EF7B7FF); // Reset value
|
||||
#elif REGS_RCC_CONFIG_F412
|
||||
class RCC::AHB1LPENR ahb1lpenr(0x006190FF); // Reset value
|
||||
#endif
|
||||
ahb1lpenr.setGPIOALPEN(true); // Enable IO port A for Charging/USB plug/Keyboard pins
|
||||
ahb1lpenr.setGPIOBLPEN(true); // Enable IO port B for LED pins
|
||||
ahb1lpenr.setGPIOCLPEN(true); // Enable IO port C for LED/Keyboard pins
|
||||
ahb1lpenr.setGPIODLPEN(false); // Disable IO port D (LCD...)
|
||||
ahb1lpenr.setGPIOELPEN(true); // Enable IO port E for Keyboard/Battery pins
|
||||
ahb1lpenr.setGPIOFLPEN(false); // Disable IO port F
|
||||
ahb1lpenr.setGPIOGLPEN(false); // Disable IO port G
|
||||
ahb1lpenr.setGPIOHLPEN(false); // Disable IO port H
|
||||
ahb1lpenr.setGPIOILPEN(false); // Disable IO port I
|
||||
ahb1lpenr.setCRCLPEN(false);
|
||||
ahb1lpenr.setFLITFLPEN(false);
|
||||
ahb1lpenr.setSRAM1LPEN(false);
|
||||
ahb1lpenr.setDMA1LPEN(false);
|
||||
ahb1lpenr.setDMA2LPEN(false);
|
||||
#if REGS_RCC_CONFIG_F730
|
||||
ahb1lpenr.setAXILPEN(false);
|
||||
ahb1lpenr.setSRAM2LPEN(false);
|
||||
ahb1lpenr.setBKPSRAMLPEN(false);
|
||||
ahb1lpenr.setDTCMLPEN(false);
|
||||
ahb1lpenr.setOTGHSLPEN(false);
|
||||
ahb1lpenr.setOTGHSULPILPEN(false);
|
||||
#endif
|
||||
RCC.AHB1LPENR()->set(ahb1lpenr);
|
||||
|
||||
// AHB2 peripheral clock enable in low-power mode register
|
||||
#if REGS_RCC_CONFIG_F730
|
||||
class RCC::AHB2LPENR ahb2lpenr(0x000000F1); // Reset value
|
||||
#elif REGS_RCC_CONFIG_F412
|
||||
class RCC::AHB2LPENR ahb2lpenr(0x000000C0); // Reset value
|
||||
#endif
|
||||
ahb2lpenr.setOTGFSLPEN(false);
|
||||
ahb2lpenr.setRNGLPEN(false);
|
||||
#if REGS_RCC_CONFIG_F730
|
||||
ahb2lpenr.setAESLPEN(false);
|
||||
#endif
|
||||
RCC.AHB2LPENR()->set(ahb2lpenr);
|
||||
|
||||
// AHB3 peripheral clock enable in low-power mode register
|
||||
class RCC::AHB3LPENR ahb3lpenr(0x00000003); // Reset value
|
||||
ahb3lpenr.setFMCLPEN(false);
|
||||
ahb3lpenr.setQSPILPEN(false);
|
||||
RCC.AHB3LPENR()->set(ahb3lpenr);
|
||||
|
||||
// APB1 peripheral clock enable in low-power mode register
|
||||
#if REGS_RCC_CONFIG_F730
|
||||
class RCC::APB1LPENR apb1lpenr(0xFFFFCBFF); // Reset value
|
||||
#elif REGS_RCC_CONFIG_F412
|
||||
class RCC::APB1LPENR apb1lpenr(0x17E6CDFF); // Reset value
|
||||
#endif
|
||||
apb1lpenr.setTIM2LPEN(false);
|
||||
apb1lpenr.setTIM3LPEN(true); // Enable TIM3 in sleep mode for LEDs
|
||||
apb1lpenr.setTIM4LPEN(false);
|
||||
apb1lpenr.setTIM5LPEN(false);
|
||||
apb1lpenr.setTIM6LPEN(false);
|
||||
apb1lpenr.setTIM7LPEN(false);
|
||||
apb1lpenr.setTIM12LPEN(false);
|
||||
apb1lpenr.setTIM13LPEN(false);
|
||||
apb1lpenr.setTIM14LPEN(false);
|
||||
apb1lpenr.setRTCAPBLPEN(false);
|
||||
apb1lpenr.setWWDGLPEN(false);
|
||||
apb1lpenr.setSPI2LPEN(false);
|
||||
apb1lpenr.setSPI3LPEN(false);
|
||||
apb1lpenr.setUSART2LPEN(false);
|
||||
apb1lpenr.setUSART3LPEN(false);
|
||||
apb1lpenr.setI2C1LPEN(false);
|
||||
apb1lpenr.setI2C2LPEN(false);
|
||||
apb1lpenr.setI2C3LPEN(false);
|
||||
apb1lpenr.setCAN1LPEN(false);
|
||||
apb1lpenr.setPWRLPEN(false);
|
||||
#if REGS_RCC_CONFIG_F730
|
||||
apb1lpenr.setLPTIM1LPEN(false);
|
||||
apb1lpenr.setUSART4LPEN(false);
|
||||
apb1lpenr.setUSART5LPEN(false);
|
||||
apb1lpenr.setOTGHSLPEN(false);
|
||||
apb1lpenr.setOTGHSULPILPEN(false);
|
||||
#elif REGS_RCC_CONFIG_F412
|
||||
apb1lpenr.setI2CFMP1LPEN(false);
|
||||
apb1lpenr.setCAN2LPEN(false);
|
||||
#endif
|
||||
RCC.APB1LPENR()->set(apb1lpenr);
|
||||
|
||||
// APB2 peripheral clock enable in low-power mode register
|
||||
#if REGS_RCC_CONFIG_F730
|
||||
class RCC::APB2LPENR apb2lpenr(0x04F77F33); // Reset value
|
||||
#elif REGS_RCC_CONFIG_F412
|
||||
class RCC::APB2LPENR apb2lpenr(0x0117F933); // Reset value
|
||||
#endif
|
||||
apb2lpenr.setTIM1LPEN(false);
|
||||
apb2lpenr.setTIM8LPEN(false);
|
||||
apb2lpenr.setUSART1LPEN(false);
|
||||
apb2lpenr.setUSART6LPEN(false);
|
||||
apb2lpenr.setADC1LPEN(false);
|
||||
apb2lpenr.setSPI1LPEN(false);
|
||||
apb2lpenr.setSPI4LPEN(false);
|
||||
apb2lpenr.setSYSCFGLPEN(false);
|
||||
apb2lpenr.setTIM9LPEN(false);
|
||||
apb2lpenr.setTIM10LPEN(false);
|
||||
apb2lpenr.setTIM11LPEN(false);
|
||||
apb2lpenr.setSPI5LPEN(false);
|
||||
#if REGS_RCC_CONFIG_F730
|
||||
apb2lpenr.setSDMMC2LPEN(false);
|
||||
apb2lpenr.setADC2LPEN(false);
|
||||
apb2lpenr.setADC3LPEN(false);
|
||||
apb2lpenr.setSAI1LPEN(false);
|
||||
apb2lpenr.setSAI2LPEN(false);
|
||||
#elif REGS_RCC_CONFIG_F412
|
||||
apb2lpenr.setSDIOLPEN(false);
|
||||
apb2lpenr.setEXTITEN(false);
|
||||
apb2lpenr.setDFSDM1LPEN(false);
|
||||
#endif
|
||||
RCC.APB2LPENR()->set(apb2lpenr);
|
||||
|
||||
CORTEX.SCR()->setSLEEPDEEP(false);
|
||||
|
||||
Device::Board::shutdownPeripherals(true);
|
||||
|
||||
Reference in New Issue
Block a user