Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/ic - Support 64-bit DMA addresses for the Tx and Rx ...
details: https://anonhg.NetBSD.org/src/rev/00ddb7aad779
branches: trunk
changeset: 1007805:00ddb7aad779
user: thorpej <thorpej%NetBSD.org@localhost>
date: Sun Mar 01 05:50:56 2020 +0000
description:
- Support 64-bit DMA addresses for the Tx and Rx ring addresses.
- g/c and unused define.
diffstat:
sys/dev/ic/gem.c | 15 ++++++++-------
sys/dev/ic/gemvar.h | 4 +---
2 files changed, 9 insertions(+), 10 deletions(-)
diffs (63 lines):
diff -r b97e8b4c44f5 -r 00ddb7aad779 sys/dev/ic/gem.c
--- a/sys/dev/ic/gem.c Sun Mar 01 05:39:05 2020 +0000
+++ b/sys/dev/ic/gem.c Sun Mar 01 05:50:56 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: gem.c,v 1.128 2020/02/07 00:56:48 thorpej Exp $ */
+/* $NetBSD: gem.c,v 1.129 2020/03/01 05:50:56 thorpej Exp $ */
/*
*
@@ -37,7 +37,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: gem.c,v 1.128 2020/02/07 00:56:48 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: gem.c,v 1.129 2020/03/01 05:50:56 thorpej Exp $");
#include "opt_inet.h"
@@ -815,8 +815,8 @@
GEM_CDSYNC(sc, BUS_DMASYNC_PREREAD);
/* Reprogram Descriptor Ring Base Addresses */
- /* NOTE: we use only 32-bit DMA addresses here. */
- bus_space_write_4(t, h, GEM_RX_RING_PTR_HI, 0);
+ bus_space_write_4(t, h, GEM_RX_RING_PTR_HI,
+ ((uint64_t)GEM_CDRXADDR(sc, 0)) >> 32);
bus_space_write_4(t, h, GEM_RX_RING_PTR_LO, GEM_CDRXADDR(sc, 0));
/* Redo ERX Configuration */
@@ -1171,11 +1171,12 @@
gem_setladrf(sc);
/* step 6 & 7. Program Descriptor Ring Base Addresses */
- /* NOTE: we use only 32-bit DMA addresses here. */
- bus_space_write_4(t, h, GEM_TX_RING_PTR_HI, 0);
+ bus_space_write_4(t, h, GEM_TX_RING_PTR_HI,
+ ((uint64_t)GEM_CDTXADDR(sc, 0)) >> 32);
bus_space_write_4(t, h, GEM_TX_RING_PTR_LO, GEM_CDTXADDR(sc, 0));
- bus_space_write_4(t, h, GEM_RX_RING_PTR_HI, 0);
+ bus_space_write_4(t, h, GEM_RX_RING_PTR_HI,
+ ((uint64_t)GEM_CDRXADDR(sc, 0)) >> 32);
bus_space_write_4(t, h, GEM_RX_RING_PTR_LO, GEM_CDRXADDR(sc, 0));
/* step 8. Global Configuration & Interrupt Mask */
diff -r b97e8b4c44f5 -r 00ddb7aad779 sys/dev/ic/gemvar.h
--- a/sys/dev/ic/gemvar.h Sun Mar 01 05:39:05 2020 +0000
+++ b/sys/dev/ic/gemvar.h Sun Mar 01 05:50:56 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: gemvar.h,v 1.26 2019/09/13 07:55:06 msaitoh Exp $ */
+/* $NetBSD: gemvar.h,v 1.27 2020/03/01 05:50:56 thorpej Exp $ */
/*
*
@@ -246,8 +246,6 @@
#define GEM_CDTXADDR(sc, x) ((sc)->sc_cddma + GEM_CDTXOFF((x)))
#define GEM_CDRXADDR(sc, x) ((sc)->sc_cddma + GEM_CDRXOFF((x)))
-#define GEM_CDADDR(sc) ((sc)->sc_cddma + GEM_CDOFF)
-
#define GEM_CDTXSYNC(sc, x, n, ops) \
do { \
int __x, __n; \
Home |
Main Index |
Thread Index |
Old Index