Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/pci Use atomic_load/store_* in ena(4), not questiona...
details: https://anonhg.NetBSD.org/src/rev/6fd9182ef550
branches: trunk
changeset: 968903:6fd9182ef550
user: riastradh <riastradh%NetBSD.org@localhost>
date: Sat Feb 01 02:32:40 2020 +0000
description:
Use atomic_load/store_* in ena(4), not questionable membar_sync.
diffstat:
sys/dev/pci/if_ena.c | 10 +++-------
1 files changed, 3 insertions(+), 7 deletions(-)
diffs (41 lines):
diff -r c679ab51364b -r 6fd9182ef550 sys/dev/pci/if_ena.c
--- a/sys/dev/pci/if_ena.c Sat Feb 01 02:23:23 2020 +0000
+++ b/sys/dev/pci/if_ena.c Sat Feb 01 02:32:40 2020 +0000
@@ -31,7 +31,7 @@
#if 0
__FBSDID("$FreeBSD: head/sys/dev/ena/ena.c 333456 2018-05-10 09:37:54Z mw $");
#endif
-__KERNEL_RCSID(0, "$NetBSD: if_ena.c,v 1.19 2019/12/02 03:06:51 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_ena.c,v 1.20 2020/02/01 02:32:40 riastradh Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -3349,7 +3349,6 @@
{
struct ena_adapter *adapter = (struct ena_adapter *)adapter_data;
struct ena_admin_aenq_keep_alive_desc *desc;
- sbintime_t stime;
uint64_t rx_drops;
desc = (struct ena_admin_aenq_keep_alive_desc *)aenq_e;
@@ -3358,8 +3357,7 @@
counter_u64_zero(adapter->hw_stats.rx_drops);
counter_u64_add(adapter->hw_stats.rx_drops, rx_drops);
- stime = getsbinuptime();
- (void) atomic_swap_64(&adapter->keep_alive_timestamp, stime);
+ atomic_store_release(&adapter->keep_alive_timestamp, getsbinuptime());
}
/* Check for keep alive expiration */
@@ -3373,9 +3371,7 @@
if (likely(adapter->keep_alive_timeout == 0))
return;
- /* FreeBSD uses atomic_load_acq_64() in place of the membar + read */
- membar_sync();
- timestamp = adapter->keep_alive_timestamp;
+ timestamp = atomic_load_acquire(&adapter->keep_alive_timestamp);
time = getsbinuptime() - timestamp;
if (unlikely(time > adapter->keep_alive_timeout)) {
Home |
Main Index |
Thread Index |
Old Index