blob: 2ec5635c0758bff6075b5f164a624ac64f509209 [file] [log] [blame]
/*
* Copyright (c) 2011 The Linux Foundation. All rights reserved.
*
* Previously licensed under the ISC license by Qualcomm Atheros, Inc.
*
*
* Permission to use, copy, modify, and/or distribute this software for
* any purpose with or without fee is hereby granted, provided that the
* above copyright notice and this permission notice appear in all
* copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
* WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
* AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
* DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
* PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
* TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
* PERFORMANCE OF THIS SOFTWARE.
*/
/*
* This file was originally distributed by Qualcomm Atheros, Inc.
* under proprietary terms before Copyright ownership was assigned
* to the Linux Foundation.
*/
/**
* @ingroup adf_os_public
* @file adf_os_defer.h
* This file abstracts deferred execution contexts.
*/
#ifndef __ADF_OS_DEFER_H
#define __ADF_OS_DEFER_H
#include <adf_os_types.h>
#include <adf_os_defer_pvt.h>
/**
* TODO This implements work queues (worker threads, kernel threads etc.).
* Note that there is no cancel on a scheduled work. You cannot free a work
* item if its queued. You cannot know if a work item is queued or not unless
* its running, whence you know its not queued.
*
* so if, say, a module is asked to unload itself, how exactly will it make
* sure that the work's not queued, for OS'es that dont provide such a
* mechanism??
*/
/**
* @brief Representation of a work queue.
*/
typedef __adf_os_work_t adf_os_work_t;
typedef __adf_os_delayed_work_t adf_os_delayed_work_t;
typedef __adf_os_workqueue_t adf_os_workqueue_t;
/**
* @brief Representation of a bottom half.
*/
typedef __adf_os_bh_t adf_os_bh_t;
/**
* @brief This creates the Bottom half deferred handler
*
* @param[in] hdl OS handle
* @param[in] bh bottom instance
* @param[in] func deferred function to run at bottom half interrupt
* context.
* @param[in] arg argument for the deferred function
*/
static inline void
adf_os_create_bh(adf_os_handle_t hdl, adf_os_bh_t *bh,
adf_os_defer_fn_t func,void *arg)
{
__adf_os_init_bh(hdl, bh, func, arg);
}
/**
* @brief schedule a bottom half (DPC)
*
* @param[in] hdl OS handle
* @param[in] bh bottom instance
*/
static inline void
adf_os_sched_bh(adf_os_handle_t hdl, adf_os_bh_t *bh)
{
__adf_os_sched_bh(hdl, bh);
}
/**
* @brief destroy the bh (synchronous)
*
* @param[in] hdl OS handle
* @param[in] bh bottom instance
*/
static inline void
adf_os_destroy_bh(adf_os_handle_t hdl, adf_os_bh_t *bh)
{
__adf_os_disable_bh(hdl,bh);
}
/*********************Non-Interrupt Context deferred Execution***************/
/**
* @brief create a work/task queue, This runs in non-interrupt
* context, so can be preempted by H/W & S/W intr
*
* @param[in] hdl OS handle
* @param[in] work work instance
* @param[in] func deferred function to run at bottom half non-interrupt
* context.
* @param[in] arg argument for the deferred function
*/
static inline void
adf_os_create_work(adf_os_handle_t hdl, adf_os_work_t *work,
adf_os_defer_fn_t func, void *arg)
{
__adf_os_init_work(hdl, work, func, arg);
}
static inline void
adf_os_create_delayed_work(adf_os_handle_t hdl, adf_os_delayed_work_t *work,
adf_os_defer_fn_t func, void *arg)
{
__adf_os_init_delayed_work(hdl, work, func, arg);
}
static inline adf_os_workqueue_t*
adf_os_create_workqueue(char *name)
{
return __adf_os_create_workqueue(name);
}
static inline void
adf_os_queue_work(adf_os_handle_t hdl, adf_os_workqueue_t *wqueue, adf_os_work_t* work)
{
return __adf_os_queue_work(hdl, wqueue, work);
}
static inline void
adf_os_queue_delayed_work(adf_os_handle_t hdl, adf_os_workqueue_t *wqueue, adf_os_delayed_work_t* work, a_uint32_t delay)
{
return __adf_os_queue_delayed_work(hdl, wqueue, work, delay);
}
static inline void
adf_os_flush_workqueue(adf_os_handle_t hdl, adf_os_workqueue_t *wqueue)
{
return __adf_os_flush_workqueue(hdl, wqueue);
}
static inline void
adf_os_destroy_workqueue(adf_os_handle_t hdl, adf_os_workqueue_t *wqueue)
{
return __adf_os_destroy_workqueue(hdl, wqueue);
}
/**
* @brief Schedule a deferred task on non-interrupt context
*
* @param[in] hdl OS handle
* @param[in] work work instance
*/
static inline void
adf_os_sched_work(adf_os_handle_t hdl, adf_os_work_t *work)
{
__adf_os_sched_work(hdl, work);
}
/**
*@brief destroy the deferred task (synchronous)
*
*@param[in] hdl OS handle
*@param[in] work work instance
*/
static inline void
adf_os_destroy_work(adf_os_handle_t hdl, adf_os_work_t *work)
{
__adf_os_disable_work(hdl, work);
}
/**
* XXX API to specify processor while scheduling a bh => only on vista
*/
#endif /*_ADF_OS_DEFER_H*/