Skip to content

Commit

Permalink
Add support for the RISC-V architecture
Browse files Browse the repository at this point in the history
Tested in QEMU 2.12.0-rc0, requires --disable-compiler-tls to go
through the benchmarks reliably.

Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
  • Loading branch information
mjeanson authored and compudj committed Mar 23, 2018
1 parent 4b2d70a commit fdfad81
Show file tree
Hide file tree
Showing 4 changed files with 96 additions and 0 deletions.
1 change: 1 addition & 0 deletions configure.ac
Original file line number Diff line number Diff line change
Expand Up @@ -151,6 +151,7 @@ AS_CASE([$host_cpu],
[tile*], [ARCHTYPE="tile"],
[hppa*], [ARCHTYPE="hppa"],
[m68k], [ARCHTYPE="m68k"],
[riscv*], [ARCHTYPE="riscv"],
[ARCHTYPE="unknown"]
)

Expand Down
2 changes: 2 additions & 0 deletions include/Makefile.am
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ EXTRA_DIST = urcu/arch/aarch64.h \
urcu/arch/mips.h \
urcu/arch/nios2.h \
urcu/arch/ppc.h \
urcu/arch/riscv.h \
urcu/arch/s390.h \
urcu/arch/sparc64.h \
urcu/arch/tile.h \
Expand All @@ -43,6 +44,7 @@ EXTRA_DIST = urcu/arch/aarch64.h \
urcu/uatomic/mips.h \
urcu/uatomic/nios2.h \
urcu/uatomic/ppc.h \
urcu/uatomic/riscv.h \
urcu/uatomic/s390.h \
urcu/uatomic/sparc64.h \
urcu/uatomic/tile.h \
Expand Down
49 changes: 49 additions & 0 deletions include/urcu/arch/riscv.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
#ifndef _URCU_ARCH_RISCV_H
#define _URCU_ARCH_RISCV_H

/*
* arch/riscv.h: definitions for the RISC-V architecture
*
* Copyright (c) 2018 Michael Jeanson <mjeanson@efficios.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/

#include <urcu/compiler.h>
#include <urcu/config.h>
#include <urcu/syscall-compat.h>

#ifdef __cplusplus
extern "C" {
#endif

#include <stdlib.h>
#include <sys/time.h>

/*
* On Linux, define the membarrier system call number if not yet available in
* the system headers.
*/
#if (defined(__linux__) && !defined(__NR_membarrier))
#define __NR_membarrier 283
#endif

#ifdef __cplusplus
}
#endif

#include <urcu/arch/generic.h>

#endif /* _URCU_ARCH_RISCV_H */
44 changes: 44 additions & 0 deletions include/urcu/uatomic/riscv.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
/*
* Atomic exchange operations for the RISC-V architecture. Let GCC do it.
*
* Copyright (c) 2018 Michael Jeanson <mjeanson@efficios.com>
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to
* deal in the Software without restriction, including without limitation the
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
* IN THE SOFTWARE.
*/

#ifndef _URCU_ARCH_UATOMIC_RISCV_H
#define _URCU_ARCH_UATOMIC_RISCV_H

#include <urcu/compiler.h>
#include <urcu/system.h>

#ifdef __cplusplus
extern "C" {
#endif

#define UATOMIC_HAS_ATOMIC_BYTE
#define UATOMIC_HAS_ATOMIC_SHORT

#ifdef __cplusplus
}
#endif

#include <urcu/uatomic/generic.h>

#endif /* _URCU_ARCH_UATOMIC_RISCV_H */

0 comments on commit fdfad81

Please sign in to comment.