English | 简体中文 | 繁體中文 | 日本語 | Deutsch | 한국어
DS3231是低成本、高精度IIC实时时钟,具有集成的温补晶体振荡器。该器件包含电池输入端,断开主电源时仍可保持精确的及时。集成晶体振荡器提高了器件的长期精确度,并减少了生产线的元件数量。DS3231提供商用级和工业级温度范围,采用16引脚、300mil的SO封装。
LibDriver DS3231是LibDriver推出的DS3231全功能驱动,该驱动提供时间读取、闹钟触发、温度读取和方波输出等功能并且它符合MISRA标准。
/src目录包含了LibDriver DS3231的源文件。
/interface目录包含了LibDriver DS3231与平台无关的IIC总线模板。
/test目录包含了LibDriver DS3231驱动测试程序,该程序可以简单的测试芯片必要功能。
/example目录包含了LibDriver DS3231编程范例。
/doc目录包含了LibDriver DS3231离线文档。
/datasheet目录包含了DS3231数据手册。
/project目录包含了常用Linux与单片机开发板的工程样例。所有工程均采用shell脚本作为调试方法,详细内容可参考每个工程里面的README.md。
/misra目录包含了LibDriver MISRA代码扫描结果。
参考/interface目录下与平台无关的IIC总线模板,完成指定平台的IIC总线驱动。
将/src目录,您使用平台的接口驱动和您开发的驱动加入工程,如果您想要使用默认的范例驱动,可以将/example目录加入您的工程。
您可以参考/example目录下的编程范例完成适合您的驱动,如果您想要使用默认的编程范例,以下是它们的使用方法。
#include "driver_ds3231_basic.h"
uint8_t res;
ds3231_time_t time;
int16_t raw;
float s;
res = ds3231_basic_init();
if (res != 0)
{
return 1;
}
...
res = ds3231_basic_get_temperature((int16_t *)&raw, (float *)&s);
if (res != 0)
{
(void)ds3231_basic_deinit();
return 1;
}
ds3231_interface_debug_print("ds3231: temperature is %0.2fC.\n", s);
...
mode = DS3231_ALARM1_MODE_ONCE_A_SECOND;
time.am_pm = DS3231_AM;
time.date = data;
time.format = DS3231_FORMAT_24H;
time.hour = hour;
time.minute = minute;
time.month = month;
time.second = second;
time.week = week;
time.year = year;
res = ds3231_basic_set_time(&time);
if (res != 0)
{
(void)ds3231_basic_deinit();
return 1;
}
...
res = ds3231_basic_get_time(&time);
if (res != 0)
{
(void)ds3231_basic_deinit();
return 1;
}
if (time.format == DS3231_FORMAT_24H)
{
ds3231_interface_debug_print("ds3231: %04d-%02d-%02d %02d:%02d:%02d %d.\n",
time.year, time.month, time.date,
time.hour, time.minute, time.second, time.week
);
}
else
{
ds3231_interface_debug_print("ds3231: %04d-%02d-%02d %s %02d:%02d:%02d %d.\n",
time.year, time.month, time.date, (time.am_pm == DS3231_AM) ? "AM" : "PM",
time.hour, time.minute, time.second, time.week
);
}
...
(void)ds3231_basic_deinit();
return 0;
#include "driver_ds3231_alarm.h"
uint8_t res;
ds3231_time_t time;
ds3231_alarm1_mode_t mode;
void alarm_receive_callback(uint8_t type)
{
switch (type)
{
case DS3231_STATUS_ALARM_2 :
{
ds3231_alarm_clear_flag(DS3231_ALARM_2);
ds3231_interface_debug_print("ds3231: irq alarm2.\n");
...
break;
}
case DS3231_STATUS_ALARM_1 :
{
ds3231_alarm_clear_flag(DS3231_ALARM_1);
ds3231_interface_debug_print("ds3231: irq alarm1.\n");
...
break;
}
default :
{
...
break;
}
}
}
res = ds3231_alarm_init(alarm_receive_callback);
if (res != 0)
{
return 1;
}
...
res = gpio_interrupt_init();
if (res != 0)
{
(void)ds3231_alarm_deinit();
return 1;
}
...
mode = DS3231_ALARM1_MODE_ONCE_A_SECOND;
time.am_pm = DS3231_AM;
time.date = data;
time.format = DS3231_FORMAT_24H;
time.hour = hour;
time.minute = minute;
time.month = month;
time.second = second;
time.week = week;
time.year = year;
res = ds3231_alarm_set_alarm1(&time, mode);
if (res != 0)
{
(void)ds3231_alarm_deinit();
return 1;
}
...
res = ds3231_alarm_enable(DS3231_ALARM_1);
if (res != 0)
{
(void)ds3231_alarm_deinit();
return 1;
}
...
(void)ds3231_alarm_deinit();
return 0;
#include "driver_ds3231_output.h"
uint8_t res;
res = ds3231_output_init();
if (res != 0)
{
return 1;
}
...
res = ds3231_output_set_square_wave(enable);
if (res != 0)
{
(void)ds3231_output_deinit();
return 1;
}
...
res = ds3231_output_set_32khz_output(enable);
if (res != 0)
{
(void)ds3231_output_deinit();
return 1;
}
...
(void)ds3231_output_deinit();
return 0;
在线文档: https://www.libdriver.com/docs/ds3231/index.html。
离线文档: /doc/html/index.html。
请参考CONTRIBUTING.md。
版权 (c) 2015 - 现在 LibDriver 版权所有
MIT 许可证(MIT)
特此免费授予任何获得本软件副本和相关文档文件(下称“软件”)的人不受限制地处置该软件的权利,包括不受限制地使用、复制、修改、合并、发布、分发、转授许可和/或出售该软件副本,以及再授权被配发了本软件的人如上的权利,须在下列条件下:
上述版权声明和本许可声明应包含在该软件的所有副本或实质成分中。
本软件是“如此”提供的,没有任何形式的明示或暗示的保证,包括但不限于对适销性、特定用途的适用性和不侵权的保证。在任何情况下,作者或版权持有人都不对任何索赔、损害或其他责任负责,无论这些追责来自合同、侵权或其它行为中,还是产生于、源于或有关于本软件以及本软件的使用或其它处置。