2022-05-27 15:44:58 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "hardware/i2c.h"
|
2022-05-30 08:40:26 +01:00
|
|
|
#include "hardware/rtc.h"
|
|
|
|
|
|
|
|
#include "common/pimoroni_common.hpp"
|
|
|
|
#include "common/pimoroni_i2c.hpp"
|
2022-05-27 15:44:58 +01:00
|
|
|
|
|
|
|
namespace pimoroni {
|
|
|
|
|
|
|
|
class PCF85063A {
|
|
|
|
//--------------------------------------------------
|
|
|
|
// Constants
|
|
|
|
//--------------------------------------------------
|
|
|
|
public:
|
2022-05-30 08:40:26 +01:00
|
|
|
static const uint DEFAULT_I2C_ADDRESS = 0x51;
|
2022-05-30 14:40:36 +01:00
|
|
|
static const int PARAM_UNUSED = -1;
|
2022-05-30 08:40:26 +01:00
|
|
|
|
2022-05-30 14:40:36 +01:00
|
|
|
|
|
|
|
//--------------------------------------------------
|
|
|
|
// Enums
|
|
|
|
//--------------------------------------------------
|
|
|
|
public:
|
2022-05-30 08:40:26 +01:00
|
|
|
enum ClockOut : uint8_t {
|
|
|
|
CLOCK_OUT_32768HZ = 0,
|
|
|
|
CLOCK_OUT_16384HZ = 1,
|
|
|
|
CLOCK_OUT_8192HZ = 2,
|
|
|
|
CLOCK_OUT_4096HZ = 3,
|
|
|
|
CLOCK_OUT_2048HZ = 4,
|
|
|
|
CLOCK_OUT_1024HZ = 5,
|
|
|
|
CLOCK_OUT_1HZ = 6,
|
|
|
|
CLOCK_OUT_OFF = 7
|
|
|
|
};
|
|
|
|
|
|
|
|
enum DayOfWeek : int8_t {
|
|
|
|
SUNDAY = 0,
|
|
|
|
MONDAY = 1,
|
|
|
|
TUESDAY = 2,
|
|
|
|
WEDNESDAY = 3,
|
|
|
|
THURSDAY = 4,
|
|
|
|
FRIDAY = 5,
|
|
|
|
SATURDAY = 6,
|
2022-05-30 14:40:36 +01:00
|
|
|
NONE = PARAM_UNUSED
|
2022-05-30 08:40:26 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
enum TimerTickPeriod : int8_t {
|
2022-05-30 14:40:36 +01:00
|
|
|
TIMER_TICK_4096HZ = 0b00,
|
|
|
|
TIMER_TICK_64HZ = 0b01,
|
|
|
|
TIMER_TICK_1HZ = 0b10,
|
|
|
|
TIMER_TICK_1_OVER_60HZ = 0b11
|
2022-05-30 08:40:26 +01:00
|
|
|
};
|
2022-05-27 15:44:58 +01:00
|
|
|
|
|
|
|
private:
|
2022-05-30 08:40:26 +01:00
|
|
|
enum Registers : uint8_t {
|
|
|
|
CONTROL_1 = 0x00,
|
|
|
|
CONTROL_2 = 0x01,
|
|
|
|
OFFSET = 0x02,
|
|
|
|
RAM_BYTE = 0x03,
|
|
|
|
OSCILLATOR_STATUS = 0x04, // flag embedded in seconds register (see below)
|
|
|
|
SECONDS = 0x04, // contains oscillator status flag (see above)
|
|
|
|
MINUTES = 0x05,
|
|
|
|
HOURS = 0x06,
|
|
|
|
DAYS = 0x07,
|
|
|
|
WEEKDAYS = 0x08,
|
|
|
|
MONTHS = 0x09,
|
|
|
|
YEARS = 0x0A,
|
|
|
|
SECOND_ALARM = 0x0B,
|
|
|
|
MINUTE_ALARM = 0x0C,
|
|
|
|
HOUR_ALARM = 0x0D,
|
|
|
|
DAY_ALARM = 0x0E,
|
|
|
|
WEEKDAY_ALARM = 0x0F,
|
|
|
|
TIMER_VALUE = 0x10,
|
|
|
|
TIMER_MODE = 0x11
|
|
|
|
};
|
2022-05-27 15:44:58 +01:00
|
|
|
|
2022-05-30 14:40:36 +01:00
|
|
|
|
|
|
|
//--------------------------------------------------
|
|
|
|
// Variables
|
|
|
|
//--------------------------------------------------
|
|
|
|
private:
|
|
|
|
I2C *i2c;
|
|
|
|
|
|
|
|
// Interface pins with our standard defaults where appropriate
|
|
|
|
uint address = DEFAULT_I2C_ADDRESS;
|
|
|
|
uint interrupt = PIN_UNUSED;
|
|
|
|
|
|
|
|
|
2022-05-27 15:44:58 +01:00
|
|
|
//--------------------------------------------------
|
|
|
|
// Constructors/Destructor
|
|
|
|
//--------------------------------------------------
|
|
|
|
public:
|
|
|
|
PCF85063A() {}
|
|
|
|
|
2022-05-30 08:40:26 +01:00
|
|
|
PCF85063A(I2C *i2c, uint interrupt = PIN_UNUSED) :
|
|
|
|
i2c(i2c), interrupt(interrupt) {}
|
2022-05-27 15:44:58 +01:00
|
|
|
|
|
|
|
//--------------------------------------------------
|
|
|
|
// Methods
|
|
|
|
//--------------------------------------------------
|
|
|
|
public:
|
|
|
|
void init();
|
|
|
|
void reset();
|
|
|
|
|
2022-05-30 14:40:36 +01:00
|
|
|
// I2C instance details access methods
|
|
|
|
i2c_inst_t* get_i2c() const;
|
|
|
|
int get_address() const;
|
|
|
|
int get_sda() const;
|
|
|
|
int get_scl() const;
|
|
|
|
int get_int() const;
|
|
|
|
|
|
|
|
// Set and get the date and time
|
|
|
|
// Uses datetime_t from pico sdk (hardware/rtc) for compatibility
|
2022-05-27 15:44:58 +01:00
|
|
|
datetime_t get_datetime();
|
2022-05-30 14:40:36 +01:00
|
|
|
void set_datetime(datetime_t *t);
|
2022-05-27 15:44:58 +01:00
|
|
|
|
2022-05-30 14:40:36 +01:00
|
|
|
// Alarm manipulation methods
|
|
|
|
void set_alarm(int second = PARAM_UNUSED, int minute = PARAM_UNUSED,
|
|
|
|
int hour = PARAM_UNUSED, int day = PARAM_UNUSED);
|
|
|
|
void set_weekday_alarm(int second = PARAM_UNUSED, int minute = PARAM_UNUSED,
|
|
|
|
int hour = PARAM_UNUSED, DayOfWeek dotw = DayOfWeek::NONE);
|
2022-05-30 08:40:26 +01:00
|
|
|
void enable_alarm_interrupt(bool enable);
|
|
|
|
bool read_alarm_flag();
|
2022-05-30 14:40:36 +01:00
|
|
|
void clear_alarm_flag();
|
2022-05-30 08:40:26 +01:00
|
|
|
void unset_alarm();
|
|
|
|
|
2022-05-30 14:40:36 +01:00
|
|
|
// Timer manipulation methods
|
2022-05-30 08:40:26 +01:00
|
|
|
void set_timer(uint8_t ticks,
|
|
|
|
TimerTickPeriod ttp = TimerTickPeriod::TIMER_TICK_1HZ);
|
2022-05-30 14:40:36 +01:00
|
|
|
void enable_timer_interrupt(bool enable, bool flag_only = false);
|
2022-05-30 08:40:26 +01:00
|
|
|
bool read_timer_flag();
|
|
|
|
void clear_timer_flag();
|
2022-05-30 14:40:36 +01:00
|
|
|
void unset_timer();
|
2022-05-30 08:40:26 +01:00
|
|
|
|
2022-05-30 14:40:36 +01:00
|
|
|
// Clock output
|
2022-05-30 08:40:26 +01:00
|
|
|
void set_clock_output(ClockOut co);
|
2022-05-27 15:44:58 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|