Mention branches and keyring.
[releases.git] / include / basic_types.h
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /******************************************************************************
3  *
4  * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
5  *
6  ******************************************************************************/
7 #ifndef __BASIC_TYPES_H__
8 #define __BASIC_TYPES_H__
9
10
11 #define SUCCESS 0
12 #define FAIL    (-1)
13
14 #include <linux/types.h>
15
16 typedef signed int sint;
17
18 #define FIELD_OFFSET(s, field)  ((__kernel_ssize_t)&((s*)(0))->field)
19
20 #define SIZE_PTR __kernel_size_t
21 #define SSIZE_PTR __kernel_ssize_t
22
23 /* port from fw by thomas */
24 /*  TODO: Belows are Sync from SD7-Driver. It is necessary to check correctness */
25
26 /*
27  *Call endian free function when
28  *      1. Read/write packet content.
29  *      2. Before write integer to IO.
30  *      3. After read integer from IO.
31 */
32
33 /*  */
34 /*  Byte Swapping routine. */
35 /*  */
36 #define EF1Byte (u8)
37 #define EF2Byte         le16_to_cpu
38 #define EF4Byte le32_to_cpu
39
40 /* Convert little data endian to host ordering */
41 #define EF1BYTE(_val)           \
42         ((u8)(_val))
43 #define EF2BYTE(_val)           \
44         (le16_to_cpu(_val))
45 #define EF4BYTE(_val)           \
46         (le32_to_cpu(_val))
47
48 /* Read data from memory */
49 #define READEF1BYTE(_ptr)       \
50         EF1BYTE(*((u8 *)(_ptr)))
51 /* Read le16 data from memory and convert to host ordering */
52 #define READEF2BYTE(_ptr)       \
53         EF2BYTE(*(_ptr))
54 #define READEF4BYTE(_ptr)       \
55         EF4BYTE(*(_ptr))
56
57 /* Write data to memory */
58 #define WRITEEF1BYTE(_ptr, _val)                        \
59         do {                                            \
60                 (*((u8 *)(_ptr))) = EF1BYTE(_val);      \
61         } while (0)
62 /* Write le data to memory in host ordering */
63 #define WRITEEF2BYTE(_ptr, _val)                        \
64         do {                                            \
65                 (*((u16 *)(_ptr))) = EF2BYTE(_val);     \
66         } while (0)
67
68 #define WRITEEF4BYTE(_ptr, _val)                        \
69         do {                                            \
70                 (*((u32 *)(_ptr))) = EF2BYTE(_val);     \
71         } while (0)
72
73 /* Create a bit mask
74  * Examples:
75  * BIT_LEN_MASK_32(0) => 0x00000000
76  * BIT_LEN_MASK_32(1) => 0x00000001
77  * BIT_LEN_MASK_32(2) => 0x00000003
78  * BIT_LEN_MASK_32(32) => 0xFFFFFFFF
79  */
80 #define BIT_LEN_MASK_32(__bitlen)        \
81         (0xFFFFFFFF >> (32 - (__bitlen)))
82 #define BIT_LEN_MASK_16(__bitlen)        \
83         (0xFFFF >> (16 - (__bitlen)))
84 #define BIT_LEN_MASK_8(__bitlen) \
85         (0xFF >> (8 - (__bitlen)))
86
87 /* Create an offset bit mask
88  * Examples:
89  * BIT_OFFSET_LEN_MASK_32(0, 2) => 0x00000003
90  * BIT_OFFSET_LEN_MASK_32(16, 2) => 0x00030000
91  */
92 #define BIT_OFFSET_LEN_MASK_32(__bitoffset, __bitlen) \
93         (BIT_LEN_MASK_32(__bitlen) << (__bitoffset))
94 #define BIT_OFFSET_LEN_MASK_16(__bitoffset, __bitlen) \
95         (BIT_LEN_MASK_16(__bitlen) << (__bitoffset))
96 #define BIT_OFFSET_LEN_MASK_8(__bitoffset, __bitlen) \
97         (BIT_LEN_MASK_8(__bitlen) << (__bitoffset))
98
99 /*Description:
100  * Return 4-byte value in host byte ordering from
101  * 4-byte pointer in little-endian system.
102  */
103 #define LE_P4BYTE_TO_HOST_4BYTE(__pstart) \
104         (EF4BYTE(*((__le32 *)(__pstart))))
105 #define LE_P2BYTE_TO_HOST_2BYTE(__pstart) \
106         (EF2BYTE(*((__le16 *)(__pstart))))
107 #define LE_P1BYTE_TO_HOST_1BYTE(__pstart) \
108         (EF1BYTE(*((u8 *)(__pstart))))
109
110 /*  */
111 /*      Description: */
112 /*              Translate subfield (continuous bits in little-endian) of 4-byte value in litten byte to */
113 /*              4-byte value in host byte ordering. */
114 /*  */
115 #define LE_BITS_TO_4BYTE(__pstart, __bitoffset, __bitlen) \
116         (\
117                 (LE_P4BYTE_TO_HOST_4BYTE(__pstart) >> (__bitoffset))  & \
118                 BIT_LEN_MASK_32(__bitlen) \
119         )
120 #define LE_BITS_TO_2BYTE(__pstart, __bitoffset, __bitlen) \
121         (\
122                 (LE_P2BYTE_TO_HOST_2BYTE(__pstart) >> (__bitoffset)) & \
123                 BIT_LEN_MASK_16(__bitlen) \
124         )
125 #define LE_BITS_TO_1BYTE(__pstart, __bitoffset, __bitlen) \
126         (\
127                 (LE_P1BYTE_TO_HOST_1BYTE(__pstart) >> (__bitoffset)) & \
128                 BIT_LEN_MASK_8(__bitlen) \
129         )
130
131 /*  */
132 /*      Description: */
133 /*              Mask subfield (continuous bits in little-endian) of 4-byte value in litten byte oredering */
134 /*              and return the result in 4-byte value in host byte ordering. */
135 /*  */
136 #define LE_BITS_CLEARED_TO_4BYTE(__pstart, __bitoffset, __bitlen) \
137         (\
138                 LE_P4BYTE_TO_HOST_4BYTE(__pstart)  & \
139                 (~BIT_OFFSET_LEN_MASK_32(__bitoffset, __bitlen)) \
140         )
141 #define LE_BITS_CLEARED_TO_2BYTE(__pstart, __bitoffset, __bitlen) \
142         (\
143                 LE_P2BYTE_TO_HOST_2BYTE(__pstart) & \
144                 (~BIT_OFFSET_LEN_MASK_16(__bitoffset, __bitlen)) \
145         )
146 #define LE_BITS_CLEARED_TO_1BYTE(__pstart, __bitoffset, __bitlen) \
147         (\
148                 LE_P1BYTE_TO_HOST_1BYTE(__pstart) & \
149                 (~BIT_OFFSET_LEN_MASK_8(__bitoffset, __bitlen)) \
150         )
151
152 /*  */
153 /*      Description: */
154 /*              Set subfield of little-endian 4-byte value to specified value. */
155 /*  */
156 #define SET_BITS_TO_LE_4BYTE(__pstart, __bitoffset, __bitlen, __val) \
157                 *((u32 *)(__pstart)) =                          \
158                 (                                               \
159                 LE_BITS_CLEARED_TO_4BYTE(__pstart, __bitoffset, __bitlen) | \
160                 ((((u32)__val) & BIT_LEN_MASK_32(__bitlen)) << (__bitoffset)) \
161                 )
162
163 #define SET_BITS_TO_LE_2BYTE(__pstart, __bitoffset, __bitlen, __val) \
164                 *((u16 *)(__pstart)) =                          \
165                 (                                       \
166                 LE_BITS_CLEARED_TO_2BYTE(__pstart, __bitoffset, __bitlen) | \
167                 ((((u16)__val) & BIT_LEN_MASK_16(__bitlen)) << (__bitoffset)) \
168                 );
169
170 #define SET_BITS_TO_LE_1BYTE(__pstart, __bitoffset, __bitlen, __val) \
171                 *((u8 *)(__pstart)) = EF1BYTE                   \
172                 (                                       \
173                 LE_BITS_CLEARED_TO_1BYTE(__pstart, __bitoffset, __bitlen) | \
174                 ((((u8)__val) & BIT_LEN_MASK_8(__bitlen)) << (__bitoffset)) \
175                 )
176
177 #define LE_BITS_CLEARED_TO_1BYTE_8BIT(__pStart, __BitOffset, __BitLen) \
178         (\
179                 LE_P1BYTE_TO_HOST_1BYTE(__pStart) \
180         )
181
182 #define SET_BITS_TO_LE_1BYTE_8BIT(__pStart, __BitOffset, __BitLen, __Value) \
183 { \
184         *((u8 *)(__pStart)) = \
185                 EF1Byte(\
186                         LE_BITS_CLEARED_TO_1BYTE_8BIT(__pStart, __BitOffset, __BitLen) \
187                         | \
188                         ((u8)__Value) \
189                 ); \
190 }
191
192 /*  Get the N-bytes aligment offset from the current length */
193 #define N_BYTE_ALIGMENT(__Value, __Aligment) ((__Aligment == 1) ? (__Value) : (((__Value + __Aligment - 1) / __Aligment) * __Aligment))
194
195 #define TEST_FLAG(__Flag, __testFlag)           (((__Flag) & (__testFlag)) != 0)
196 #define SET_FLAG(__Flag, __setFlag)                     ((__Flag) |= __setFlag)
197 #define CLEAR_FLAG(__Flag, __clearFlag)         ((__Flag) &= ~(__clearFlag))
198 #define CLEAR_FLAGS(__Flag)                                     ((__Flag) = 0)
199 #define TEST_FLAGS(__Flag, __testFlags)         (((__Flag) & (__testFlags)) == (__testFlags))
200
201 #endif /* __BASIC_TYPES_H__ */