extend.texi (x86 transactional memory intrinsics): Reorganize discussion of _xbegin.
authorSandra Loosemore <sandra@codesourcery.com>
Fri, 27 Feb 2015 18:59:29 +0000 (13:59 -0500)
committerSandra Loosemore <sandra@gcc.gnu.org>
Fri, 27 Feb 2015 18:59:29 +0000 (13:59 -0500)
2015-02-27  Sandra Loosemore  <sandra@codesourcery.com>

gcc/
* doc/extend.texi (x86 transactional memory intrinsics):
Reorganize discussion of _xbegin.  Clarify that the return
value is a bit mask.  Expand example and move to end of section.

From-SVN: r221068

gcc/ChangeLog
gcc/doc/extend.texi

index bae6265d6da343b87d2bd2b997ababc35844c447..06ea6d8296b88e643224c2a4eff8a76a5643314e 100644 (file)
@@ -1,3 +1,9 @@
+2015-02-27  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * doc/extend.texi (x86 transactional memory intrinsics):
+       Reorganize discussion of _xbegin.  Clarify that the return
+       value is a bit mask.  Expand example and move to end of section.
+
 2015-02-26  Jakub Jelinek  <jakub@redhat.com>
            Aldy Hernandez  <aldyh@redhat.com>
 
index c066d32274e014d46cd3b30358f736e5c7a01909..eb818613eed61e331907c9339c39023691165ea0 100644 (file)
@@ -17274,24 +17274,11 @@ and suitable fallback code always needs to be supplied.
 Start a RTM (Restricted Transactional Memory) transaction. 
 Returns @code{_XBEGIN_STARTED} when the transaction
 started successfully (note this is not 0, so the constant has to be 
-explicitly tested).  If the transaction aborts, all side-effects
-are undone and an abort code is returned. There is no guarantee
-any transaction ever succeeds, so there always needs to be a valid
-fallback path.
-@end deftypefn
-
-@smallexample
-#include <immintrin.h>
-
-if ((status = _xbegin ()) == _XBEGIN_STARTED) @{
-    ... transaction code...
-    _xend ();
-@} else @{
-    ... non transactional fallback path...
-@}
-@end smallexample
+explicitly tested).  
 
-If the transaction aborts, the return value is one of:
+If the transaction aborts, all side-effects 
+are undone and an abort code encoded as a bit mask is returned.
+The following macros are defined:
 
 @table @code
 @item _XABORT_EXPLICIT
@@ -17309,6 +17296,11 @@ Transaction abort due to a debug trap.
 Transaction abort in an inner nested transaction.
 @end table
 
+There is no guarantee
+any transaction ever succeeds, so there always needs to be a valid
+fallback path.
+@end deftypefn
+
 @deftypefn {RTM Function} {void} _xend ()
 Commit the current transaction. When no transaction is active this faults.
 All memory side-effects of the transaction become visible
@@ -17325,6 +17317,37 @@ The @var{status} is an 8-bit constant; its value is encoded in the return
 value from @code{_xbegin}.
 @end deftypefn
 
+Here is an example showing handling for @code{_XABORT_RETRY}
+and a fallback path for other failures:
+
+@smallexample
+#include <immintrin.h>
+
+int n_tries, max_tries;
+unsigned status = _XABORT_EXPLICIT;
+...
+
+for (n_tries = 0; n_tries < max_tries; n_tries++) 
+  @{
+    status = _xbegin ();
+    if (status == _XBEGIN_STARTED || !(status & _XABORT_RETRY))
+      break;
+  @}
+if (status == _XBEGIN_STARTED) 
+  @{
+    ... transaction code...
+    _xend ();
+  @} 
+else 
+  @{
+    ... non-transactional fallback path...
+  @}
+@end smallexample
+
+@noindent
+Note that, in most cases, the transactional and non-transactional code
+must synchronize together to ensure consistency.
+
 @node Target Format Checks
 @section Format Checks Specific to Particular Target Machines