annotate libbacktrace/atomic.c @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents 84e7813d76e9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* atomic.c -- Support for atomic functions if not present.
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
2 Copyright (C) 2013-2020 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
3 Written by Ian Lance Taylor, Google.
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 Redistribution and use in source and binary forms, with or without
kono
parents:
diff changeset
6 modification, are permitted provided that the following conditions are
kono
parents:
diff changeset
7 met:
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 (1) Redistributions of source code must retain the above copyright
kono
parents:
diff changeset
10 notice, this list of conditions and the following disclaimer.
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 (2) Redistributions in binary form must reproduce the above copyright
kono
parents:
diff changeset
13 notice, this list of conditions and the following disclaimer in
kono
parents:
diff changeset
14 the documentation and/or other materials provided with the
kono
parents:
diff changeset
15 distribution.
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 (3) The name of the author may not be used to
kono
parents:
diff changeset
18 endorse or promote products derived from this software without
kono
parents:
diff changeset
19 specific prior written permission.
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
kono
parents:
diff changeset
22 IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
kono
parents:
diff changeset
23 WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
kono
parents:
diff changeset
24 DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
kono
parents:
diff changeset
25 INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
kono
parents:
diff changeset
26 (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
kono
parents:
diff changeset
27 SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
kono
parents:
diff changeset
28 HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
kono
parents:
diff changeset
29 STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
kono
parents:
diff changeset
30 IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
kono
parents:
diff changeset
31 POSSIBILITY OF SUCH DAMAGE. */
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 #include "config.h"
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 #include <sys/types.h>
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 #include "backtrace.h"
kono
parents:
diff changeset
38 #include "backtrace-supported.h"
kono
parents:
diff changeset
39 #include "internal.h"
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 /* This file holds implementations of the atomic functions that are
kono
parents:
diff changeset
42 used if the host compiler has the sync functions but not the atomic
kono
parents:
diff changeset
43 functions, as is true of versions of GCC before 4.7. */
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 #if !defined (HAVE_ATOMIC_FUNCTIONS) && defined (HAVE_SYNC_FUNCTIONS)
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 /* Do an atomic load of a pointer. */
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49 void *
kono
parents:
diff changeset
50 backtrace_atomic_load_pointer (void *arg)
kono
parents:
diff changeset
51 {
kono
parents:
diff changeset
52 void **pp;
kono
parents:
diff changeset
53 void *p;
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 pp = (void **) arg;
kono
parents:
diff changeset
56 p = *pp;
kono
parents:
diff changeset
57 while (!__sync_bool_compare_and_swap (pp, p, p))
kono
parents:
diff changeset
58 p = *pp;
kono
parents:
diff changeset
59 return p;
kono
parents:
diff changeset
60 }
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 /* Do an atomic load of an int. */
kono
parents:
diff changeset
63
kono
parents:
diff changeset
64 int
kono
parents:
diff changeset
65 backtrace_atomic_load_int (int *p)
kono
parents:
diff changeset
66 {
kono
parents:
diff changeset
67 int i;
kono
parents:
diff changeset
68
kono
parents:
diff changeset
69 i = *p;
kono
parents:
diff changeset
70 while (!__sync_bool_compare_and_swap (p, i, i))
kono
parents:
diff changeset
71 i = *p;
kono
parents:
diff changeset
72 return i;
kono
parents:
diff changeset
73 }
kono
parents:
diff changeset
74
kono
parents:
diff changeset
75 /* Do an atomic store of a pointer. */
kono
parents:
diff changeset
76
kono
parents:
diff changeset
77 void
kono
parents:
diff changeset
78 backtrace_atomic_store_pointer (void *arg, void *p)
kono
parents:
diff changeset
79 {
kono
parents:
diff changeset
80 void **pp;
kono
parents:
diff changeset
81 void *old;
kono
parents:
diff changeset
82
kono
parents:
diff changeset
83 pp = (void **) arg;
kono
parents:
diff changeset
84 old = *pp;
kono
parents:
diff changeset
85 while (!__sync_bool_compare_and_swap (pp, old, p))
kono
parents:
diff changeset
86 old = *pp;
kono
parents:
diff changeset
87 }
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 /* Do an atomic store of a size_t value. */
kono
parents:
diff changeset
90
kono
parents:
diff changeset
91 void
kono
parents:
diff changeset
92 backtrace_atomic_store_size_t (size_t *p, size_t v)
kono
parents:
diff changeset
93 {
kono
parents:
diff changeset
94 size_t old;
kono
parents:
diff changeset
95
kono
parents:
diff changeset
96 old = *p;
kono
parents:
diff changeset
97 while (!__sync_bool_compare_and_swap (p, old, v))
kono
parents:
diff changeset
98 old = *p;
kono
parents:
diff changeset
99 }
kono
parents:
diff changeset
100
kono
parents:
diff changeset
101 /* Do an atomic store of a int value. */
kono
parents:
diff changeset
102
kono
parents:
diff changeset
103 void
kono
parents:
diff changeset
104 backtrace_atomic_store_int (int *p, int v)
kono
parents:
diff changeset
105 {
kono
parents:
diff changeset
106 size_t old;
kono
parents:
diff changeset
107
kono
parents:
diff changeset
108 old = *p;
kono
parents:
diff changeset
109 while (!__sync_bool_compare_and_swap (p, old, v))
kono
parents:
diff changeset
110 old = *p;
kono
parents:
diff changeset
111 }
kono
parents:
diff changeset
112
kono
parents:
diff changeset
113 #endif