You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

73 lines
1.8 KiB
C

/* SPDX-License-Identifier: GPL-3.0-or-later */
/* See the end of this file for copyright, license, and warranty information. */
#include <ardix/atom.h>
void atom_init(atom_t *atom)
{
atom->count = 0;
}
int atom_get(atom_t *atom)
{
int tmp;
int newval;
atom_t atom_val;
__asm__ volatile(
"1: ldrex %0, [%3] \n" /* atom_val = *atom */
" add %1, %0, #1 \n" /* newval = atom_val.count + 1 */
" strex %2, %1, [%3] \n" /* *atom = newval */
" teq %2, #0 \n" /* store successful? */
" bne 1b \n" /* -> goto 1 if not */
" dmb " /* memory barrier */
: "=&r" (atom_val), "=&r" (newval), "=&r" (tmp)
: "r" (atom)
: "cc");
return newval;
}
int atom_put(atom_t *atom)
{
int tmp;
int newval;
atom_t atom_val;
__asm__ volatile(
"1: ldrex %0, [%3] \n" /* atom_val = *atom */
" sub %1, %0, #1 \n" /* newval = atom_val.count - 1 */
" strex %2, %1, [%3] \n" /* *atom = newval */
" teq %2, #0 \n" /* store successful? */
" bne 1b \n" /* -> goto 1 if not */
" dmb " /* memory barrier */
: "=&r" (atom_val), "=&r" (newval), "=&r" (tmp)
: "r" (atom)
: "cc");
return newval;
}
int atom_count(atom_t *atom)
{
return atom->count;
}
/*
* This file is part of Ardix.
* Copyright (c) 2020, 2021 Felix Kopp <owo@fef.moe>.
*
* Ardix is free software: you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Ardix is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/