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