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

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* GNU compiler hardware transactional execution 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 Andreas Krebbel (Andreas.Krebbel@de.ibm.com)
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 This file is part of GCC.
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 GCC is free software; you can redistribute it and/or modify it under
kono
parents:
diff changeset
8 the terms of the GNU General Public License as published by the Free
kono
parents:
diff changeset
9 Software Foundation; either version 3, or (at your option) any later
kono
parents:
diff changeset
10 version.
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
kono
parents:
diff changeset
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
kono
parents:
diff changeset
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
kono
parents:
diff changeset
15 for more details.
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
kono
parents:
diff changeset
18 along with GCC; see the file COPYING3. If not see
kono
parents:
diff changeset
19 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 #ifndef _HTMINTRIN_H
kono
parents:
diff changeset
22 #define _HTMINTRIN_H
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 /* Condition codes generated by tbegin */
kono
parents:
diff changeset
26 #define _HTM_TBEGIN_STARTED 0
kono
parents:
diff changeset
27 #define _HTM_TBEGIN_INDETERMINATE 1
kono
parents:
diff changeset
28 #define _HTM_TBEGIN_TRANSIENT 2
kono
parents:
diff changeset
29 #define _HTM_TBEGIN_PERSISTENT 3
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 /* The abort codes below this threshold are reserved for machine
kono
parents:
diff changeset
32 use. */
kono
parents:
diff changeset
33 #define _HTM_FIRST_USER_ABORT_CODE 256
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 /* The transaction diagnostic block is it is defined in the Principles
kono
parents:
diff changeset
36 of Operation chapter 5-91. */
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 struct __htm_tdb {
kono
parents:
diff changeset
39 unsigned char format; /* 0 */
kono
parents:
diff changeset
40 unsigned char flags;
kono
parents:
diff changeset
41 unsigned char reserved1[4];
kono
parents:
diff changeset
42 unsigned short nesting_depth;
kono
parents:
diff changeset
43 unsigned long long abort_code; /* 8 */
kono
parents:
diff changeset
44 unsigned long long conflict_token; /* 16 */
kono
parents:
diff changeset
45 unsigned long long atia; /* 24 */
kono
parents:
diff changeset
46 unsigned char eaid; /* 32 */
kono
parents:
diff changeset
47 unsigned char dxc;
kono
parents:
diff changeset
48 unsigned char reserved2[2];
kono
parents:
diff changeset
49 unsigned int program_int_id;
kono
parents:
diff changeset
50 unsigned long long exception_id; /* 40 */
kono
parents:
diff changeset
51 unsigned long long bea; /* 48 */
kono
parents:
diff changeset
52 unsigned char reserved3[72]; /* 56 */
kono
parents:
diff changeset
53 unsigned long long gprs[16]; /* 128 */
kono
parents:
diff changeset
54 } __attribute__((__packed__, __aligned__ (8)));
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 #endif /* _HTMINTRIN_H */