source: mainline/uspace/lib/c/generic/thread/atomic.c@ 6340b4d2

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 6340b4d2 was 6340b4d2, checked in by Jiří Zárevúcky <jiri.zarevucky@…>, 7 years ago

libc: Put threading-related files into a subdirectory.

  • Property mode set to 100644
File size: 2.3 KB
Line 
1/*
2 * Copyright (c) 2018 CZ.NIC, z.s.p.o.
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29#include <atomic.h>
30
31#ifdef PLATFORM_arm32
32
33/*
34 * Older ARMs don't have atomic instructions, so we need to define a bunch
35 * of symbols for GCC to use.
36 */
37
38unsigned __sync_add_and_fetch_4(volatile void *vptr, unsigned val)
39{
40 return atomic_add((atomic_t *)vptr, val);
41}
42
43unsigned __sync_sub_and_fetch_4(volatile void *vptr, unsigned val)
44{
45 return atomic_add((atomic_t *)vptr, -(atomic_signed_t)val);
46}
47
48bool __sync_bool_compare_and_swap_4(volatile void *ptr, unsigned old_val, unsigned new_val)
49{
50 return cas((atomic_t *)ptr, old_val, new_val);
51}
52
53unsigned __sync_val_compare_and_swap_4(volatile void *ptr, unsigned old_val, unsigned new_val)
54{
55 while (true) {
56 if (__sync_bool_compare_and_swap_4(ptr, old_val, new_val)) {
57 return old_val;
58 }
59
60 unsigned current = *(volatile unsigned *)ptr;
61 if (current != old_val)
62 return current;
63
64 /* If the current value is the same as old_val, retry. */
65 }
66}
67
68#endif
Note: See TracBrowser for help on using the repository browser.