/* include/linux/android_alarm.h * * Copyright (C) 2006-2007 Google, Inc. * * This software is licensed under the terms of the GNU General Public * License version 2, as published by the Free Software Foundation, and * may be copied, distributed, and modified under those terms. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * */ #ifndef _LINUX_ANDROID_ALARM_H #define _LINUX_ANDROID_ALARM_H #include #include enum android_alarm_type { /* return code bit numbers or set alarm arg */ ANDROID_ALARM_RTC_WAKEUP, ANDROID_ALARM_RTC, ANDROID_ALARM_ELAPSED_REALTIME_WAKEUP, ANDROID_ALARM_ELAPSED_REALTIME, ANDROID_ALARM_SYSTEMTIME, ANDROID_ALARM_TYPE_COUNT, /* return code bit numbers */ /* ANDROID_ALARM_TIME_CHANGE = 16 */ }; #ifdef __KERNEL__ #include #include /* * The alarm interface is similar to the hrtimer interface but adds support * for wakeup from suspend. It also adds an elapsed realtime clock that can * be used for periodic timers that need to keep runing while the system is * suspended and not be disrupted when the wall time is set. */ /** * struct alarm - the basic alarm structure * @node: red black tree node for time ordered insertion * @type: alarm type. rtc/elapsed-realtime/systemtime, wakeup/non-wakeup. * @softexpires: the absolute earliest expiry time of the alarm. * @expires: the absolute expiry time. * @function: alarm expiry callback function * * The alarm structure must be initialized by alarm_init() * */ struct android_alarm { struct rb_node node; enum android_alarm_type type; ktime_t softexpires; ktime_t expires; void (*function)(struct android_alarm *); }; void android_alarm_init(struct android_alarm *alarm, enum android_alarm_type type, void (*function)(struct android_alarm *)); void android_alarm_start_range(struct android_alarm *alarm, ktime_t start, ktime_t end); int android_alarm_try_to_cancel(struct android_alarm *alarm); int android_alarm_cancel(struct android_alarm *alarm); ktime_t alarm_get_elapsed_realtime(void); /* set rtc while preserving elapsed realtime */ int android_alarm_set_rtc(const struct timespec ts); #ifdef CONFIG_ANDROID_ALARM_OLDDRV_COMPAT /* * Some older drivers depend on the old API, * so provide compatability macros for now. */ #define alarm android_alarm #define alarm_init(x, y, z) android_alarm_init(x, y, z) #define alarm_start_range(x, y, z) android_alarm_start_range(x, y, z) #define alarm_try_to_cancel(x) android_alarm_try_to_cancel(x) #define alarm_cancel(x) android_alarm_cancel(x) #define alarm_set_rtc(x) android_alarm_set_rtc(x) #endif #endif enum android_alarm_return_flags { ANDROID_ALARM_RTC_WAKEUP_MASK = 1U << ANDROID_ALARM_RTC_WAKEUP, ANDROID_ALARM_RTC_MASK = 1U << ANDROID_ALARM_RTC, ANDROID_ALARM_ELAPSED_REALTIME_WAKEUP_MASK = 1U << ANDROID_ALARM_ELAPSED_REALTIME_WAKEUP, ANDROID_ALARM_ELAPSED_REALTIME_MASK = 1U << ANDROID_ALARM_ELAPSED_REALTIME, ANDROID_ALARM_SYSTEMTIME_MASK = 1U << ANDROID_ALARM_SYSTEMTIME, ANDROID_ALARM_TIME_CHANGE_MASK = 1U << 16 }; /* Disable alarm */ #define ANDROID_ALARM_CLEAR(type) _IO('a', 0 | ((type) << 4)) /* Ack last alarm and wait for next */ #define ANDROID_ALARM_WAIT _IO('a', 1) #define ALARM_IOW(c, type, size) _IOW('a', (c) | ((type) << 4), size) /* Set alarm */ #define ANDROID_ALARM_SET(type) ALARM_IOW(2, type, struct timespec) #define ANDROID_ALARM_SET_AND_WAIT(type) ALARM_IOW(3, type, struct timespec) #define ANDROID_ALARM_GET_TIME(type) ALARM_IOW(4, type, struct timespec) #define ANDROID_ALARM_SET_RTC _IOW('a', 5, struct timespec) #define ANDROID_ALARM_BASE_CMD(cmd) (cmd & ~(_IOC(0, 0, 0xf0, 0))) #define ANDROID_ALARM_IOCTL_TO_TYPE(cmd) (_IOC_NR(cmd) >> 4) #endif