mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-23 15:32:33 +00:00
43 lines
1.3 KiB
Diff
43 lines
1.3 KiB
Diff
|
--- a/arch/mips/include/asm/mach-ath79/ath79.h
|
||
|
+++ b/arch/mips/include/asm/mach-ath79/ath79.h
|
||
|
@@ -145,6 +145,7 @@ static inline u32 ath79_reset_rr(unsigne
|
||
|
|
||
|
void ath79_device_reset_set(u32 mask);
|
||
|
void ath79_device_reset_clear(u32 mask);
|
||
|
+u32 ath79_device_reset_get(u32 mask);
|
||
|
|
||
|
void ath79_cpu_irq_init(unsigned irq_wb_chan2, unsigned irq_wb_chan3);
|
||
|
void ath79_misc_irq_init(void __iomem *regs, int irq,
|
||
|
--- a/arch/mips/ath79/common.c
|
||
|
+++ b/arch/mips/ath79/common.c
|
||
|
@@ -142,3 +142,29 @@ void ath79_device_reset_clear(u32 mask)
|
||
|
spin_unlock_irqrestore(&ath79_device_reset_lock, flags);
|
||
|
}
|
||
|
EXPORT_SYMBOL_GPL(ath79_device_reset_clear);
|
||
|
+
|
||
|
+u32 ath79_device_reset_get(u32 mask)
|
||
|
+{
|
||
|
+ unsigned long flags;
|
||
|
+ u32 reg;
|
||
|
+ u32 ret;
|
||
|
+
|
||
|
+ if (soc_is_ar71xx())
|
||
|
+ reg = AR71XX_RESET_REG_RESET_MODULE;
|
||
|
+ else if (soc_is_ar724x())
|
||
|
+ reg = AR724X_RESET_REG_RESET_MODULE;
|
||
|
+ else if (soc_is_ar913x())
|
||
|
+ reg = AR913X_RESET_REG_RESET_MODULE;
|
||
|
+ else if (soc_is_ar933x())
|
||
|
+ reg = AR933X_RESET_REG_RESET_MODULE;
|
||
|
+ else if (soc_is_ar934x())
|
||
|
+ reg = AR934X_RESET_REG_RESET_MODULE;
|
||
|
+ else
|
||
|
+ BUG();
|
||
|
+
|
||
|
+ spin_lock_irqsave(&ath79_device_reset_lock, flags);
|
||
|
+ ret = ath79_reset_rr(reg);
|
||
|
+ spin_unlock_irqrestore(&ath79_device_reset_lock, flags);
|
||
|
+ return ret;
|
||
|
+}
|
||
|
+EXPORT_SYMBOL_GPL(ath79_device_reset_get);
|