/* $NetBSD: tasklet.h,v 1.7 2022/07/17 14:11:07 riastradh Exp $ */
/*-
* Copyright (c) 2018, 2020 The NetBSD Foundation, Inc.
* All rights reserved.
*
* This code is derived from software contributed to The NetBSD Foundation
* by Taylor R. Campbell.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef _LINUX_TASKLET_H_
#define _LINUX_TASKLET_H_
/* namespace */
#define __tasklet_disable_sync_once linux___tasklet_disable_sync_once
#define __tasklet_enable linux___tasklet_enable
#define __tasklet_enable_sync_once linux___tasklet_enable_sync_once
#define __tasklet_is_enabled linux___tasklet_is_enabled
#define __tasklet_is_scheduled linux___tasklet_is_scheduled
#define tasklet_disable linux_tasklet_disable
#define tasklet_disable_nosync linux_tasklet_disable_nosync
#define tasklet_enable linux_tasklet_enable
#define tasklet_hi_schedule linux_tasklet_hi_schedule
#define tasklet_init linux_tasklet_init
#define tasklet_is_locked linux_tasklet_is_locked
#define tasklet_kill linux_tasklet_kill
#define tasklet_schedule linux_tasklet_schedule
#define tasklet_struct linux_tasklet_struct
#define tasklet_trylock linux_tasklet_trylock
#define tasklet_unlock linux_tasklet_unlock
#define tasklet_unlock_wait linux_tasklet_unlock_wait
struct tasklet_struct {
SIMPLEQ_ENTRY(tasklet_struct) tl_entry;
volatile unsigned tl_state;
volatile unsigned tl_disablecount;
/* begin Linux API */
void (*func)(unsigned long);
unsigned long data;
/* end Linux API */
};
#define DEFINE_TASKLET(name, func, data) \
struct tasklet_struct name = { \
.tl_state = 0, \
.tl_disablecount = 0, \
.func = (func), \
.data = (data), \
}
#define DEFINE_TASKLET_DISABLED(name, func, data) \
struct tasklet_struct name = { \
.tl_state = 0, \
.tl_disablecount = 1, \
.func = (func), \
.data = (data), \
}
int linux_tasklets_init(void);
void linux_tasklets_fini(void);
void tasklet_init(struct tasklet_struct *, void (*)(unsigned long),
unsigned long);
void tasklet_disable_nosync(struct tasklet_struct *);
void tasklet_disable(struct tasklet_struct *);
void tasklet_enable(struct tasklet_struct *);
void tasklet_schedule(struct tasklet_struct *);
void tasklet_hi_schedule(struct tasklet_struct *);
void tasklet_kill(struct tasklet_struct *);
bool tasklet_is_locked(const struct tasklet_struct *);
bool tasklet_trylock(struct tasklet_struct *);
void tasklet_unlock(struct tasklet_struct *);
void tasklet_unlock_wait(const struct tasklet_struct *);
/* i915 hacks */
void __tasklet_disable_sync_once(struct tasklet_struct *);
void __tasklet_enable_sync_once(struct tasklet_struct *);
bool __tasklet_is_enabled(const struct tasklet_struct *);
bool __tasklet_is_scheduled(const struct tasklet_struct *);
bool __tasklet_enable(struct tasklet_struct *);
#endif /* _LINUX_TASKLET_H_ */