annotate gcc/config/powerpcspe/htmintrin.h @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Hardware Transactional Memory (HTM) intrinsics.
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
2 Copyright (C) 2013-2018 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
3 Contributed by Peter Bergner <bergner@vnet.ibm.com>.
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 This file is free software; you can redistribute it and/or modify it under
kono
parents:
diff changeset
6 the terms of the GNU General Public License as published by the Free
kono
parents:
diff changeset
7 Software Foundation; either version 3 of the License, or (at your option)
kono
parents:
diff changeset
8 any later version.
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 This file is distributed in the hope that it will be useful, but WITHOUT
kono
parents:
diff changeset
11 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
kono
parents:
diff changeset
12 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
kono
parents:
diff changeset
13 for more details.
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 Under Section 7 of GPL version 3, you are granted additional
kono
parents:
diff changeset
16 permissions described in the GCC Runtime Library Exception, version
kono
parents:
diff changeset
17 3.1, as published by the Free Software Foundation.
kono
parents:
diff changeset
18
kono
parents:
diff changeset
19 You should have received a copy of the GNU General Public License and
kono
parents:
diff changeset
20 a copy of the GCC Runtime Library Exception along with this program;
kono
parents:
diff changeset
21 see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
kono
parents:
diff changeset
22 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 #ifndef __HTM__
kono
parents:
diff changeset
25 # error "HTM instruction set not enabled"
kono
parents:
diff changeset
26 #endif /* __HTM__ */
kono
parents:
diff changeset
27
kono
parents:
diff changeset
28 #ifndef _HTMINTRIN_H
kono
parents:
diff changeset
29 #define _HTMINTRIN_H
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 #include <stdint.h>
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 typedef uint64_t texasr_t;
kono
parents:
diff changeset
34 typedef uint32_t texasru_t;
kono
parents:
diff changeset
35 typedef uint32_t texasrl_t;
kono
parents:
diff changeset
36 typedef uintptr_t tfiar_t;
kono
parents:
diff changeset
37 typedef uintptr_t tfhar_t;
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 #define _HTM_STATE(CR0) ((CR0 >> 1) & 0x3)
kono
parents:
diff changeset
40 #define _HTM_NONTRANSACTIONAL 0x0
kono
parents:
diff changeset
41 #define _HTM_SUSPENDED 0x1
kono
parents:
diff changeset
42 #define _HTM_TRANSACTIONAL 0x2
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 /* The following macros use the IBM bit numbering for BITNUM
kono
parents:
diff changeset
45 as used in the ISA documentation. */
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 #define _TEXASR_EXTRACT_BITS(TEXASR,BITNUM,SIZE) \
kono
parents:
diff changeset
48 (((TEXASR) >> (63-(BITNUM))) & ((1<<(SIZE))-1))
kono
parents:
diff changeset
49 #define _TEXASRU_EXTRACT_BITS(TEXASR,BITNUM,SIZE) \
kono
parents:
diff changeset
50 (((TEXASR) >> (31-(BITNUM))) & ((1<<(SIZE))-1))
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52 #define _TEXASR_FAILURE_CODE(TEXASR) \
kono
parents:
diff changeset
53 _TEXASR_EXTRACT_BITS(TEXASR, 7, 8)
kono
parents:
diff changeset
54 #define _TEXASRU_FAILURE_CODE(TEXASRU) \
kono
parents:
diff changeset
55 _TEXASRU_EXTRACT_BITS(TEXASRU, 7, 8)
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 #define _TEXASR_FAILURE_PERSISTENT(TEXASR) \
kono
parents:
diff changeset
58 _TEXASR_EXTRACT_BITS(TEXASR, 7, 1)
kono
parents:
diff changeset
59 #define _TEXASRU_FAILURE_PERSISTENT(TEXASRU) \
kono
parents:
diff changeset
60 _TEXASRU_EXTRACT_BITS(TEXASRU, 7, 1)
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 #define _TEXASR_DISALLOWED(TEXASR) \
kono
parents:
diff changeset
63 _TEXASR_EXTRACT_BITS(TEXASR, 8, 1)
kono
parents:
diff changeset
64 #define _TEXASRU_DISALLOWED(TEXASRU) \
kono
parents:
diff changeset
65 _TEXASRU_EXTRACT_BITS(TEXASRU, 8, 1)
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 #define _TEXASR_NESTING_OVERFLOW(TEXASR) \
kono
parents:
diff changeset
68 _TEXASR_EXTRACT_BITS(TEXASR, 9, 1)
kono
parents:
diff changeset
69 #define _TEXASRU_NESTING_OVERFLOW(TEXASRU) \
kono
parents:
diff changeset
70 _TEXASRU_EXTRACT_BITS(TEXASRU, 9, 1)
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 #define _TEXASR_FOOTPRINT_OVERFLOW(TEXASR) \
kono
parents:
diff changeset
73 _TEXASR_EXTRACT_BITS(TEXASR, 10, 1)
kono
parents:
diff changeset
74 #define _TEXASRU_FOOTPRINT_OVERFLOW(TEXASRU) \
kono
parents:
diff changeset
75 _TEXASRU_EXTRACT_BITS(TEXASRU, 10, 1)
kono
parents:
diff changeset
76
kono
parents:
diff changeset
77 #define _TEXASR_SELF_INDUCED_CONFLICT(TEXASR) \
kono
parents:
diff changeset
78 _TEXASR_EXTRACT_BITS(TEXASR, 11, 1)
kono
parents:
diff changeset
79 #define _TEXASRU_SELF_INDUCED_CONFLICT(TEXASRU) \
kono
parents:
diff changeset
80 _TEXASRU_EXTRACT_BITS(TEXASRU, 11, 1)
kono
parents:
diff changeset
81
kono
parents:
diff changeset
82 #define _TEXASR_NON_TRANSACTIONAL_CONFLICT(TEXASR) \
kono
parents:
diff changeset
83 _TEXASR_EXTRACT_BITS(TEXASR, 12, 1)
kono
parents:
diff changeset
84 #define _TEXASRU_NON_TRANSACTIONAL_CONFLICT(TEXASRU) \
kono
parents:
diff changeset
85 _TEXASRU_EXTRACT_BITS(TEXASRU, 12, 1)
kono
parents:
diff changeset
86
kono
parents:
diff changeset
87 #define _TEXASR_TRANSACTION_CONFLICT(TEXASR) \
kono
parents:
diff changeset
88 _TEXASR_EXTRACT_BITS(TEXASR, 13, 1)
kono
parents:
diff changeset
89 #define _TEXASRU_TRANSACTION_CONFLICT(TEXASRU) \
kono
parents:
diff changeset
90 _TEXASRU_EXTRACT_BITS(TEXASRU, 13, 1)
kono
parents:
diff changeset
91
kono
parents:
diff changeset
92 #define _TEXASR_TRANSLATION_INVALIDATION_CONFLICT(TEXASR) \
kono
parents:
diff changeset
93 _TEXASR_EXTRACT_BITS(TEXASR, 14, 1)
kono
parents:
diff changeset
94 #define _TEXASRU_TRANSLATION_INVALIDATION_CONFLICT(TEXASRU) \
kono
parents:
diff changeset
95 _TEXASRU_EXTRACT_BITS(TEXASRU, 14, 1)
kono
parents:
diff changeset
96
kono
parents:
diff changeset
97 #define _TEXASR_IMPLEMENTAION_SPECIFIC(TEXASR) \
kono
parents:
diff changeset
98 _TEXASR_EXTRACT_BITS(TEXASR, 15, 1)
kono
parents:
diff changeset
99 #define _TEXASRU_IMPLEMENTAION_SPECIFIC(TEXASRU) \
kono
parents:
diff changeset
100 _TEXASRU_EXTRACT_BITS(TEXASRU, 15, 1)
kono
parents:
diff changeset
101
kono
parents:
diff changeset
102 #define _TEXASR_INSTRUCTION_FETCH_CONFLICT(TEXASR) \
kono
parents:
diff changeset
103 _TEXASR_EXTRACT_BITS(TEXASR, 16, 1)
kono
parents:
diff changeset
104 #define _TEXASRU_INSTRUCTION_FETCH_CONFLICT(TEXASRU) \
kono
parents:
diff changeset
105 _TEXASRU_EXTRACT_BITS(TEXASRU, 16, 1)
kono
parents:
diff changeset
106
kono
parents:
diff changeset
107 #define _TEXASR_ABORT(TEXASR) \
kono
parents:
diff changeset
108 _TEXASR_EXTRACT_BITS(TEXASR, 31, 1)
kono
parents:
diff changeset
109 #define _TEXASRU_ABORT(TEXASRU) \
kono
parents:
diff changeset
110 _TEXASRU_EXTRACT_BITS(TEXASRU, 31, 1)
kono
parents:
diff changeset
111
kono
parents:
diff changeset
112
kono
parents:
diff changeset
113 #define _TEXASR_SUSPENDED(TEXASR) \
kono
parents:
diff changeset
114 _TEXASR_EXTRACT_BITS(TEXASR, 32, 1)
kono
parents:
diff changeset
115
kono
parents:
diff changeset
116 #define _TEXASR_PRIVILEGE(TEXASR) \
kono
parents:
diff changeset
117 _TEXASR_EXTRACT_BITS(TEXASR, 35, 2)
kono
parents:
diff changeset
118
kono
parents:
diff changeset
119 #define _TEXASR_FAILURE_SUMMARY(TEXASR) \
kono
parents:
diff changeset
120 _TEXASR_EXTRACT_BITS(TEXASR, 36, 1)
kono
parents:
diff changeset
121
kono
parents:
diff changeset
122 #define _TEXASR_TFIAR_EXACT(TEXASR) \
kono
parents:
diff changeset
123 _TEXASR_EXTRACT_BITS(TEXASR, 37, 1)
kono
parents:
diff changeset
124
kono
parents:
diff changeset
125 #define _TEXASR_ROT(TEXASR) \
kono
parents:
diff changeset
126 _TEXASR_EXTRACT_BITS(TEXASR, 38, 1)
kono
parents:
diff changeset
127
kono
parents:
diff changeset
128 #define _TEXASR_TRANSACTION_LEVEL(TEXASR) \
kono
parents:
diff changeset
129 _TEXASR_EXTRACT_BITS(TEXASR, 63, 12)
kono
parents:
diff changeset
130
kono
parents:
diff changeset
131 #endif /* _HTMINTRIN_H */