13d0407baSopenharmony_ci/* include/linux/wakelock.h
23d0407baSopenharmony_ci *
33d0407baSopenharmony_ci * Copyright (C) 2007-2012 Google, Inc.
43d0407baSopenharmony_ci *
53d0407baSopenharmony_ci * This software is licensed under the terms of the GNU General Public
63d0407baSopenharmony_ci * License version 2, as published by the Free Software Foundation, and
73d0407baSopenharmony_ci * may be copied, distributed, and modified under those terms.
83d0407baSopenharmony_ci *
93d0407baSopenharmony_ci * This program is distributed in the hope that it will be useful,
103d0407baSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of
113d0407baSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
123d0407baSopenharmony_ci * GNU General Public License for more details.
133d0407baSopenharmony_ci *
143d0407baSopenharmony_ci */
153d0407baSopenharmony_ci
163d0407baSopenharmony_ci#ifndef _LINUX_WAKELOCK_H
173d0407baSopenharmony_ci#define _LINUX_WAKELOCK_H
183d0407baSopenharmony_ci
193d0407baSopenharmony_ci#include <linux/ktime.h>
203d0407baSopenharmony_ci#include <linux/device.h>
213d0407baSopenharmony_ci
223d0407baSopenharmony_ci/* A wake_lock prevents the system from entering suspend or other low power
233d0407baSopenharmony_ci * states when active. If the type is set to WAKE_LOCK_SUSPEND, the wake_lock
243d0407baSopenharmony_ci * prevents a full system suspend.
253d0407baSopenharmony_ci */
263d0407baSopenharmony_ci
273d0407baSopenharmony_cienum {
283d0407baSopenharmony_ci    WAKE_LOCK_SUSPEND, /* Prevent suspend */
293d0407baSopenharmony_ci    WAKE_LOCK_TYPE_COUNT
303d0407baSopenharmony_ci};
313d0407baSopenharmony_ci
323d0407baSopenharmony_cistruct wake_lock {
333d0407baSopenharmony_ci    struct wakeup_source ws;
343d0407baSopenharmony_ci};
353d0407baSopenharmony_ci
363d0407baSopenharmony_cistatic inline void wake_lock_init(struct wake_lock *lock, int type, const char *name)
373d0407baSopenharmony_ci{
383d0407baSopenharmony_ci    struct wakeup_source *ws = &lock->ws;
393d0407baSopenharmony_ci
403d0407baSopenharmony_ci    if (ws) {
413d0407baSopenharmony_ci        memset(ws, 0, sizeof(*ws));
423d0407baSopenharmony_ci        ws->name = name;
433d0407baSopenharmony_ci    }
443d0407baSopenharmony_ci    wakeup_source_add(ws);
453d0407baSopenharmony_ci}
463d0407baSopenharmony_ci
473d0407baSopenharmony_cistatic inline void wake_lock_destroy(struct wake_lock *lock)
483d0407baSopenharmony_ci{
493d0407baSopenharmony_ci    struct wakeup_source *ws = &lock->ws;
503d0407baSopenharmony_ci
513d0407baSopenharmony_ci    wakeup_source_remove(ws);
523d0407baSopenharmony_ci    __pm_relax(ws);
533d0407baSopenharmony_ci}
543d0407baSopenharmony_ci
553d0407baSopenharmony_cistatic inline void wake_lock(struct wake_lock *lock)
563d0407baSopenharmony_ci{
573d0407baSopenharmony_ci    __pm_stay_awake(&lock->ws);
583d0407baSopenharmony_ci}
593d0407baSopenharmony_ci
603d0407baSopenharmony_cistatic inline void wake_lock_timeout(struct wake_lock *lock, long timeout)
613d0407baSopenharmony_ci{
623d0407baSopenharmony_ci    __pm_wakeup_event(&lock->ws, jiffies_to_msecs(timeout));
633d0407baSopenharmony_ci}
643d0407baSopenharmony_ci
653d0407baSopenharmony_cistatic inline void wake_unlock(struct wake_lock *lock)
663d0407baSopenharmony_ci{
673d0407baSopenharmony_ci    __pm_relax(&lock->ws);
683d0407baSopenharmony_ci}
693d0407baSopenharmony_ci
703d0407baSopenharmony_cistatic inline int wake_lock_active(struct wake_lock *lock)
713d0407baSopenharmony_ci{
723d0407baSopenharmony_ci    return lock->ws.active;
733d0407baSopenharmony_ci}
743d0407baSopenharmony_ci
753d0407baSopenharmony_ci#endif
76