Kimberly Lie / Mbed 2 deprecated ECE4180_MasterCode

Dependencies:   mbed mbed-rtos SDFileSystem PinDetect ESP8266NodeMCUInterface

Embed: (wiki syntax)

« Back to documentation index

Show/hide line numbers PowerControl.h Source File

PowerControl.h

00001 /* mbed PowerControl Library
00002   * Copyright (c) 2010 Michael Wei
00003   */ 
00004   
00005 #ifndef MBED_POWERCONTROL_H 
00006 #define MBED_POWERCONTROL_H 
00007 
00008 //shouldn't have to include, but fixes weird problems with defines
00009 //#include "LPC1768/LPC17xx.h"
00010 //System Control Register
00011 // bit 0: Reserved
00012 // bit 1: Sleep on Exit
00013 #define LPC1768_SCR_SLEEPONEXIT     0x2
00014 // bit 2: Deep Sleep
00015 #define LPC1768_SCR_SLEEPDEEP       0x4
00016 // bit 3: Resereved
00017 // bit 4: Send on Pending
00018 #define LPC1768_SCR_SEVONPEND        0x10
00019 // bit 5-31: Reserved
00020 
00021 //Power Control Register
00022 // bit 0: Power mode control bit 0 (power-down mode)
00023 #define LPC1768_PCON_PM0            0x1
00024 // bit 1: Power mode control bit 1 (deep power-down mode)
00025 #define LPC1768_PCON_PM1            0x2
00026 // bit 2: Brown-out reduced power mode
00027 #define LPC1768_PCON_BODRPM         0x4
00028 // bit 3: Brown-out global disable
00029 #define LPC1768_PCON_BOGD           0x8
00030 // bit 4: Brown-out reset disable
00031 #define LPC1768_PCON_BORD           0x10
00032 // bit 5-7 : Reserved
00033 // bit 8: Sleep Mode Entry Flag
00034 #define LPC1768_PCON_SMFLAG         0x100
00035 // bit 9: Deep Sleep Entry Flag
00036 #define LPC1768_PCON_DSFLAG         0x200
00037 // bit 10: Power Down Entry Flag
00038 #define LPC1768_PCON_PDFLAG         0x400
00039 // bit 11: Deep Power Down Entry Flag
00040 #define LPC1768_PCON_DPDFLAG        0x800
00041 // bit 12-31: Reserved
00042 
00043 //"Sleep Mode" (WFI).
00044 inline void Sleep(void)
00045 {
00046     __WFI();
00047 }
00048 
00049 //"Deep Sleep" Mode
00050 inline void DeepSleep(void)
00051 {
00052    SCB->SCR |= LPC1768_SCR_SLEEPDEEP;
00053    __WFI();
00054 }
00055 
00056 //"Power-Down" Mode
00057 inline void PowerDown(void)
00058 {
00059    SCB->SCR |= LPC1768_SCR_SLEEPDEEP;
00060    LPC_SC->PCON &= ~LPC1768_PCON_PM1;
00061    LPC_SC->PCON |= LPC1768_PCON_PM0;
00062    __WFI();
00063    //reset back to normal
00064   LPC_SC->PCON &= ~(LPC1768_PCON_PM1 | LPC1768_PCON_PM0);
00065 }
00066 
00067 //"Deep Power-Down" Mode
00068 inline void DeepPowerDown(void)
00069 {
00070    SCB->SCR |= LPC1768_SCR_SLEEPDEEP;
00071    LPC_SC->PCON |= LPC1768_PCON_PM1 | LPC1768_PCON_PM0;
00072    __WFI();
00073    //reset back to normal
00074   LPC_SC->PCON &= ~(LPC1768_PCON_PM1 | LPC1768_PCON_PM0);
00075 }
00076 
00077 //shut down BOD during power-down/deep sleep
00078 inline void BrownOut_ReducedPowerMode_Enable(void)
00079 {
00080     LPC_SC->PCON |= LPC1768_PCON_BODRPM;
00081 }
00082 
00083 //turn on BOD during power-down/deep sleep
00084 inline void BrownOut_ReducedPowerMode_Disable(void)
00085 {
00086     LPC_SC->PCON &= ~LPC1768_PCON_BODRPM;
00087 }
00088 
00089 //turn off brown out circutry
00090 inline void BrownOut_Global_Disable(void)
00091 {
00092     LPC_SC->PCON |= LPC1768_PCON_BOGD;
00093 }
00094 
00095 //turn on brown out circutry
00096 inline void BrownOut_Global_Enable(void)
00097 {
00098     LPC_SC->PCON &= !LPC1768_PCON_BOGD;
00099 }
00100 
00101 //turn off brown out reset circutry
00102 inline void BrownOut_Reset_Disable(void)
00103 {
00104     LPC_SC->PCON |= LPC1768_PCON_BORD;
00105 }
00106 
00107 //turn on brown outreset  circutry
00108 inline void BrownOut_Reset_Enable(void)
00109 {
00110     LPC_SC->PCON &= ~LPC1768_PCON_BORD;
00111 }
00112 //Peripheral Control Register
00113 // bit 0: Reserved
00114 // bit 1: PCTIM0: Timer/Counter 0 power/clock enable
00115 #define LPC1768_PCONP_PCTIM0        0x2
00116 // bit 2: PCTIM1: Timer/Counter 1 power/clock enable
00117 #define LPC1768_PCONP_PCTIM1        0x4
00118 // bit 3: PCUART0: UART 0 power/clock enable
00119 #define LPC1768_PCONP_PCUART0       0x8
00120 // bit 4: PCUART1: UART 1 power/clock enable
00121 #define LPC1768_PCONP_PCUART1       0x10
00122 // bit 5: Reserved
00123 // bit 6: PCPWM1: PWM 1 power/clock enable
00124 #define LPC1768_PCONP_PCPWM1        0x40
00125 // bit 7: PCI2C0: I2C interface 0 power/clock enable
00126 #define LPC1768_PCONP_PCI2C0        0x80
00127 // bit 8: PCSPI: SPI interface power/clock enable
00128 #define LPC1768_PCONP_PCSPI         0x100
00129 // bit 9: PCRTC: RTC power/clock enable
00130 #define LPC1768_PCONP_PCRTC         0x200
00131 // bit 10: PCSSP1: SSP interface 1 power/clock enable
00132 #define LPC1768_PCONP_PCSSP1        0x400
00133 // bit 11: Reserved
00134 // bit 12: PCADC: A/D converter power/clock enable
00135 #define LPC1768_PCONP_PCADC         0x1000
00136 // bit 13: PCCAN1: CAN controller 1 power/clock enable
00137 #define LPC1768_PCONP_PCCAN1        0x2000
00138 // bit 14: PCCAN2: CAN controller 2 power/clock enable
00139 #define LPC1768_PCONP_PCCAN2        0x4000
00140 // bit 15: PCGPIO: GPIOs power/clock enable
00141 #define LPC1768_PCONP_PCGPIO        0x8000
00142 // bit 16: PCRIT: Repetitive interrupt timer power/clock enable
00143 #define LPC1768_PCONP_PCRIT         0x10000
00144 // bit 17: PCMCPWM: Motor control PWM power/clock enable
00145 #define LPC1768_PCONP_PCMCPWM       0x20000
00146 // bit 18: PCQEI: Quadrature encoder interface power/clock enable
00147 #define LPC1768_PCONP_PCQEI         0x40000
00148 // bit 19: PCI2C1: I2C interface 1 power/clock enable
00149 #define LPC1768_PCONP_PCI2C1        0x80000
00150 // bit 20: Reserved
00151 // bit 21: PCSSP0: SSP interface 0 power/clock enable
00152 #define LPC1768_PCONP_PCSSP0        0x200000
00153 // bit 22: PCTIM2: Timer 2 power/clock enable
00154 #define LPC1768_PCONP_PCTIM2        0x400000
00155 // bit 23: PCTIM3: Timer 3 power/clock enable
00156 #define LPC1768_PCONP_PCQTIM3       0x800000
00157 // bit 24: PCUART2: UART 2 power/clock enable
00158 #define LPC1768_PCONP_PCUART2       0x1000000
00159 // bit 25: PCUART3: UART 3 power/clock enable
00160 #define LPC1768_PCONP_PCUART3       0x2000000
00161 // bit 26: PCI2C2: I2C interface 2 power/clock enable
00162 #define LPC1768_PCONP_PCI2C2        0x4000000
00163 // bit 27: PCI2S: I2S interface power/clock enable
00164 #define LPC1768_PCONP_PCI2S         0x8000000
00165 // bit 28: Reserved
00166 // bit 29: PCGPDMA: GP DMA function power/clock enable
00167 #define LPC1768_PCONP_PCGPDMA       0x20000000
00168 // bit 30: PCENET: Ethernet block power/clock enable
00169 #define LPC1768_PCONP_PCENET        0x40000000
00170 // bit 31: PCUSB: USB interface power/clock enable
00171 #define LPC1768_PCONP_PCUSB         0x80000000
00172 
00173 //Powers Up specified Peripheral(s)
00174 inline unsigned int Peripheral_PowerUp(unsigned int bitMask)
00175 {
00176     return LPC_SC->PCONP |= bitMask;
00177 }   
00178 
00179 //Powers Down specified Peripheral(s) 
00180 inline unsigned int Peripheral_PowerDown(unsigned int bitMask)
00181 {
00182     return LPC_SC->PCONP &= ~bitMask;
00183 }
00184 
00185 //returns if the peripheral is on or off
00186 inline bool Peripheral_GetStatus(unsigned int peripheral)
00187 {
00188     return (LPC_SC->PCONP & peripheral) ? true : false;
00189 }
00190 
00191 #endif