diff options
author | Michael Shalayeff <mickey@cvs.openbsd.org> | 2002-06-05 22:49:50 +0000 |
---|---|---|
committer | Michael Shalayeff <mickey@cvs.openbsd.org> | 2002-06-05 22:49:50 +0000 |
commit | 8bac8c18090ee7864bdba33156f56d06e218ad2b (patch) | |
tree | a5e10165f3e09bdb3442d9487f29d1050334da8e /sys/dev | |
parent | 563191ee312b660d496287c752aecb81a748fb93 (diff) |
steal'' performance calculating loop from pchb.c and have a uniform output
Diffstat (limited to 'sys/dev')
-rw-r--r-- | sys/dev/pci/amdpm.c | 32 |
1 files changed, 19 insertions, 13 deletions
diff --git a/sys/dev/pci/amdpm.c b/sys/dev/pci/amdpm.c index 6c5e5f3ed0e..82fd53fc227 100644 --- a/sys/dev/pci/amdpm.c +++ b/sys/dev/pci/amdpm.c @@ -1,4 +1,4 @@ -/* $OpenBSD: amdpm.c,v 1.1 2002/06/05 22:35:16 mickey Exp $ */ +/* $OpenBSD: amdpm.c,v 1.2 2002/06/05 22:49:49 mickey Exp $ */ /*- * Copyright (c) 2002 The NetBSD Foundation, Inc. @@ -96,8 +96,8 @@ amdpm_attach(struct device *parent, struct device *self, void *aux) { struct amdpm_softc *sc = (struct amdpm_softc *) self; struct pci_attach_args *pa = aux; + struct timeval tv1, tv2; pcireg_t reg; - u_int32_t pmreg; int i; sc->sc_pc = pa->pa_pc; @@ -121,16 +121,22 @@ amdpm_attach(struct device *parent, struct device *self, void *aux) /* Check to see if we can read data from the RNG. */ (void) bus_space_read_4(sc->sc_iot, sc->sc_ioh, AMDPM_RNGDATA); - for (i = 0; i < 1000; i++) { - pmreg = bus_space_read_4(sc->sc_iot, - sc->sc_ioh, AMDPM_RNGSTAT); - if (pmreg & AMDPM_RNGDONE) - break; - delay(1); + /* benchmark the RNG */ + microtime(&tv1); + for (i = 2 * 1024; i--; ) { + while(!(bus_space_read_1(sc->sc_iot, sc->sc_ioh, + AMDPM_RNGSTAT) & AMDPM_RNGDONE)) + ; + (void) bus_space_read_4(sc->sc_iot, sc->sc_ioh, + AMDPM_RNGDATA); } - if ((pmreg & AMDPM_RNGDONE) != 0) { - printf(": rng active (apprx. %dms)\n", i); - timeout_set(&sc->sc_rnd_ch, amdpm_rnd_callout, sc); + microtime(&tv2); + + timersub(&tv2, &tv1, &tv1); + if (tv1.tv_sec) + tv1.tv_usec += 1000000 * tv1.tv_sec; + printf(": rng active, %dKb/sec", 8 * 1000000 / tv1.tv_usec); + #ifdef AMDPM_RND_COUNTERS evcnt_attach_dynamic(&sc->sc_rnd_hits, EVCNT_TYPE_MISC, NULL, sc->sc_dev.dv_xname, "rnd hits"); @@ -142,8 +148,8 @@ amdpm_attach(struct device *parent, struct device *self, void *aux) "rnd data"); } #endif - amdpm_rnd_callout(sc); - } + timeout_set(&sc->sc_rnd_ch, amdpm_rnd_callout, sc); + amdpm_rnd_callout(sc); } } |