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,

Reply via email to