Code formatted, minor fixes (#466)
This commit is contained in:
parent
8a474d749d
commit
5fa48d0298
28 changed files with 623 additions and 608 deletions
|
|
@ -38,36 +38,36 @@ static uint8_t dec2bcd(uint8_t val)
|
|||
return ((val / 10) << 4) + (val % 10);
|
||||
}
|
||||
|
||||
static uint8_t read_register(i2c_dev_t* dev, uint8_t reg)
|
||||
static uint8_t read_register(i2c_dev_t *dev, uint8_t reg)
|
||||
{
|
||||
uint8_t val;
|
||||
i2c_slave_read(dev->bus, dev->addr, ®, &val, 1);
|
||||
return val;
|
||||
}
|
||||
|
||||
static void update_register(i2c_dev_t* dev, uint8_t reg, uint8_t mask, uint8_t val)
|
||||
static void update_register(i2c_dev_t *dev, uint8_t reg, uint8_t mask, uint8_t val)
|
||||
{
|
||||
uint8_t buf = (read_register(dev,reg) & mask) | val;
|
||||
uint8_t buf = (read_register(dev, reg) & mask) | val;
|
||||
|
||||
i2c_slave_write(dev->bus, dev->addr, ®, &buf, 1);
|
||||
}
|
||||
|
||||
void ds1307_start(i2c_dev_t* dev, bool start)
|
||||
void ds1307_start(i2c_dev_t *dev, bool start)
|
||||
{
|
||||
update_register(dev, TIME_REG, CH_MASK, start ? 0 : CH_BIT);
|
||||
}
|
||||
|
||||
bool ds1307_is_running(i2c_dev_t* dev)
|
||||
bool ds1307_is_running(i2c_dev_t *dev)
|
||||
{
|
||||
return !(read_register(dev, TIME_REG) & CH_BIT);
|
||||
}
|
||||
|
||||
void ds1307_get_time(i2c_dev_t* dev, struct tm *time)
|
||||
void ds1307_get_time(i2c_dev_t *dev, struct tm *time)
|
||||
{
|
||||
uint8_t buf[7];
|
||||
uint8_t reg = TIME_REG ;
|
||||
uint8_t reg = TIME_REG;
|
||||
|
||||
i2c_slave_read(dev->bus, dev->addr, ® , buf, 7);
|
||||
i2c_slave_read(dev->bus, dev->addr, ®, buf, 7);
|
||||
|
||||
time->tm_sec = bcd2dec(buf[0] & SECONDS_MASK);
|
||||
time->tm_min = bcd2dec(buf[1]);
|
||||
|
|
@ -78,14 +78,15 @@ void ds1307_get_time(i2c_dev_t* dev, struct tm *time)
|
|||
if (buf[2] & PM_BIT)
|
||||
time->tm_hour += 12;
|
||||
}
|
||||
else time->tm_hour = bcd2dec(buf[2] & HOUR24_MASK);
|
||||
else
|
||||
time->tm_hour = bcd2dec(buf[2] & HOUR24_MASK);
|
||||
time->tm_wday = bcd2dec(buf[3]) - 1;
|
||||
time->tm_mday = bcd2dec(buf[4]);
|
||||
time->tm_mon = bcd2dec(buf[5]) - 1;
|
||||
time->tm_mon = bcd2dec(buf[5]) - 1;
|
||||
time->tm_year = bcd2dec(buf[6]) + 2000;
|
||||
}
|
||||
|
||||
void ds1307_set_time(i2c_dev_t* dev, const struct tm *time)
|
||||
void ds1307_set_time(i2c_dev_t *dev, const struct tm *time)
|
||||
{
|
||||
uint8_t buf[8];
|
||||
buf[0] = TIME_REG;
|
||||
|
|
@ -97,51 +98,55 @@ void ds1307_set_time(i2c_dev_t* dev, const struct tm *time)
|
|||
buf[6] = dec2bcd(time->tm_mon + 1);
|
||||
buf[7] = dec2bcd(time->tm_year - 2000);
|
||||
|
||||
i2c_slave_write(dev->bus, dev->addr, &buf[0], &buf[1] , 7);
|
||||
i2c_slave_write(dev->bus, dev->addr, &buf[0], &buf[1], 7);
|
||||
}
|
||||
|
||||
void ds1307_enable_squarewave(i2c_dev_t* dev, bool enable)
|
||||
void ds1307_enable_squarewave(i2c_dev_t *dev, bool enable)
|
||||
{
|
||||
update_register(dev, CONTROL_REG, SQWE_MASK, enable ? SQWE_BIT : 0);
|
||||
}
|
||||
|
||||
bool ds1307_is_squarewave_enabled(i2c_dev_t* dev)
|
||||
bool ds1307_is_squarewave_enabled(i2c_dev_t *dev)
|
||||
{
|
||||
return read_register(dev, CONTROL_REG) & SQWE_BIT;
|
||||
}
|
||||
|
||||
void ds1307_set_squarewave_freq(i2c_dev_t* dev, ds1307_squarewave_freq_t freq)
|
||||
void ds1307_set_squarewave_freq(i2c_dev_t *dev, ds1307_squarewave_freq_t freq)
|
||||
{
|
||||
update_register(dev, CONTROL_REG, SQWEF_MASK, (uint8_t)freq);
|
||||
}
|
||||
|
||||
ds1307_squarewave_freq_t ds1307_get_squarewave_freq(i2c_dev_t* dev)
|
||||
ds1307_squarewave_freq_t ds1307_get_squarewave_freq(i2c_dev_t *dev)
|
||||
{
|
||||
return (ds1307_squarewave_freq_t)(read_register(dev, CONTROL_REG) & SQWEF_MASK);
|
||||
}
|
||||
|
||||
bool ds1307_get_output(i2c_dev_t* dev)
|
||||
bool ds1307_get_output(i2c_dev_t *dev)
|
||||
{
|
||||
return read_register(dev, CONTROL_REG) & OUT_BIT;
|
||||
}
|
||||
|
||||
void ds1307_set_output(i2c_dev_t* dev, bool value)
|
||||
void ds1307_set_output(i2c_dev_t *dev, bool value)
|
||||
{
|
||||
update_register(dev, CONTROL_REG, OUT_MASK, value ? OUT_BIT : 0);
|
||||
}
|
||||
|
||||
int ds1307_read_ram(i2c_dev_t* dev, uint8_t offset, uint8_t *buf, uint8_t len)
|
||||
int ds1307_read_ram(i2c_dev_t *dev, uint8_t offset, uint8_t *buf, uint8_t len)
|
||||
{
|
||||
if (offset + len > RAM_SIZE) return false;
|
||||
uint8_t reg = RAM_REG + offset ;
|
||||
if (offset + len > RAM_SIZE)
|
||||
return -EINVAL;
|
||||
|
||||
uint8_t reg = RAM_REG + offset;
|
||||
|
||||
return i2c_slave_read(dev->bus, dev->addr, ®, buf, len);
|
||||
}
|
||||
|
||||
int ds1307_write_ram(i2c_dev_t* dev, uint8_t offset, uint8_t *buf, uint8_t len)
|
||||
int ds1307_write_ram(i2c_dev_t *dev, uint8_t offset, uint8_t *buf, uint8_t len)
|
||||
{
|
||||
if (offset + len > RAM_SIZE) return false;
|
||||
uint8_t reg = RAM_REG + offset ;
|
||||
if (offset + len > RAM_SIZE)
|
||||
return -EINVAL;
|
||||
|
||||
uint8_t reg = RAM_REG + offset;
|
||||
|
||||
return i2c_slave_write(dev->bus, dev->addr, ®, buf, len);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -17,11 +17,12 @@
|
|||
extern "C" {
|
||||
#endif
|
||||
|
||||
#define DS1307_ADDR 0x68
|
||||
#define DS1307_ADDR 0x68
|
||||
|
||||
/**
|
||||
* Squarewave frequency
|
||||
*/
|
||||
typedef enum _ds1307_squarewave_freq_t
|
||||
typedef enum
|
||||
{
|
||||
DS1307_1HZ = 0, //!< 1 Hz
|
||||
DS1307_4096HZ, //!< 4096 Hz
|
||||
|
|
@ -33,62 +34,62 @@ typedef enum _ds1307_squarewave_freq_t
|
|||
* \brief Start/stop clock
|
||||
* \param start Start clock if true
|
||||
*/
|
||||
void ds1307_start(i2c_dev_t* dev, bool start);
|
||||
void ds1307_start(i2c_dev_t *dev, bool start);
|
||||
|
||||
/**
|
||||
* \brief Get current clock state
|
||||
* \return true if clock running
|
||||
*/
|
||||
bool ds1307_is_running(i2c_dev_t* dev);
|
||||
bool ds1307_is_running(i2c_dev_t *dev);
|
||||
|
||||
/**
|
||||
* \brief Get current time
|
||||
* \param time Pointer to the time struct to fill
|
||||
*/
|
||||
void ds1307_get_time(i2c_dev_t* dev, struct tm *time);
|
||||
void ds1307_get_time(i2c_dev_t *dev, struct tm *time);
|
||||
|
||||
/**
|
||||
* \brief Set time to RTC
|
||||
* \param time Pointer to the time struct
|
||||
*/
|
||||
void ds1307_set_time(i2c_dev_t* dev, const struct tm *time);
|
||||
void ds1307_set_time(i2c_dev_t *dev, const struct tm *time);
|
||||
|
||||
/**
|
||||
* \brief Enable or disable square-wave oscillator output
|
||||
* \param enable Enable oscillator if true
|
||||
*/
|
||||
void ds1307_enable_squarewave(i2c_dev_t* dev, bool enable);
|
||||
void ds1307_enable_squarewave(i2c_dev_t *dev, bool enable);
|
||||
|
||||
/**
|
||||
* \brief Get square-wave oscillator output
|
||||
* \return true if square-wave oscillator enabled
|
||||
*/
|
||||
bool ds1307_is_squarewave_enabled(i2c_dev_t* dev);
|
||||
bool ds1307_is_squarewave_enabled(i2c_dev_t *dev);
|
||||
|
||||
/**
|
||||
* \brief Set square-wave oscillator frequency
|
||||
* \param freq Frequency
|
||||
*/
|
||||
void ds1307_set_squarewave_freq(i2c_dev_t* dev, ds1307_squarewave_freq_t freq);
|
||||
void ds1307_set_squarewave_freq(i2c_dev_t *dev, ds1307_squarewave_freq_t freq);
|
||||
|
||||
/**
|
||||
* \brief Get current square-wave oscillator frequency
|
||||
* \return Frequency
|
||||
*/
|
||||
ds1307_squarewave_freq_t ds1307_get_squarewave_freq(i2c_dev_t* dev);
|
||||
ds1307_squarewave_freq_t ds1307_get_squarewave_freq(i2c_dev_t *dev);
|
||||
|
||||
/**
|
||||
* \brief Get current output level of the SQW/OUT pin
|
||||
* \return true if high
|
||||
*/
|
||||
bool ds1307_get_output(i2c_dev_t* dev);
|
||||
bool ds1307_get_output(i2c_dev_t *dev);
|
||||
|
||||
/**
|
||||
* \brief Set output level of the SQW/OUT pin
|
||||
* Set output level if square-wave output is disabled
|
||||
* \param value High level if true
|
||||
*/
|
||||
void ds1307_set_output(i2c_dev_t* dev, bool value);
|
||||
void ds1307_set_output(i2c_dev_t *dev, bool value);
|
||||
|
||||
/**
|
||||
* \brief Read RAM contents into the buffer
|
||||
|
|
@ -97,7 +98,7 @@ void ds1307_set_output(i2c_dev_t* dev, bool value);
|
|||
* \param len Bytes to read, 1..56
|
||||
* \return Non-zero if error occured
|
||||
*/
|
||||
int ds1307_read_ram(i2c_dev_t* dev, uint8_t offset, uint8_t *buf, uint8_t len);
|
||||
int ds1307_read_ram(i2c_dev_t *dev, uint8_t offset, uint8_t *buf, uint8_t len);
|
||||
|
||||
/**
|
||||
* \brief Write buffer to RTC RAM
|
||||
|
|
@ -106,7 +107,7 @@ int ds1307_read_ram(i2c_dev_t* dev, uint8_t offset, uint8_t *buf, uint8_t len);
|
|||
* \param len Bytes to write, 1..56
|
||||
* \return Non-zero if error occured
|
||||
*/
|
||||
int ds1307_write_ram(i2c_dev_t* dev, uint8_t offset, uint8_t *buf, uint8_t len);
|
||||
int ds1307_write_ram(i2c_dev_t *dev, uint8_t offset, uint8_t *buf, uint8_t len);
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue