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,
373d0407baSopenharmony_ci				  const char *name)
383d0407baSopenharmony_ci{
393d0407baSopenharmony_ci	struct wakeup_source *ws = &lock->ws;
403d0407baSopenharmony_ci
413d0407baSopenharmony_ci	if (ws) {
423d0407baSopenharmony_ci		memset(ws, 0, sizeof(*ws));
433d0407baSopenharmony_ci		ws->name = name;
443d0407baSopenharmony_ci	}
453d0407baSopenharmony_ci	wakeup_source_add(ws);
463d0407baSopenharmony_ci}
473d0407baSopenharmony_ci
483d0407baSopenharmony_cistatic inline void wake_lock_destroy(struct wake_lock *lock)
493d0407baSopenharmony_ci{
503d0407baSopenharmony_ci	struct wakeup_source *ws = &lock->ws;
513d0407baSopenharmony_ci
523d0407baSopenharmony_ci	wakeup_source_remove(ws);
533d0407baSopenharmony_ci	__pm_relax(ws);
543d0407baSopenharmony_ci}
553d0407baSopenharmony_ci
563d0407baSopenharmony_cistatic inline void wake_lock(struct wake_lock *lock)
573d0407baSopenharmony_ci{
583d0407baSopenharmony_ci	__pm_stay_awake(&lock->ws);
593d0407baSopenharmony_ci}
603d0407baSopenharmony_ci
613d0407baSopenharmony_cistatic inline void wake_lock_timeout(struct wake_lock *lock, long timeout)
623d0407baSopenharmony_ci{
633d0407baSopenharmony_ci	__pm_wakeup_event(&lock->ws, jiffies_to_msecs(timeout));
643d0407baSopenharmony_ci}
653d0407baSopenharmony_ci
663d0407baSopenharmony_cistatic inline void wake_unlock(struct wake_lock *lock)
673d0407baSopenharmony_ci{
683d0407baSopenharmony_ci	__pm_relax(&lock->ws);
693d0407baSopenharmony_ci}
703d0407baSopenharmony_ci
713d0407baSopenharmony_cistatic inline int wake_lock_active(struct wake_lock *lock)
723d0407baSopenharmony_ci{
733d0407baSopenharmony_ci	return lock->ws.active;
743d0407baSopenharmony_ci}
753d0407baSopenharmony_ci
763d0407baSopenharmony_ci#endif
77