2011-09-03 13:14:04 -06:00
|
|
|
/******************************************************************************
|
|
|
|
*
|
|
|
|
* Copyright(c) 2007 - 2010 Realtek Corporation. All rights reserved.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of version 2 of the GNU General Public License as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
|
|
* more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along with
|
|
|
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
|
|
|
*
|
|
|
|
* Modifications for inclusion into the Linux staging tree are
|
|
|
|
* Copyright(c) 2010 Larry Finger. All rights reserved.
|
|
|
|
*
|
|
|
|
* Contact information:
|
|
|
|
* WLAN FAE <wlanfae@realtek.com>
|
|
|
|
* Larry Finger <Larry.Finger@lwfinger.net>
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
2010-08-20 09:15:30 -06:00
|
|
|
#ifndef __OSDEP_SERVICE_H_
|
|
|
|
#define __OSDEP_SERVICE_H_
|
|
|
|
|
|
|
|
#define _SUCCESS 1
|
|
|
|
#define _FAIL 0
|
|
|
|
|
|
|
|
#include <linux/spinlock.h>
|
2011-09-03 13:14:11 -06:00
|
|
|
|
|
|
|
#include <linux/interrupt.h>
|
2010-08-20 09:15:30 -06:00
|
|
|
#include <linux/semaphore.h>
|
2011-09-03 13:14:11 -06:00
|
|
|
#include <linux/sched.h>
|
2010-08-20 09:15:30 -06:00
|
|
|
#include <linux/sem.h>
|
|
|
|
#include <linux/netdevice.h>
|
|
|
|
#include <linux/etherdevice.h>
|
|
|
|
#include <net/iw_handler.h>
|
2011-09-03 13:14:11 -06:00
|
|
|
#include <linux/proc_fs.h> /* Necessary because we use the proc fs */
|
|
|
|
|
|
|
|
#include "basic_types.h"
|
2010-08-20 09:15:30 -06:00
|
|
|
|
|
|
|
struct __queue {
|
|
|
|
struct list_head queue;
|
|
|
|
spinlock_t lock;
|
|
|
|
};
|
|
|
|
|
|
|
|
#define _pkt struct sk_buff
|
|
|
|
#define _buffer unsigned char
|
|
|
|
#define thread_exit() complete_and_exit(NULL, 0)
|
|
|
|
|
|
|
|
#define _init_queue(pqueue) \
|
|
|
|
do { \
|
2014-06-24 20:52:34 -06:00
|
|
|
INIT_LIST_HEAD(&((pqueue)->queue)); \
|
2010-08-20 09:15:30 -06:00
|
|
|
spin_lock_init(&((pqueue)->lock)); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
static inline u32 _down_sema(struct semaphore *sema)
|
|
|
|
{
|
|
|
|
if (down_interruptible(sema))
|
|
|
|
return _FAIL;
|
2014-10-03 08:03:39 -06:00
|
|
|
return _SUCCESS;
|
2010-08-20 09:15:30 -06:00
|
|
|
}
|
|
|
|
|
2014-03-17 17:39:25 -06:00
|
|
|
static inline u32 end_of_queue_search(struct list_head *head,
|
|
|
|
struct list_head *plist)
|
2010-08-20 09:15:30 -06:00
|
|
|
{
|
2014-10-03 08:03:39 -06:00
|
|
|
return (head == plist);
|
2010-08-20 09:15:30 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void sleep_schedulable(int ms)
|
|
|
|
{
|
|
|
|
u32 delta;
|
|
|
|
|
2015-01-31 03:51:54 -07:00
|
|
|
delta = msecs_to_jiffies(ms);/*(ms)*/
|
2010-08-20 09:15:30 -06:00
|
|
|
set_current_state(TASK_INTERRUPTIBLE);
|
2015-01-31 03:52:14 -07:00
|
|
|
schedule_timeout(delta);
|
2010-08-20 09:15:30 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void flush_signals_thread(void)
|
|
|
|
{
|
|
|
|
if (signal_pending(current))
|
|
|
|
flush_signals(current);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|