mirror of https://gitee.com/openkylin/linux.git
wil6210: add memory barriers for the reset flow
make sure reset flow executed in order Signed-off-by: Vladimir Kondratiev <qca_vkondrat@qca.qualcomm.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
d28bcc3026
commit
260e695196
|
@ -289,19 +289,23 @@ static void wil_target_reset(struct wil6210_priv *wil)
|
||||||
S(RGF_USER_CLKS_CTL_SW_RST_MASK_0, BIT(6));
|
S(RGF_USER_CLKS_CTL_SW_RST_MASK_0, BIT(6));
|
||||||
/* car_perst_rst_src_n_mask */
|
/* car_perst_rst_src_n_mask */
|
||||||
S(RGF_USER_CLKS_CTL_SW_RST_MASK_0, BIT(7));
|
S(RGF_USER_CLKS_CTL_SW_RST_MASK_0, BIT(7));
|
||||||
|
wmb(); /* order is important here */
|
||||||
|
|
||||||
W(RGF_USER_MAC_CPU_0, BIT(1)); /* mac_cpu_man_rst */
|
W(RGF_USER_MAC_CPU_0, BIT(1)); /* mac_cpu_man_rst */
|
||||||
W(RGF_USER_USER_CPU_0, BIT(1)); /* user_cpu_man_rst */
|
W(RGF_USER_USER_CPU_0, BIT(1)); /* user_cpu_man_rst */
|
||||||
|
wmb(); /* order is important here */
|
||||||
|
|
||||||
W(RGF_USER_CLKS_CTL_SW_RST_VEC_2, 0xFE000000);
|
W(RGF_USER_CLKS_CTL_SW_RST_VEC_2, 0xFE000000);
|
||||||
W(RGF_USER_CLKS_CTL_SW_RST_VEC_1, 0x0000003F);
|
W(RGF_USER_CLKS_CTL_SW_RST_VEC_1, 0x0000003F);
|
||||||
W(RGF_USER_CLKS_CTL_SW_RST_VEC_3, 0x00000170);
|
W(RGF_USER_CLKS_CTL_SW_RST_VEC_3, 0x00000170);
|
||||||
W(RGF_USER_CLKS_CTL_SW_RST_VEC_0, 0xFFE7FC00);
|
W(RGF_USER_CLKS_CTL_SW_RST_VEC_0, 0xFFE7FC00);
|
||||||
|
wmb(); /* order is important here */
|
||||||
|
|
||||||
W(RGF_USER_CLKS_CTL_SW_RST_VEC_3, 0);
|
W(RGF_USER_CLKS_CTL_SW_RST_VEC_3, 0);
|
||||||
W(RGF_USER_CLKS_CTL_SW_RST_VEC_2, 0);
|
W(RGF_USER_CLKS_CTL_SW_RST_VEC_2, 0);
|
||||||
W(RGF_USER_CLKS_CTL_SW_RST_VEC_1, 0);
|
W(RGF_USER_CLKS_CTL_SW_RST_VEC_1, 0);
|
||||||
W(RGF_USER_CLKS_CTL_SW_RST_VEC_0, 0);
|
W(RGF_USER_CLKS_CTL_SW_RST_VEC_0, 0);
|
||||||
|
wmb(); /* order is important here */
|
||||||
|
|
||||||
W(RGF_USER_CLKS_CTL_SW_RST_VEC_3, 0x00000001);
|
W(RGF_USER_CLKS_CTL_SW_RST_VEC_3, 0x00000001);
|
||||||
if (rev_id == 1) {
|
if (rev_id == 1) {
|
||||||
|
@ -311,6 +315,7 @@ static void wil_target_reset(struct wil6210_priv *wil)
|
||||||
W(RGF_USER_CLKS_CTL_SW_RST_VEC_2, 0x00008000);
|
W(RGF_USER_CLKS_CTL_SW_RST_VEC_2, 0x00008000);
|
||||||
}
|
}
|
||||||
W(RGF_USER_CLKS_CTL_SW_RST_VEC_0, 0);
|
W(RGF_USER_CLKS_CTL_SW_RST_VEC_0, 0);
|
||||||
|
wmb(); /* order is important here */
|
||||||
|
|
||||||
/* wait until device ready */
|
/* wait until device ready */
|
||||||
do {
|
do {
|
||||||
|
@ -327,6 +332,7 @@ static void wil_target_reset(struct wil6210_priv *wil)
|
||||||
W(RGF_PCIE_LOS_COUNTER_CTL, BIT(8));
|
W(RGF_PCIE_LOS_COUNTER_CTL, BIT(8));
|
||||||
|
|
||||||
C(RGF_USER_CLKS_CTL_0, BIT_USER_CLKS_RST_PWGD);
|
C(RGF_USER_CLKS_CTL_0, BIT_USER_CLKS_RST_PWGD);
|
||||||
|
wmb(); /* order is important here */
|
||||||
|
|
||||||
wil_dbg_misc(wil, "Reset completed in %d ms\n", delay);
|
wil_dbg_misc(wil, "Reset completed in %d ms\n", delay);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue