mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/herbert/cryptodev-2.6.git
synced 2026-04-04 20:57:45 -04:00
locking/atomic: Add generic support for sync_try_cmpxchg() and its fallback
Provide the generic sync_try_cmpxchg() function from the raw_ prefixed version, also adding explicit instrumentation. The patch amends existing scripts to generate sync_try_cmpxchg() locking primitive and its raw_sync_try_cmpxchg() fallback, while leaving existing macros from the try_cmpxchg() family unchanged. The target can define its own arch_sync_try_cmpxchg() to override the generic version of raw_sync_try_cmpxchg(). This allows the target to generate more optimal assembly than the generic version. Additionally, the patch renames two scripts to better reflect whet they really do. Signed-off-by: Uros Bizjak <ubizjak@gmail.com> Signed-off-by: Ingo Molnar <mingo@kernel.org> Cc: Will Deacon <will@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Boqun Feng <boqun.feng@gmail.com> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: linux-kernel@vger.kernel.org
This commit is contained in:
@@ -223,14 +223,15 @@ gen_xchg_fallbacks()
|
||||
|
||||
gen_try_cmpxchg_fallback()
|
||||
{
|
||||
local prefix="$1"; shift
|
||||
local cmpxchg="$1"; shift;
|
||||
local order="$1"; shift;
|
||||
local suffix="$1"; shift;
|
||||
|
||||
cat <<EOF
|
||||
#define raw_try_${cmpxchg}${order}(_ptr, _oldp, _new) \\
|
||||
#define raw_${prefix}try_${cmpxchg}${suffix}(_ptr, _oldp, _new) \\
|
||||
({ \\
|
||||
typeof(*(_ptr)) *___op = (_oldp), ___o = *___op, ___r; \\
|
||||
___r = raw_${cmpxchg}${order}((_ptr), ___o, (_new)); \\
|
||||
___r = raw_${prefix}${cmpxchg}${suffix}((_ptr), ___o, (_new)); \\
|
||||
if (unlikely(___r != ___o)) \\
|
||||
*___op = ___r; \\
|
||||
likely(___r == ___o); \\
|
||||
@@ -259,11 +260,11 @@ gen_try_cmpxchg_order_fallback()
|
||||
fi
|
||||
|
||||
printf "#else\n"
|
||||
gen_try_cmpxchg_fallback "${cmpxchg}" "${order}"
|
||||
gen_try_cmpxchg_fallback "" "${cmpxchg}" "${order}"
|
||||
printf "#endif\n\n"
|
||||
}
|
||||
|
||||
gen_try_cmpxchg_fallbacks()
|
||||
gen_try_cmpxchg_order_fallbacks()
|
||||
{
|
||||
local cmpxchg="$1"; shift;
|
||||
|
||||
@@ -272,15 +273,17 @@ gen_try_cmpxchg_fallbacks()
|
||||
done
|
||||
}
|
||||
|
||||
gen_cmpxchg_local_fallbacks()
|
||||
gen_def_and_try_cmpxchg_fallback()
|
||||
{
|
||||
local prefix="$1"; shift
|
||||
local cmpxchg="$1"; shift
|
||||
local suffix="$1"; shift
|
||||
|
||||
printf "#define raw_${cmpxchg} arch_${cmpxchg}\n\n"
|
||||
printf "#ifdef arch_try_${cmpxchg}\n"
|
||||
printf "#define raw_try_${cmpxchg} arch_try_${cmpxchg}\n"
|
||||
printf "#define raw_${prefix}${cmpxchg}${suffix} arch_${prefix}${cmpxchg}${suffix}\n\n"
|
||||
printf "#ifdef arch_${prefix}try_${cmpxchg}${suffix}\n"
|
||||
printf "#define raw_${prefix}try_${cmpxchg}${suffix} arch_${prefix}try_${cmpxchg}${suffix}\n"
|
||||
printf "#else\n"
|
||||
gen_try_cmpxchg_fallback "${cmpxchg}" ""
|
||||
gen_try_cmpxchg_fallback "${prefix}" "${cmpxchg}" "${suffix}"
|
||||
printf "#endif\n\n"
|
||||
}
|
||||
|
||||
@@ -302,15 +305,15 @@ for xchg in "xchg" "cmpxchg" "cmpxchg64" "cmpxchg128"; do
|
||||
done
|
||||
|
||||
for cmpxchg in "cmpxchg" "cmpxchg64" "cmpxchg128"; do
|
||||
gen_try_cmpxchg_fallbacks "${cmpxchg}"
|
||||
gen_try_cmpxchg_order_fallbacks "${cmpxchg}"
|
||||
done
|
||||
|
||||
for cmpxchg in "cmpxchg_local" "cmpxchg64_local" "cmpxchg128_local"; do
|
||||
gen_cmpxchg_local_fallbacks "${cmpxchg}" ""
|
||||
for cmpxchg in "cmpxchg" "cmpxchg64" "cmpxchg128"; do
|
||||
gen_def_and_try_cmpxchg_fallback "" "${cmpxchg}" "_local"
|
||||
done
|
||||
|
||||
for cmpxchg in "sync_cmpxchg"; do
|
||||
printf "#define raw_${cmpxchg} arch_${cmpxchg}\n\n"
|
||||
for cmpxchg in "cmpxchg"; do
|
||||
gen_def_and_try_cmpxchg_fallback "sync_" "${cmpxchg}" ""
|
||||
done
|
||||
|
||||
grep '^[a-z]' "$1" | while read name meta args; do
|
||||
|
||||
@@ -169,7 +169,8 @@ for xchg in "xchg" "cmpxchg" "cmpxchg64" "cmpxchg128" "try_cmpxchg" "try_cmpxchg
|
||||
done
|
||||
done
|
||||
|
||||
for xchg in "cmpxchg_local" "cmpxchg64_local" "cmpxchg128_local" "sync_cmpxchg" "try_cmpxchg_local" "try_cmpxchg64_local" "try_cmpxchg128_local"; do
|
||||
for xchg in "cmpxchg_local" "cmpxchg64_local" "cmpxchg128_local" "sync_cmpxchg" \
|
||||
"try_cmpxchg_local" "try_cmpxchg64_local" "try_cmpxchg128_local" "sync_try_cmpxchg"; do
|
||||
gen_xchg "${xchg}" ""
|
||||
printf "\n"
|
||||
done
|
||||
|
||||
Reference in New Issue
Block a user