Files
MuditaOS/module-bsp/drivers/pll/DriverPLL.hpp
Lukasz Mastalerz 21171bb474 [BH-1714] Eink refactor and error handling
Cleanup and refactor for eink code.
Changed turning on/off procedure.
Add error handling.
2023-07-14 10:23:42 +02:00

51 lines
1.0 KiB
C++

// Copyright (c) 2017-2023, Mudita Sp. z.o.o. All rights reserved.
// For licensing, see https://github.com/mudita/MuditaOS/LICENSE.md
#pragma once
#include <memory>
#include <cstdint>
namespace drivers
{
enum class PLLInstances
{
OSC_24M,
PLL1_ARM,
PLL2_PFD2,
PLL3,
PLL3_PFD0,
PLL3_PFD1,
PLL3_PFD2,
PLL4_Audio,
COUNT
};
struct DriverPLLParams
{
std::uint32_t loopDivider;
std::uint32_t postDivider;
std::uint32_t numerator;
std::uint32_t denominator;
std::uint32_t src;
};
class DriverPLL
{
public:
static std::shared_ptr<DriverPLL> Create(PLLInstances inst, const DriverPLLParams &params);
explicit DriverPLL(const DriverPLLParams &params) : parameters(params)
{}
protected:
const DriverPLLParams parameters;
private:
static std::weak_ptr<DriverPLL> singleton[static_cast<std::uint32_t>(PLLInstances::COUNT)];
};
} // namespace drivers