mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-18 02:46:06 +00:00
aec499c75c
The nds32 architecture, also known as AndeStar V3, is a custom 32-bit RISC target designed by Andes Technologies. Support was added to the kernel in 2016 as the replacement RISC-V based V5 processors were already announced, and maintained by (current or former) Andes employees. As explained by Alan Kao, new customers are now all using RISC-V, and all known nds32 users are already on longterm stable kernels provided by Andes, with no development work going into mainline support any more. While the port is still in a reasonably good shape, it only gets worse over time without active maintainers, so it seems best to remove it before it becomes unusable. As always, if it turns out that there are mainline users after all, and they volunteer to maintain the port in the future, the removal can be reverted. Link: https://lore.kernel.org/linux-mm/YhdWNLUhk+x9RAzU@yamatobi.andestech.com/ Link: https://lore.kernel.org/lkml/20220302065213.82702-1-alankao@andestech.com/ Link: https://www.andestech.com/en/products-solutions/andestar-architecture/ Signed-off-by: Alan Kao <alankao@andestech.com> [arnd: rewrite changelog to provide more background] Signed-off-by: Arnd Bergmann <arnd@arndb.de>
64 lines
1.5 KiB
C
64 lines
1.5 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#include <linux/compiler.h>
|
|
#if defined(__i386__) || defined(__x86_64__)
|
|
#include "../../arch/x86/include/asm/barrier.h"
|
|
#elif defined(__arm__)
|
|
#include "../../arch/arm/include/asm/barrier.h"
|
|
#elif defined(__aarch64__)
|
|
#include "../../arch/arm64/include/asm/barrier.h"
|
|
#elif defined(__powerpc__)
|
|
#include "../../arch/powerpc/include/asm/barrier.h"
|
|
#elif defined(__s390__)
|
|
#include "../../arch/s390/include/asm/barrier.h"
|
|
#elif defined(__sh__)
|
|
#include "../../arch/sh/include/asm/barrier.h"
|
|
#elif defined(__sparc__)
|
|
#include "../../arch/sparc/include/asm/barrier.h"
|
|
#elif defined(__tile__)
|
|
#include "../../arch/tile/include/asm/barrier.h"
|
|
#elif defined(__alpha__)
|
|
#include "../../arch/alpha/include/asm/barrier.h"
|
|
#elif defined(__mips__)
|
|
#include "../../arch/mips/include/asm/barrier.h"
|
|
#elif defined(__ia64__)
|
|
#include "../../arch/ia64/include/asm/barrier.h"
|
|
#elif defined(__xtensa__)
|
|
#include "../../arch/xtensa/include/asm/barrier.h"
|
|
#else
|
|
#include <asm-generic/barrier.h>
|
|
#endif
|
|
|
|
/*
|
|
* Generic fallback smp_*() definitions for archs that haven't
|
|
* been updated yet.
|
|
*/
|
|
|
|
#ifndef smp_rmb
|
|
# define smp_rmb() rmb()
|
|
#endif
|
|
|
|
#ifndef smp_wmb
|
|
# define smp_wmb() wmb()
|
|
#endif
|
|
|
|
#ifndef smp_mb
|
|
# define smp_mb() mb()
|
|
#endif
|
|
|
|
#ifndef smp_store_release
|
|
# define smp_store_release(p, v) \
|
|
do { \
|
|
smp_mb(); \
|
|
WRITE_ONCE(*p, v); \
|
|
} while (0)
|
|
#endif
|
|
|
|
#ifndef smp_load_acquire
|
|
# define smp_load_acquire(p) \
|
|
({ \
|
|
typeof(*p) ___p1 = READ_ONCE(*p); \
|
|
smp_mb(); \
|
|
___p1; \
|
|
})
|
|
#endif
|