1 // Copyright 2010-2019 Espressif Systems (Shanghai) PTE LTD
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 //     http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14 
15 #pragma once
16 
17 //Register Bits{{
18 #define BIT31   0x80000000
19 #define BIT30   0x40000000
20 #define BIT29   0x20000000
21 #define BIT28   0x10000000
22 #define BIT27   0x08000000
23 #define BIT26   0x04000000
24 #define BIT25   0x02000000
25 #define BIT24   0x01000000
26 #define BIT23   0x00800000
27 #define BIT22   0x00400000
28 #define BIT21   0x00200000
29 #define BIT20   0x00100000
30 #define BIT19   0x00080000
31 #define BIT18   0x00040000
32 #define BIT17   0x00020000
33 #define BIT16   0x00010000
34 #define BIT15   0x00008000
35 #define BIT14   0x00004000
36 #define BIT13   0x00002000
37 #define BIT12   0x00001000
38 #define BIT11   0x00000800
39 #define BIT10   0x00000400
40 #define BIT9     0x00000200
41 #define BIT8     0x00000100
42 #define BIT7     0x00000080
43 #define BIT6     0x00000040
44 #define BIT5     0x00000020
45 #define BIT4     0x00000010
46 #define BIT3     0x00000008
47 #define BIT2     0x00000004
48 #define BIT1     0x00000002
49 #define BIT0     0x00000001
50 //}}
51 
52 #define BIT63    (0x80000000ULL << 32)
53 #define BIT62    (0x40000000ULL << 32)
54 #define BIT61    (0x20000000ULL << 32)
55 #define BIT60    (0x10000000ULL << 32)
56 #define BIT59    (0x08000000ULL << 32)
57 #define BIT58    (0x04000000ULL << 32)
58 #define BIT57    (0x02000000ULL << 32)
59 #define BIT56    (0x01000000ULL << 32)
60 #define BIT55    (0x00800000ULL << 32)
61 #define BIT54    (0x00400000ULL << 32)
62 #define BIT53    (0x00200000ULL << 32)
63 #define BIT52    (0x00100000ULL << 32)
64 #define BIT51    (0x00080000ULL << 32)
65 #define BIT50    (0x00040000ULL << 32)
66 #define BIT49    (0x00020000ULL << 32)
67 #define BIT48    (0x00010000ULL << 32)
68 #define BIT47    (0x00008000ULL << 32)
69 #define BIT46    (0x00004000ULL << 32)
70 #define BIT45    (0x00002000ULL << 32)
71 #define BIT44    (0x00001000ULL << 32)
72 #define BIT43    (0x00000800ULL << 32)
73 #define BIT42    (0x00000400ULL << 32)
74 #define BIT41    (0x00000200ULL << 32)
75 #define BIT40    (0x00000100ULL << 32)
76 #define BIT39    (0x00000080ULL << 32)
77 #define BIT38    (0x00000040ULL << 32)
78 #define BIT37    (0x00000020ULL << 32)
79 #define BIT36    (0x00000010ULL << 32)
80 #define BIT35    (0x00000008ULL << 32)
81 #define BIT34    (0x00000004ULL << 32)
82 #define BIT33    (0x00000002ULL << 32)
83 #define BIT32    (0x00000001ULL << 32)
84 
85 #ifndef __ASSEMBLER__
86 #ifndef BIT
87 #define BIT(nr)                 (1UL << (nr))
88 #endif
89 #ifndef BIT64
90 #define BIT64(_n)               (1ULL << (_n))
91 #endif
92 #else
93 #ifndef BIT
94 #define BIT(nr)                 (1 << (nr))
95 #endif
96 #endif
97