1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26#ifndef _OAL_MARC_H
27#define _OAL_MARC_H
28
29#include "oal_dt.h"
30#include "usbdrv.h"
31
32#define ZM_OS_LINUX_FUNC
33
34
35
36#ifndef ZM_HALPLUS_LOCK
37#define zmw_get_wlan_dev(dev) struct zsWlanDev *wd = (struct zsWlanDev*) ((((struct usbdrv_private*)dev->priv)->wd))
38
39#define zmw_declare_for_critical_section() unsigned long irqFlag;
40
41
42#define zmw_enter_critical_section(dev) \
43 spin_lock_irqsave(&(((struct usbdrv_private *)(dev->priv))->cs_lock), irqFlag);
44
45
46#define zmw_leave_critical_section(dev) \
47 spin_unlock_irqrestore(&(((struct usbdrv_private *)(dev->priv))->cs_lock), irqFlag);
48#else
49#define zmw_get_wlan_dev(dev) struct zsWlanDev *wd = zfwGetWlanDev(dev);
50
51
52#define zmw_declare_for_critical_section()
53
54
55#define zmw_enter_critical_section(dev) \
56 zfwEnterCriticalSection(dev);
57
58
59#define zmw_leave_critical_section(dev) \
60 zfwLeaveCriticalSection(dev);
61#endif
62
63
64#ifdef ZM_CONFIG_BIG_ENDIAN
65#define zmw_cpu_to_le32(v) (((v & 0xff000000) >> 24) | \
66 ((v & 0x00ff0000) >> 8) | \
67 ((v & 0x0000ff00) << 8) | \
68 ((v & 0x000000ff) << 24))
69
70#define zmw_le32_to_cpu(v) (((v & 0xff000000) >> 24) | \
71 ((v & 0x00ff0000) >> 8) | \
72 ((v & 0x0000ff00) << 8) | \
73 ((v & 0x000000ff) << 24))
74
75#define zmw_cpu_to_le16(v) (((v & 0xff00) >> 8) | \
76 ((v & 0x00ff) << 8))
77
78#define zmw_le16_to_cpu(v) (((v & 0xff00) >> 8) | \
79 ((v & 0x00ff) << 8))
80#else
81#define zmw_cpu_to_le32(v) (v)
82#define zmw_le32_to_cpu(v) (v)
83#define zmw_cpu_to_le16(v) (v)
84#define zmw_le16_to_cpu(v) (v)
85#endif
86
87
88
89#ifndef ZM_HALPLUS_LOCK
90
91#define zmw_buf_readb(dev, buf, offset) *(u8_t*)((u8_t*)buf->data+offset)
92#define zmw_buf_readh(dev, buf, offset) zmw_cpu_to_le16(*(u16_t*)((u8_t*)buf->data+offset))
93#define zmw_buf_writeb(dev, buf, offset, value) *(u8_t*)((u8_t*)buf->data+offset) = value
94#define zmw_buf_writeh(dev, buf, offset, value) *(u16_t*)((u8_t*)buf->data+offset) = zmw_cpu_to_le16(value)
95#define zmw_buf_get_buffer(dev, buf) (u8_t*)(buf->data)
96
97#else
98
99#define zmw_buf_readb(dev, buf, offset) zfwBufReadByte(dev, buf, offset)
100#define zmw_buf_readh(dev, buf, offset) zfwBufReadHalfWord(dev, buf, offset)
101#define zmw_buf_writeb(dev, buf, offset, value) zfwBufWriteByte(dev, buf, offset, value)
102#define zmw_buf_writeh(dev, buf, offset, value) zfwBufWriteHalfWord(dev, buf, offset, value)
103#define zmw_buf_get_buffer(dev, buf) zfwGetBuffer(dev, buf)
104
105#endif
106
107
108#if 0
109#define zm_debug_msg0(msg) printk("%s:%s\n", __func__, msg);
110#define zm_debug_msg1(msg, val) printk("%s:%s%ld\n", __func__, \
111 msg, (u32_t)val);
112#define zm_debug_msg2(msg, val) printk("%s:%s%lxh\n", __func__, \
113 msg, (u32_t)val);
114#define zm_debug_msg_s(msg, val) printk("%s:%s%s\n", __func__, \
115 msg, val);
116#define zm_debug_msg_p(msg, val1, val2) printk("%s:%s%01ld.%02ld\n", __func__, \
117 msg, (val1/val2), (((val1*100)/val2)%100));
118#define zm_dbg(S) printk S
119#else
120#define zm_debug_msg0(msg)
121#define zm_debug_msg1(msg, val)
122#define zm_debug_msg2(msg, val)
123#define zm_debug_msg_s(msg, val)
124#define zm_debug_msg_p(msg, val1, val2)
125#define zm_dbg(S)
126#endif
127
128#define zm_assert(expr) if(!(expr)) { \
129 printk( "Atheors Assertion failed! %s,%s,%s,line=%d\n", \
130 #expr,__FILE__,__func__,__LINE__); \
131 }
132
133#define DbgPrint printk
134
135#endif
136