Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/mips/cavium/dev CN70XX iobdma limit appears to be 1...
details: https://anonhg.NetBSD.org/src/rev/ddc5b543f624
branches: trunk
changeset: 972555:ddc5b543f624
user: simonb <simonb%NetBSD.org@localhost>
date: Sat May 30 03:12:52 2020 +0000
description:
CN70XX iobdma limit appears to be 128 words, so gather that many samples
as a time.
Gather the full 512 bytes of samples and process in a single call to
rnd_add_data_sync() - about 10% faster than 4 calls to rnd_add_data_sync().
Put sample buffer in the softc to save some stack usage.
diffstat:
sys/arch/mips/cavium/dev/octeon_rnm.c | 34 ++++++++++++++++++----------------
1 files changed, 18 insertions(+), 16 deletions(-)
diffs (87 lines):
diff -r 55b6dc7fb497 -r ddc5b543f624 sys/arch/mips/cavium/dev/octeon_rnm.c
--- a/sys/arch/mips/cavium/dev/octeon_rnm.c Sat May 30 02:56:54 2020 +0000
+++ b/sys/arch/mips/cavium/dev/octeon_rnm.c Sat May 30 03:12:52 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: octeon_rnm.c,v 1.6 2020/05/18 16:05:09 riastradh Exp $ */
+/* $NetBSD: octeon_rnm.c,v 1.7 2020/05/30 03:12:52 simonb Exp $ */
/*
* Copyright (c) 2007 Internet Initiative Japan, Inc.
@@ -99,7 +99,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: octeon_rnm.c,v 1.6 2020/05/18 16:05:09 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: octeon_rnm.c,v 1.7 2020/05/30 03:12:52 simonb Exp $");
#include <sys/param.h>
#include <sys/device.h>
@@ -123,6 +123,7 @@
#define RNG_FIFO_WORDS (512/sizeof(uint64_t))
struct octeon_rnm_softc {
+ uint64_t sc_sample[RNG_FIFO_WORDS];
bus_space_tag_t sc_bust;
bus_space_handle_t sc_regh;
kmutex_t sc_lock;
@@ -222,8 +223,8 @@
octeon_rnm_rng(size_t nbytes, void *vsc)
{
const unsigned BPB = 256; /* bits of data per bit of entropy */
- uint64_t sample[32];
struct octeon_rnm_softc *sc = vsc;
+ uint64_t *samplepos;
size_t needed = NBBY*nbytes;
unsigned i;
@@ -244,20 +245,21 @@
octeon_rnm_raw_entropy(sc, sc->sc_rogroup);
/*
- * Gather half the FIFO at a time -- we are limited to
- * 256 bytes because of limits on the CVMSEG buffer.
+ * Gather quarter the FIFO at a time -- we are limited
+ * to 128 bytes because of limits on the CVMSEG buffer.
*/
- CTASSERT(sizeof sample == 256);
- CTASSERT(2*__arraycount(sample) == RNG_FIFO_WORDS);
- for (i = 0; i < 2; i++) {
- octeon_rnm_iobdma(sc, sample, __arraycount(sample));
+ CTASSERT(sizeof sc->sc_sample == 512);
+ CTASSERT(__arraycount(sc->sc_sample) == RNG_FIFO_WORDS);
+ for (samplepos = sc->sc_sample, i = 0; i < 4; i++) {
+ octeon_rnm_iobdma(sc, samplepos, RNG_FIFO_WORDS / 4);
+ samplepos += RNG_FIFO_WORDS / 4;
+ }
#ifdef OCTEON_RNM_DEBUG
- hexdump(printf, "rnm", sample, sizeof sample);
+ hexdump(printf, "rnm", sc->sc_sample, sizeof sc->sc_sample);
#endif
- rnd_add_data_sync(&sc->sc_rndsrc, sample,
- sizeof sample, NBBY*sizeof(sample)/BPB);
- needed -= MIN(needed, MAX(1, NBBY*sizeof(sample)/BPB));
- }
+ rnd_add_data_sync(&sc->sc_rndsrc, sc->sc_sample,
+ sizeof sc->sc_sample, NBBY*sizeof(sc->sc_sample)/BPB);
+ needed -= MIN(needed, MAX(1, NBBY*sizeof(sc->sc_sample)/BPB));
/* Yield if requested. */
if (__predict_false(curcpu()->ci_schedstate.spc_flags &
@@ -270,7 +272,7 @@
mutex_exit(&sc->sc_lock);
/* Zero the sample. */
- explicit_memset(sample, 0, sizeof sample);
+ explicit_memset(sc->sc_sample, 0, sizeof sc->sc_sample);
}
/*
@@ -366,7 +368,7 @@
__SHIFTIN(RNM_IOBDMA_MAJORDID, IOBDMA_MAJORDID) |
__SHIFTIN(RNM_IOBDMA_SUBDID, IOBDMA_SUBDID);
- KASSERT(nwords < 256); /* iobdma address restriction */
+ KASSERT(nwords < 128); /* iobdma address restriction */
KASSERT(nwords <= 32); /* octeon_cvmseg_map limitation */
octeon_iobdma_write_8(iobdma);
Home |
Main Index |
Thread Index |
Old Index