mbed library sources. Supersedes mbed-src.

Dependents:   Nucleo_Hello_Encoder BLE_iBeaconScan AM1805_DEMO DISCO-F429ZI_ExportTemplate1 ... more

Committer:
AnnaBridge
Date:
Wed Feb 20 22:31:08 2019 +0000
Revision:
189:f392fc9709a3
mbed library release version 165

Who changed what in which revision?

UserRevisionLine numberNew contents of line
AnnaBridge 189:f392fc9709a3 1 /* mbed Microcontroller Library
AnnaBridge 189:f392fc9709a3 2 * (C)Copyright TOSHIBA ELECTRONIC DEVICES & STORAGE CORPORATION 2018 All rights reserved
AnnaBridge 189:f392fc9709a3 3 *
AnnaBridge 189:f392fc9709a3 4 * Licensed under the Apache License, Version 2.0 (the "License");
AnnaBridge 189:f392fc9709a3 5 * you may not use this file except in compliance with the License.
AnnaBridge 189:f392fc9709a3 6 * You may obtain a copy of the License at
AnnaBridge 189:f392fc9709a3 7 *
AnnaBridge 189:f392fc9709a3 8 * http://www.apache.org/licenses/LICENSE-2.0
AnnaBridge 189:f392fc9709a3 9 *
AnnaBridge 189:f392fc9709a3 10 * Unless required by applicable law or agreed to in writing, software
AnnaBridge 189:f392fc9709a3 11 * distributed under the License is distributed on an "AS IS" BASIS,
AnnaBridge 189:f392fc9709a3 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
AnnaBridge 189:f392fc9709a3 13 * See the License for the specific language governing permissions and
AnnaBridge 189:f392fc9709a3 14 * limitations under the License.
AnnaBridge 189:f392fc9709a3 15 */
AnnaBridge 189:f392fc9709a3 16 #include "sleep_api.h"
AnnaBridge 189:f392fc9709a3 17 #include "gpio_include.h"
AnnaBridge 189:f392fc9709a3 18
AnnaBridge 189:f392fc9709a3 19 static void warming_up_time(void);
AnnaBridge 189:f392fc9709a3 20
AnnaBridge 189:f392fc9709a3 21 void hal_sleep(void)
AnnaBridge 189:f392fc9709a3 22 {
AnnaBridge 189:f392fc9709a3 23 // Set low power consumption mode IDLE
AnnaBridge 189:f392fc9709a3 24 TSB_CG->STBYCR = CG_STBY_MODE_IDLE;
AnnaBridge 189:f392fc9709a3 25 __DSB(); // Enter idle mode
AnnaBridge 189:f392fc9709a3 26 __WFI();
AnnaBridge 189:f392fc9709a3 27 }
AnnaBridge 189:f392fc9709a3 28
AnnaBridge 189:f392fc9709a3 29 void hal_deepsleep(void)
AnnaBridge 189:f392fc9709a3 30 {
AnnaBridge 189:f392fc9709a3 31 uint32_t tmp = 0;
AnnaBridge 189:f392fc9709a3 32
AnnaBridge 189:f392fc9709a3 33 TSB_CG_FSYSENB_IPENB31 = ENABLE;
AnnaBridge 189:f392fc9709a3 34 while ((TSB_FC->SR0 & 0x01) != 0x01) {
AnnaBridge 189:f392fc9709a3 35 // Flash wait
AnnaBridge 189:f392fc9709a3 36 }
AnnaBridge 189:f392fc9709a3 37
AnnaBridge 189:f392fc9709a3 38 while (TSB_CG_WUPHCR_WUEF) {
AnnaBridge 189:f392fc9709a3 39 // Wait for end of Warming-up for IHOSC1
AnnaBridge 189:f392fc9709a3 40 }
AnnaBridge 189:f392fc9709a3 41
AnnaBridge 189:f392fc9709a3 42 TSB_CG_WUPHCR_WUCLK = DISABLE;
AnnaBridge 189:f392fc9709a3 43 warming_up_time();
AnnaBridge 189:f392fc9709a3 44 TSB_CG->STBYCR = CG_STBY_MODE_STOP1;
AnnaBridge 189:f392fc9709a3 45 TSB_CG_PLL0SEL_PLL0SEL = DISABLE;
AnnaBridge 189:f392fc9709a3 46
AnnaBridge 189:f392fc9709a3 47 while (TSB_CG_PLL0SEL_PLL0ST) {
AnnaBridge 189:f392fc9709a3 48 // Wait for PLL status of fsys until off state(fosc=0)
AnnaBridge 189:f392fc9709a3 49 }
AnnaBridge 189:f392fc9709a3 50
AnnaBridge 189:f392fc9709a3 51 TSB_CG_PLL0SEL_PLL0ON = DISABLE; // Stop PLL of fsys
AnnaBridge 189:f392fc9709a3 52 TSB_CG_OSCCR_IHOSC1EN = ENABLE;
AnnaBridge 189:f392fc9709a3 53 TSB_CG_OSCCR_OSCSEL = DISABLE;
AnnaBridge 189:f392fc9709a3 54
AnnaBridge 189:f392fc9709a3 55 while (TSB_CG_OSCCR_OSCF) {
AnnaBridge 189:f392fc9709a3 56 // Wait for fosc status until IHOSC1 = 0
AnnaBridge 189:f392fc9709a3 57 }
AnnaBridge 189:f392fc9709a3 58
AnnaBridge 189:f392fc9709a3 59 tmp = TSB_CG->OSCCR;
AnnaBridge 189:f392fc9709a3 60 tmp &= EXTERNEL_OSC_MASK;
AnnaBridge 189:f392fc9709a3 61 TSB_CG->OSCCR = tmp;
AnnaBridge 189:f392fc9709a3 62 TSB_CG_OSCCR_IHOSC2EN = DISABLE;
AnnaBridge 189:f392fc9709a3 63
AnnaBridge 189:f392fc9709a3 64 while (TSB_CG_OSCCR_IHOSC2F) {
AnnaBridge 189:f392fc9709a3 65 // Wait for status of OFD until off "0"
AnnaBridge 189:f392fc9709a3 66 }
AnnaBridge 189:f392fc9709a3 67
AnnaBridge 189:f392fc9709a3 68 __DSB();
AnnaBridge 189:f392fc9709a3 69 __WFI();
AnnaBridge 189:f392fc9709a3 70 }
AnnaBridge 189:f392fc9709a3 71
AnnaBridge 189:f392fc9709a3 72 static void warming_up_time(void)
AnnaBridge 189:f392fc9709a3 73 {
AnnaBridge 189:f392fc9709a3 74 uint32_t work = 0;
AnnaBridge 189:f392fc9709a3 75 uint64_t x = 0;
AnnaBridge 189:f392fc9709a3 76
AnnaBridge 189:f392fc9709a3 77 x = (uint64_t)(IHOSC_CFG_WARM_UP_TIME * IHOSC_CFG_CLOCK);
AnnaBridge 189:f392fc9709a3 78 x = (uint64_t)(x / (uint64_t)(1000000));
AnnaBridge 189:f392fc9709a3 79
AnnaBridge 189:f392fc9709a3 80 work = (uint32_t)x;
AnnaBridge 189:f392fc9709a3 81 work &= (uint32_t)(0xFFFFFFF0);
AnnaBridge 189:f392fc9709a3 82 work <<= 16;
AnnaBridge 189:f392fc9709a3 83 work |= (uint32_t)(TSB_CG->WUPHCR & ~CGWUPHCR_WUPT_HIGH_MASK);
AnnaBridge 189:f392fc9709a3 84 TSB_CG->WUPHCR = work;
AnnaBridge 189:f392fc9709a3 85 }