a4de3e61431fb4feb9ec1d94bbf2f1cafcd00ea4
[firefly-linux-kernel-4.4.55.git] / drivers / net / wireless / rockchip_wlan / rtl8723bu / core / rtw_mem.c
1 \r
2 #include <drv_types.h>\r
3 #include <rtw_mem.h>\r
4 \r
5 MODULE_LICENSE("GPL");\r
6 MODULE_DESCRIPTION("Realtek Wireless Lan Driver");\r
7 MODULE_AUTHOR("Realtek Semiconductor Corp.");\r
8 MODULE_VERSION("DRIVERVERSION");\r
9 \r
10 struct sk_buff_head rtk_skb_mem_q;\r
11 struct u8* rtk_buf_mem[NR_RECVBUFF];\r
12 \r
13 struct u8       * rtw_get_buf_premem(int index)\r
14 {\r
15         printk("%s, rtk_buf_mem index : %d\n", __func__, index);\r
16         return rtk_buf_mem[index];\r
17 }\r
18 \r
19 struct sk_buff *rtw_alloc_skb_premem(void)\r
20 {\r
21         struct sk_buff *skb = NULL;\r
22 \r
23         skb = skb_dequeue(&rtk_skb_mem_q);\r
24 \r
25         printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));\r
26 \r
27         return skb;     \r
28 }\r
29 EXPORT_SYMBOL(rtw_alloc_skb_premem);\r
30 \r
31 int rtw_free_skb_premem(struct sk_buff *pskb)\r
32 {\r
33         if(!pskb)\r
34                 return -1;\r
35 \r
36         if(skb_queue_len(&rtk_skb_mem_q) >= NR_PREALLOC_RECV_SKB)       \r
37                 return -1;\r
38         \r
39         skb_queue_tail(&rtk_skb_mem_q, pskb);\r
40         \r
41         printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));\r
42 \r
43         return 0;\r
44 }\r
45 EXPORT_SYMBOL(rtw_free_skb_premem);\r
46 \r
47 static int __init rtw_mem_init(void)\r
48 {\r
49         int i;\r
50         SIZE_PTR tmpaddr=0;\r
51         SIZE_PTR alignment=0;\r
52         struct sk_buff *pskb=NULL;\r
53 \r
54         printk("%s\n", __func__);\r
55 \r
56 #ifdef CONFIG_USE_USB_BUFFER_ALLOC_RX\r
57         for(i=0; i<NR_RECVBUFF; i++)\r\r
58         {\r\r
59                 rtk_buf_mem[i] = usb_buffer_alloc(dev, size, (in_interrupt() ? GFP_ATOMIC : GFP_KERNEL), dma);\r
60         }\r
61 #endif //CONFIG_USE_USB_BUFFER_ALLOC_RX\r
62 \r
63         skb_queue_head_init(&rtk_skb_mem_q);\r
64 \r
65         for(i=0; i<NR_PREALLOC_RECV_SKB; i++)\r
66         {\r
67                 pskb = __dev_alloc_skb(MAX_RECVBUF_SZ + RECVBUFF_ALIGN_SZ, in_interrupt() ? GFP_ATOMIC : GFP_KERNEL);\r
68                 if(pskb)\r
69                 {               \r
70                         tmpaddr = (SIZE_PTR)pskb->data;\r
71                         alignment = tmpaddr & (RECVBUFF_ALIGN_SZ-1);\r
72                         skb_reserve(pskb, (RECVBUFF_ALIGN_SZ - alignment));\r
73 \r
74                         skb_queue_tail(&rtk_skb_mem_q, pskb);\r
75                 }\r
76                 else\r
77                 {\r
78                         printk("%s, alloc skb memory fail!\n", __func__);\r
79                 }\r
80 \r
81                 pskb=NULL;\r
82         }\r
83 \r
84         printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));\r
85 \r
86         return 0;\r
87         \r
88 }\r
89 \r
90 static void __exit rtw_mem_exit(void)\r
91 {\r
92         if (skb_queue_len(&rtk_skb_mem_q)) {\r
93                 printk("%s, rtk_skb_mem_q len : %d\n", __func__, skb_queue_len(&rtk_skb_mem_q));\r
94         }\r
95 \r
96         skb_queue_purge(&rtk_skb_mem_q);\r
97 \r
98         printk("%s\n", __func__);\r
99 }\r
100 \r
101 module_init(rtw_mem_init);\r
102 module_exit(rtw_mem_exit);\r
103 \r