Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/pci Fixed a panic problem at attach with aq(4) F/W v...
details: https://anonhg.NetBSD.org/src/rev/b0f16e6c1322
branches: trunk
changeset: 1025537:b0f16e6c1322
user: ryo <ryo%NetBSD.org@localhost>
date: Thu Nov 11 06:56:56 2021 +0000
description:
Fixed a panic problem at attach with aq(4) F/W version 1.
- Don't use cprng(9) when attaching, since it's not available yet.
- Wait up to 10 seconds because delay is not enough.
- Even if the delay is not enough, it will fail attach without panic.
- Checked on the actual card D107 (F/W version 1.5.58)
diffstat:
sys/dev/pci/if_aq.c | 20 ++++++++++----------
1 files changed, 10 insertions(+), 10 deletions(-)
diffs (49 lines):
diff -r d630a613b840 -r b0f16e6c1322 sys/dev/pci/if_aq.c
--- a/sys/dev/pci/if_aq.c Thu Nov 11 01:10:09 2021 +0000
+++ b/sys/dev/pci/if_aq.c Thu Nov 11 06:56:56 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_aq.c,v 1.29 2021/10/11 15:08:17 msaitoh Exp $ */
+/* $NetBSD: if_aq.c,v 1.30 2021/11/11 06:56:56 ryo Exp $ */
/**
* aQuantia Corporation Network Driver
@@ -62,7 +62,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_aq.c,v 1.29 2021/10/11 15:08:17 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_aq.c,v 1.30 2021/11/11 06:56:56 ryo Exp $");
#ifdef _KERNEL_OPT
#include "opt_if_aq.h"
@@ -2068,22 +2068,22 @@
int timo;
if (FW_VERSION_MAJOR(sc) == 1) {
- if (AQ_READ_REG(sc, FW1X_MPI_INIT2_REG) == 0) {
- uint32_t data;
- cprng_fast(&data, sizeof(data));
- data &= 0xfefefefe;
- data |= 0x02020202;
- AQ_WRITE_REG(sc, FW1X_MPI_INIT2_REG, data);
- }
+ if (AQ_READ_REG(sc, FW1X_MPI_INIT2_REG) == 0)
+ AQ_WRITE_REG(sc, FW1X_MPI_INIT2_REG, 0xfefefefe);
AQ_WRITE_REG(sc, FW1X_MPI_INIT1_REG, 0);
}
- for (timo = 100; timo > 0; timo--) {
+ /* Wait a maximum of 10sec. It usually takes about 5sec. */
+ for (timo = 10000; timo > 0; timo--) {
sc->sc_mbox_addr = AQ_READ_REG(sc, FW_MPI_MBOX_ADDR_REG);
if (sc->sc_mbox_addr != 0)
break;
delay(1000);
}
+ if (sc->sc_mbox_addr == 0) {
+ aprint_error_dev(sc->sc_dev, "cannot get mbox addr\n");
+ return ETIMEDOUT;
+ }
#define AQ_FW_MIN_VERSION 0x01050006
#define AQ_FW_MIN_VERSION_STR "1.5.6"
Home |
Main Index |
Thread Index |
Old Index