diff options
Diffstat (limited to 'target/linux/ar71xx/files/arch/mips')
| -rw-r--r-- | target/linux/ar71xx/files/arch/mips/ar71xx/ar71xx.c | 26 | 
1 files changed, 26 insertions, 0 deletions
diff --git a/target/linux/ar71xx/files/arch/mips/ar71xx/ar71xx.c b/target/linux/ar71xx/files/arch/mips/ar71xx/ar71xx.c index ed3127418..31b4422a0 100644 --- a/target/linux/ar71xx/files/arch/mips/ar71xx/ar71xx.c +++ b/target/linux/ar71xx/files/arch/mips/ar71xx/ar71xx.c @@ -71,6 +71,15 @@ void ar71xx_device_stop(u32 mask)  		spin_unlock_irqrestore(&ar71xx_device_lock, flags);  		break; +	case AR71XX_SOC_AR9341: +	case AR71XX_SOC_AR9342: +	case AR71XX_SOC_AR9344: +		spin_lock_irqsave(&ar71xx_device_lock, flags); +		t = ar71xx_reset_rr(AR934X_RESET_REG_RESET_MODULE); +		ar71xx_reset_wr(AR934X_RESET_REG_RESET_MODULE, t | mask); +		spin_unlock_irqrestore(&ar71xx_device_lock, flags); +		break; +  	default:  		BUG();  	} @@ -113,6 +122,15 @@ void ar71xx_device_start(u32 mask)  		spin_unlock_irqrestore(&ar71xx_device_lock, flags);  		break; +	case AR71XX_SOC_AR9341: +	case AR71XX_SOC_AR9342: +	case AR71XX_SOC_AR9344: +		spin_lock_irqsave(&ar71xx_device_lock, flags); +		t = ar71xx_reset_rr(AR934X_RESET_REG_RESET_MODULE); +		ar71xx_reset_wr(AR934X_RESET_REG_RESET_MODULE, t & ~mask); +		spin_unlock_irqrestore(&ar71xx_device_lock, flags); +		break; +  	default:  		BUG();  	} @@ -148,6 +166,14 @@ int ar71xx_device_stopped(u32 mask)  		spin_unlock_irqrestore(&ar71xx_device_lock, flags);  		break; +	case AR71XX_SOC_AR9341: +	case AR71XX_SOC_AR9342: +	case AR71XX_SOC_AR9344: +		spin_lock_irqsave(&ar71xx_device_lock, flags); +		t = ar71xx_reset_rr(AR934X_RESET_REG_RESET_MODULE); +		spin_unlock_irqrestore(&ar71xx_device_lock, flags); +		break; +  	default:  		BUG();  	}  | 
