openwrt_archive/target/linux/ar71xx/patches-3.3/650-MIPS-ath79-fix-ar933x-reset.patch
Felix Fietkau 88e506e321 ar71xx: add an external reset callback for ar913x and use it in ath9k
should reduce the frequency of DMA stop failures

Backport of r36530

Signed-off-by: Felix Fietkau <nbd@openwrt.org>

SVN-Revision: 36664
2013-05-19 22:49:09 +00:00

32 lines
645 B
Diff

--- a/arch/mips/ath79/dev-wmac.c
+++ b/arch/mips/ath79/dev-wmac.c
@@ -76,10 +76,27 @@ static void __init ar913x_wmac_setup(voi
static int ar933x_wmac_reset(void)
{
+ int retries = 20;
+
ath79_device_reset_set(AR933X_RESET_WMAC);
ath79_device_reset_clear(AR933X_RESET_WMAC);
- return 0;
+ while (1) {
+ u32 bootstrap;
+
+ bootstrap = ath79_reset_rr(AR933X_RESET_REG_BOOTSTRAP);
+ if ((bootstrap & AR933X_BOOTSTRAP_EEPBUSY) == 0)
+ return 0;
+
+ if (retries-- == 0)
+ break;
+
+ udelay(10000);
+ retries++;
+ }
+
+ pr_err("ar933x: WMAC reset timed out");
+ return -ETIMEDOUT;
}
static int ar933x_r1_get_wmac_revision(void)