Skip to content

Commit

Permalink
Add LoongArch support
Browse files Browse the repository at this point in the history
  • Loading branch information
wangjingwb authored and yetist committed Jun 30, 2021
1 parent 6558e7a commit 9527dea
Show file tree
Hide file tree
Showing 7 changed files with 105 additions and 0 deletions.
1 change: 1 addition & 0 deletions LICENSE
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ MIT/X11 (BSD like) license apply to:
compiler.h
arch/s390.h
uatomic/alpha.h
uatomic/loongarch.h
uatomic/mips.h
uatomic/nios2.h
uatomic/s390.h
Expand Down
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ Currently, the following architectures are supported:
- hppa/PA-RISC
- m68k
- RISC-V
- LoongArch

Tested on:

Expand Down
2 changes: 2 additions & 0 deletions include/Makefile.am
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ nobase_include_HEADERS = \
urcu/arch.h \
urcu/arch/hppa.h \
urcu/arch/ia64.h \
urcu/arch/loongarch.h \
urcu/arch/m68k.h \
urcu/arch/mips.h \
urcu/arch/nios2.h \
Expand Down Expand Up @@ -67,6 +68,7 @@ nobase_include_HEADERS = \
urcu/uatomic.h \
urcu/uatomic/hppa.h \
urcu/uatomic/ia64.h \
urcu/uatomic/loongarch.h \
urcu/uatomic/m68k.h \
urcu/uatomic/mips.h \
urcu/uatomic/nios2.h \
Expand Down
6 changes: 6 additions & 0 deletions include/urcu/arch.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@
* URCU_ARCH_HPPA : All HP PA-RISC variants
* URCU_ARCH_M68K : All Motorola 68000 variants
* URCU_ARCH_RISCV : All RISC-V variants
* URCU_ARCH_LOONGARCH : All LoongArch variants
*/

#if (defined(__INTEL_OFFLOAD) || defined(__TARGET_ARCH_MIC) || defined(__MIC__))
Expand Down Expand Up @@ -157,6 +158,11 @@
#define URCU_ARCH_RISCV 1
#include <urcu/arch/riscv.h>

#elif defined(__loongarch__)

#define URCU_ARCH_LOONGARCH 1
#include <urcu/arch/loongarch.h>

#else
#error "Cannot build: unrecognized architecture, see <urcu/arch.h>."
#endif
Expand Down
49 changes: 49 additions & 0 deletions include/urcu/arch/loongarch.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
#ifndef _URCU_ARCH_LOONGARCH_H
#define _URCU_ARCH_LOONGARCH_H

/*
* arch/loongarch.h: trivial definitions for the LoongArch architecture.
*
* Copyright (c) 2021 Wang Jing <wangjing@loongson.cn>
*
* 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_LOONGARCH_H */
2 changes: 2 additions & 0 deletions include/urcu/uatomic.h
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,8 @@
#include <urcu/uatomic/m68k.h>
#elif defined(URCU_ARCH_RISCV)
#include <urcu/uatomic/riscv.h>
#elif defined(URCU_ARCH_LOONGARCH)
#include <urcu/uatomic/loongarch.h>
#else
#error "Cannot build: unrecognized architecture, see <urcu/arch.h>."
#endif
Expand Down
44 changes: 44 additions & 0 deletions include/urcu/uatomic/loongarch.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
#ifndef _URCU_UATOMIC_ARCH_LOONGARCH_H
#define _URCU_UATOMIC_ARCH_LOONGARCH_H

/*
* Atomic exchange operations for the LoongArch architecture. Let GCC do it.
*
* Copyright (c) 2021 Wang Jing <wangjing@loongson.cn>
*
* 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.
*/

#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_UATOMIC_ARCH_LOONGARCH_H */

0 comments on commit 9527dea

Please sign in to comment.