~aleteoryx/muditaos

ref: 0c0fdef19b2a06d2be92d6177fca2c0ec4bcd31b muditaos/module-bsp/board/rt1051/bsp/lpm/RT1051LPM.hpp -rw-r--r-- 1.1 KiB
0c0fdef1 — Maciej-Mudita [EGD-4881] Add oscillator clock switching mechanisms 5 years ago
                                                                                
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
// Copyright (c) 2017-2020, Mudita Sp. z.o.o. All rights reserved.
// For licensing, see https://github.com/mudita/MuditaOS/LICENSE.md

#ifndef PUREPHONE_RT1051LPM_HPP
#define PUREPHONE_RT1051LPM_HPP

#include "bsp/lpm/bsp_lpm.hpp"
#include "drivers/gpio/DriverGPIO.hpp"
#include "CpuFreqLPM.hpp"
#include <fsl_clock.h>

namespace bsp
{
    inline constexpr uint8_t OscillatorReadyCounterValue{127};
    inline constexpr uint8_t CCM_TupleShift{8};
    inline constexpr uint8_t CCM_TupleMask{0x1F};
    inline constexpr uint32_t ClockNeededRunWaitMode{3};

    class RT1051LPM : public LowPowerMode
    {
      public:
        RT1051LPM();
        int32_t PowerOff() override final;
        int32_t Reboot() override final;
        void SetCpuFrequency(CpuFrequency freq) final;
        void SwitchOscillatorSource(OscillatorSource source) final;

      private:
        [[nodiscard]] bool IsClockEnabled(clock_ip_name_t name) const noexcept;

        std::shared_ptr<drivers::DriverGPIO> gpio;
        std::unique_ptr<bsp::CpuFreqLPM> CpuFreq;
    };

} // namespace bsp

#endif // PUREPHONE_RT1051LPM_HPP