162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci#ifndef _LINUX_TASK_WORK_H
362306a36Sopenharmony_ci#define _LINUX_TASK_WORK_H
462306a36Sopenharmony_ci
562306a36Sopenharmony_ci#include <linux/list.h>
662306a36Sopenharmony_ci#include <linux/sched.h>
762306a36Sopenharmony_ci
862306a36Sopenharmony_citypedef void (*task_work_func_t)(struct callback_head *);
962306a36Sopenharmony_ci
1062306a36Sopenharmony_cistatic inline void
1162306a36Sopenharmony_ciinit_task_work(struct callback_head *twork, task_work_func_t func)
1262306a36Sopenharmony_ci{
1362306a36Sopenharmony_ci	twork->func = func;
1462306a36Sopenharmony_ci}
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_cienum task_work_notify_mode {
1762306a36Sopenharmony_ci	TWA_NONE,
1862306a36Sopenharmony_ci	TWA_RESUME,
1962306a36Sopenharmony_ci	TWA_SIGNAL,
2062306a36Sopenharmony_ci	TWA_SIGNAL_NO_IPI,
2162306a36Sopenharmony_ci};
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_cistatic inline bool task_work_pending(struct task_struct *task)
2462306a36Sopenharmony_ci{
2562306a36Sopenharmony_ci	return READ_ONCE(task->task_works);
2662306a36Sopenharmony_ci}
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ciint task_work_add(struct task_struct *task, struct callback_head *twork,
2962306a36Sopenharmony_ci			enum task_work_notify_mode mode);
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_cistruct callback_head *task_work_cancel_match(struct task_struct *task,
3262306a36Sopenharmony_ci	bool (*match)(struct callback_head *, void *data), void *data);
3362306a36Sopenharmony_cistruct callback_head *task_work_cancel(struct task_struct *, task_work_func_t);
3462306a36Sopenharmony_civoid task_work_run(void);
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_cistatic inline void exit_task_work(struct task_struct *task)
3762306a36Sopenharmony_ci{
3862306a36Sopenharmony_ci	task_work_run();
3962306a36Sopenharmony_ci}
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ci#endif	/* _LINUX_TASK_WORK_H */
42