Module Name: src
Committed By: riastradh
Date: Sun Dec 19 01:39:27 UTC 2021
Modified Files:
src/sys/external/bsd/drm2/include/linux: atomic.h
Log Message:
Guarantee no repeated loads.
To generate a diff of this commit:
cvs rdiff -u -r1.25 -r1.26 src/sys/external/bsd/drm2/include/linux/atomic.h
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/external/bsd/drm2/include/linux/atomic.h
diff -u src/sys/external/bsd/drm2/include/linux/atomic.h:1.25 src/sys/external/bsd/drm2/include/linux/atomic.h:1.26
--- src/sys/external/bsd/drm2/include/linux/atomic.h:1.25 Sun Dec 19 01:39:20 2021
+++ src/sys/external/bsd/drm2/include/linux/atomic.h Sun Dec 19 01:39:27 2021
@@ -1,4 +1,4 @@
-/* $NetBSD: atomic.h,v 1.25 2021/12/19 01:39:20 riastradh Exp $ */
+/* $NetBSD: atomic.h,v 1.26 2021/12/19 01:39:27 riastradh Exp $ */
/*-
* Copyright (c) 2013 The NetBSD Foundation, Inc.
@@ -207,6 +207,7 @@ atomic_add_unless(atomic_t *atomic, int
smp_mb__before_atomic();
do {
value = atomic->a_u.au_int;
+ __insn_barrier();
if (value == zero)
break;
} while (atomic_cas_uint(&atomic->a_u.au_uint, value, (value + addend))
@@ -389,6 +390,7 @@ atomic_long_add_unless(struct atomic_lon
smp_mb__before_atomic();
do {
value = (long)a->al_v;
+ __insn_barrier();
if (value == zero)
break;
} while (atomic_cas_ulong(&a->al_v, (unsigned long)value,