158391efdSNathan Chancellor /* SPDX-License-Identifier: GPL-2.0 */
2554c0a3aSHans de Goede /******************************************************************************
3554c0a3aSHans de Goede  *
4554c0a3aSHans de Goede  * Copyright(c) 2007 - 2013 Realtek Corporation. All rights reserved.
5554c0a3aSHans de Goede  *
6554c0a3aSHans de Goede  ******************************************************************************/
7554c0a3aSHans de Goede #ifndef __OSDEP_SERVICE_H_
8554c0a3aSHans de Goede #define __OSDEP_SERVICE_H_
9554c0a3aSHans de Goede 
10554c0a3aSHans de Goede 
11554c0a3aSHans de Goede #define _FAIL		0
12554c0a3aSHans de Goede #define _SUCCESS	1
13554c0a3aSHans de Goede #define RTW_RX_HANDLED 2
14554c0a3aSHans de Goede 
15554c0a3aSHans de Goede #include <osdep_service_linux.h>
16554c0a3aSHans de Goede 
17554c0a3aSHans de Goede #define BIT0	0x00000001
18554c0a3aSHans de Goede #define BIT1	0x00000002
19554c0a3aSHans de Goede #define BIT2	0x00000004
20554c0a3aSHans de Goede #define BIT3	0x00000008
21554c0a3aSHans de Goede #define BIT4	0x00000010
22554c0a3aSHans de Goede #define BIT5	0x00000020
23554c0a3aSHans de Goede #define BIT6	0x00000040
24554c0a3aSHans de Goede #define BIT7	0x00000080
25554c0a3aSHans de Goede #define BIT8	0x00000100
26554c0a3aSHans de Goede #define BIT9	0x00000200
27554c0a3aSHans de Goede #define BIT10	0x00000400
28554c0a3aSHans de Goede #define BIT11	0x00000800
29554c0a3aSHans de Goede #define BIT12	0x00001000
30554c0a3aSHans de Goede #define BIT13	0x00002000
31554c0a3aSHans de Goede #define BIT14	0x00004000
32554c0a3aSHans de Goede #define BIT15	0x00008000
33554c0a3aSHans de Goede #define BIT16	0x00010000
34554c0a3aSHans de Goede #define BIT17	0x00020000
35554c0a3aSHans de Goede #define BIT18	0x00040000
36554c0a3aSHans de Goede #define BIT19	0x00080000
37554c0a3aSHans de Goede #define BIT20	0x00100000
38554c0a3aSHans de Goede #define BIT21	0x00200000
39554c0a3aSHans de Goede #define BIT22	0x00400000
40554c0a3aSHans de Goede #define BIT23	0x00800000
41554c0a3aSHans de Goede #define BIT24	0x01000000
42554c0a3aSHans de Goede #define BIT25	0x02000000
43554c0a3aSHans de Goede #define BIT26	0x04000000
44554c0a3aSHans de Goede #define BIT27	0x08000000
45554c0a3aSHans de Goede #define BIT28	0x10000000
46554c0a3aSHans de Goede #define BIT29	0x20000000
47554c0a3aSHans de Goede #define BIT30	0x40000000
48554c0a3aSHans de Goede #define BIT31	0x80000000
49554c0a3aSHans de Goede #define BIT32	0x0100000000
50554c0a3aSHans de Goede #define BIT33	0x0200000000
51554c0a3aSHans de Goede #define BIT34	0x0400000000
52554c0a3aSHans de Goede #define BIT35	0x0800000000
53554c0a3aSHans de Goede #define BIT36	0x1000000000
54554c0a3aSHans de Goede 
55554c0a3aSHans de Goede extern int RTW_STATUS_CODE(int error_code);
56554c0a3aSHans de Goede 
5735628c4aSJoe Perches void *_rtw_zmalloc(u32 sz);
5835628c4aSJoe Perches void *_rtw_malloc(u32 sz);
59554c0a3aSHans de Goede void _kfree(u8 *pbuf, u32 sz);
60554c0a3aSHans de Goede 
61554c0a3aSHans de Goede struct sk_buff *_rtw_skb_alloc(u32 sz);
62554c0a3aSHans de Goede struct sk_buff *_rtw_skb_copy(const struct sk_buff *skb);
6300d5865cSMarco Cesati int _rtw_netif_rx(struct net_device *ndev, struct sk_buff *skb);
64554c0a3aSHans de Goede 
65554c0a3aSHans de Goede #define rtw_malloc(sz)			_rtw_malloc((sz))
66554c0a3aSHans de Goede #define rtw_zmalloc(sz)			_rtw_zmalloc((sz))
67554c0a3aSHans de Goede 
68554c0a3aSHans de Goede #define rtw_skb_alloc(size) _rtw_skb_alloc((size))
69554c0a3aSHans de Goede #define rtw_skb_alloc_f(size, mstat_f)	_rtw_skb_alloc((size))
70554c0a3aSHans de Goede #define rtw_skb_copy(skb)	_rtw_skb_copy((skb))
71554c0a3aSHans de Goede #define rtw_skb_copy_f(skb, mstat_f)	_rtw_skb_copy((skb))
72554c0a3aSHans de Goede #define rtw_netif_rx(ndev, skb) _rtw_netif_rx(ndev, skb)
73554c0a3aSHans de Goede 
74554c0a3aSHans de Goede extern void _rtw_init_queue(struct __queue	*pqueue);
75554c0a3aSHans de Goede 
thread_enter(char * name)764a397521SRasmus Villemoes static inline void thread_enter(char *name)
77554c0a3aSHans de Goede {
78554c0a3aSHans de Goede 	allow_signal(SIGTERM);
79554c0a3aSHans de Goede }
80554c0a3aSHans de Goede 
flush_signals_thread(void)814a397521SRasmus Villemoes static inline void flush_signals_thread(void)
82554c0a3aSHans de Goede {
83554c0a3aSHans de Goede 	if (signal_pending(current))
84554c0a3aSHans de Goede 	{
85554c0a3aSHans de Goede 		flush_signals(current);
86554c0a3aSHans de Goede 	}
87554c0a3aSHans de Goede }
88554c0a3aSHans de Goede 
89554c0a3aSHans de Goede #define rtw_warn_on(condition) WARN_ON(condition)
90554c0a3aSHans de Goede 
rtw_bug_check(void * parg1,void * parg2,void * parg3,void * parg4)914a397521SRasmus Villemoes static inline int rtw_bug_check(void *parg1, void *parg2, void *parg3, void *parg4)
92554c0a3aSHans de Goede {
93554c0a3aSHans de Goede 	int ret = true;
94554c0a3aSHans de Goede 
95554c0a3aSHans de Goede 	return ret;
96554c0a3aSHans de Goede 
97554c0a3aSHans de Goede }
98554c0a3aSHans de Goede 
99554c0a3aSHans de Goede #define _RND(sz, r) ((((sz)+((r)-1))/(r))*(r))
100554c0a3aSHans de Goede 
101554c0a3aSHans de Goede #ifndef MAC_ARG
10212cc28baSJoe Perches #define MAC_ARG(x) (x)
103554c0a3aSHans de Goede #endif
104554c0a3aSHans de Goede 
105554c0a3aSHans de Goede extern void rtw_free_netdev(struct net_device * netdev);
106554c0a3aSHans de Goede 
107554c0a3aSHans de Goede /* Macros for handling unaligned memory accesses */
108554c0a3aSHans de Goede 
109554c0a3aSHans de Goede void rtw_buf_free(u8 **buf, u32 *buf_len);
110554c0a3aSHans de Goede void rtw_buf_update(u8 **buf, u32 *buf_len, u8 *src, u32 src_len);
111554c0a3aSHans de Goede 
112554c0a3aSHans de Goede struct rtw_cbuf {
113554c0a3aSHans de Goede 	u32 write;
114554c0a3aSHans de Goede 	u32 read;
115554c0a3aSHans de Goede 	u32 size;
116*0d197f20SGustavo A. R. Silva 	void *bufs[];
117554c0a3aSHans de Goede };
118554c0a3aSHans de Goede 
119554c0a3aSHans de Goede bool rtw_cbuf_full(struct rtw_cbuf *cbuf);
120554c0a3aSHans de Goede bool rtw_cbuf_empty(struct rtw_cbuf *cbuf);
121554c0a3aSHans de Goede bool rtw_cbuf_push(struct rtw_cbuf *cbuf, void *buf);
122554c0a3aSHans de Goede void *rtw_cbuf_pop(struct rtw_cbuf *cbuf);
123554c0a3aSHans de Goede struct rtw_cbuf *rtw_cbuf_alloc(u32 size);
124554c0a3aSHans de Goede 
125554c0a3aSHans de Goede /*  String handler */
126554c0a3aSHans de Goede /*
127554c0a3aSHans de Goede  * Write formatted output to sized buffer
128554c0a3aSHans de Goede  */
129554c0a3aSHans de Goede #define rtw_sprintf(buf, size, format, arg...)	snprintf(buf, size, format, ##arg)
130554c0a3aSHans de Goede 
131554c0a3aSHans de Goede #endif
132