blob: 80b388278149681cbf968449bd3681d7080a8f52 [file] [log] [blame]
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00001/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef __ASM_LSE_H
3#define __ASM_LSE_H
4
David Brazdil0f672f62019-12-10 10:32:29 +00005#include <asm/atomic_ll_sc.h>
6
Andrew Scullb4b6d4a2019-01-02 15:54:55 +00007#if defined(CONFIG_AS_LSE) && defined(CONFIG_ARM64_LSE_ATOMICS)
8
9#include <linux/compiler_types.h>
10#include <linux/export.h>
David Brazdil0f672f62019-12-10 10:32:29 +000011#include <linux/jump_label.h>
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000012#include <linux/stringify.h>
13#include <asm/alternative.h>
David Brazdil0f672f62019-12-10 10:32:29 +000014#include <asm/atomic_lse.h>
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000015#include <asm/cpucaps.h>
16
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000017__asm__(".arch_extension lse");
18
David Brazdil0f672f62019-12-10 10:32:29 +000019extern struct static_key_false cpu_hwcap_keys[ARM64_NCAPS];
20extern struct static_key_false arm64_const_caps_ready;
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000021
David Brazdil0f672f62019-12-10 10:32:29 +000022static inline bool system_uses_lse_atomics(void)
23{
24 return (static_branch_likely(&arm64_const_caps_ready)) &&
25 static_branch_likely(&cpu_hwcap_keys[ARM64_HAS_LSE_ATOMICS]);
26}
27
28#define __lse_ll_sc_body(op, ...) \
29({ \
30 system_uses_lse_atomics() ? \
31 __lse_##op(__VA_ARGS__) : \
32 __ll_sc_##op(__VA_ARGS__); \
33})
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000034
35/* In-line patching at runtime */
36#define ARM64_LSE_ATOMIC_INSN(llsc, lse) \
37 ALTERNATIVE(llsc, lse, ARM64_HAS_LSE_ATOMICS)
38
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000039#else /* CONFIG_AS_LSE && CONFIG_ARM64_LSE_ATOMICS */
40
David Brazdil0f672f62019-12-10 10:32:29 +000041static inline bool system_uses_lse_atomics(void) { return false; }
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000042
David Brazdil0f672f62019-12-10 10:32:29 +000043#define __lse_ll_sc_body(op, ...) __ll_sc_##op(__VA_ARGS__)
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000044
45#define ARM64_LSE_ATOMIC_INSN(llsc, lse) llsc
46
Andrew Scullb4b6d4a2019-01-02 15:54:55 +000047#endif /* CONFIG_AS_LSE && CONFIG_ARM64_LSE_ATOMICS */
48#endif /* __ASM_LSE_H */