接口设计
26 Nov 2024
Read time: 2 minute(s)
Driver 层接口设计
以下接口是 RTC 设备驱动框架的标准接口。
struct rt_rtc_ops
{
rt_err_t (*init)(void);
rt_err_t (*get_secs)(time_t *sec);
rt_err_t (*set_secs)(time_t *sec);
rt_err_t (*get_alarm)(struct rt_rtc_wkalarm *alarm);
rt_err_t (*set_alarm)(struct rt_rtc_wkalarm *alarm);
rt_err_t (*get_timeval)(struct timeval *tv); // 暂未实现
rt_err_t (*set_timeval)(struct timeval *tv); // 暂未实现
};
函数原型 | rt_err_t rtc_ops_init(void) |
---|---|
功能说明 | RTC 控制器的初始化 |
参数定义 | 无 |
返回值 | 0,成功 |
注意事项 | - |
函数原型 | rt_err_t rtc_ops_get_secs(time_t *sec) |
---|---|
功能说明 | 获取当前的 RTC 时间 |
参数定义 | sec - 用于保存返回的时间信息,单位:秒 |
返回值 | 0,成功 |
注意事项 | - |
函数原型 | rt_err_t rtc_ops_set_secs(time_t *sec) |
---|---|
功能说明 | 设置当前的 RTC 时间 |
参数定义 | sec - 用于保存要设置的时间信息,单位:秒 |
返回值 | 0,成功 |
注意事项 | - |
函数原型 | rt_err_t rtc_ops_get_alarm(struct rt_rtc_wkalarm *alarm) |
---|---|
功能说明 | 获取当前的 Alarm 信息 |
参数定义 | alarm - 用于保存返回的 alarm 信息 |
返回值 | 0,成功 |
注意事项 | - |
函数原型 | rt_err_t rtc_ops_set_alarm(struct rt_rtc_wkalarm *alarm) |
---|---|
功能说明 | 设置 Alarm 信息 |
参数定义 | alarm - 用于保存要设置的 Alarm 信息 |
返回值 | 0,成功 |
注意事项 | - |
HAL 层接口设计
HAL 层的函数接口声明存放在 hal_rtc.h
中,主要接口有:
s32 hal_rtc_init(void);
s32 hal_rtc_deinit(void);
void hal_rtc_read_time(u32 *sec);
void hal_rtc_set_time(u32 sec);
s32 hal_rtc_read_alarm(u32 *sec);
void hal_rtc_set_alarm(u32 sec);
void hal_rtc_alarm_io_output(void);
void hal_rtc_32k_clk_output(void);
irqreturn_t hal_rtc_irq(int irq, void *arg);
void hal_rtc_cali(s32 clk_rate);
s32 hal_rtc_register_callback(rtc_callback_t callback);