cnss2: Log SW_CTRL GPIO value if PCIe link training fails
Add change to print SW_CTRL GPIO value when PCIe link training fails during power on. Change-Id: I77bd2db80dad4c56647f52d67acfab0fe7efb7a7
Cette révision appartient à :

révisé par
Gerrit - the friendly Code Review server

Parent
83cc8e3076
révision
8ebc3d7e4f
@@ -112,6 +112,7 @@ struct cnss_pinctrl_info {
|
||||
struct pinctrl_state *wlan_en_sleep;
|
||||
int bt_en_gpio;
|
||||
int xo_clk_gpio; /*qca6490 only */
|
||||
int sw_ctrl_gpio;
|
||||
int wlan_sw_ctrl_gpio;
|
||||
};
|
||||
|
||||
@@ -630,4 +631,5 @@ int cnss_clear_feature_list(struct cnss_plat_data *plat_priv,
|
||||
enum cnss_feature_v01 feature);
|
||||
int cnss_get_feature_list(struct cnss_plat_data *plat_priv,
|
||||
u64 *feature_list);
|
||||
int cnss_get_input_gpio_value(struct cnss_plat_data *plat_priv, int gpio_num);
|
||||
#endif /* _CNSS_MAIN_H */
|
||||
|
@@ -2865,6 +2865,7 @@ static int cnss_qca6290_powerup(struct cnss_pci_data *pci_priv)
|
||||
struct cnss_plat_data *plat_priv = pci_priv->plat_priv;
|
||||
unsigned int timeout;
|
||||
int retry = 0, bt_en_gpio = plat_priv->pinctrl_info.bt_en_gpio;
|
||||
int sw_ctrl_gpio = plat_priv->pinctrl_info.sw_ctrl_gpio;
|
||||
|
||||
if (plat_priv->ramdump_info_v2.dump_data_valid) {
|
||||
cnss_pci_clear_dump_info(pci_priv);
|
||||
@@ -2888,6 +2889,8 @@ retry:
|
||||
ret = cnss_resume_pci_link(pci_priv);
|
||||
if (ret) {
|
||||
cnss_pr_err("Failed to resume PCI link, err = %d\n", ret);
|
||||
cnss_pr_dbg("Value of SW_CTRL GPIO: %d\n",
|
||||
cnss_get_input_gpio_value(plat_priv, sw_ctrl_gpio));
|
||||
if (test_bit(IGNORE_PCI_LINK_FAILURE,
|
||||
&plat_priv->ctrl_params.quirks)) {
|
||||
cnss_pr_dbg("Ignore PCI link resume failure\n");
|
||||
@@ -2906,6 +2909,9 @@ retry:
|
||||
gpio_get_value(bt_en_gpio));
|
||||
}
|
||||
cnss_pr_dbg("Retry to resume PCI link #%d\n", retry);
|
||||
cnss_pr_dbg("Value of SW_CTRL GPIO: %d\n",
|
||||
cnss_get_input_gpio_value(plat_priv,
|
||||
sw_ctrl_gpio));
|
||||
msleep(POWER_ON_RETRY_DELAY_MS * retry);
|
||||
goto retry;
|
||||
}
|
||||
|
@@ -65,6 +65,7 @@ static struct cnss_clk_cfg cnss_clk_list[] = {
|
||||
#define WLAN_EN_GPIO "wlan-en-gpio"
|
||||
#define BT_EN_GPIO "qcom,bt-en-gpio"
|
||||
#define XO_CLK_GPIO "qcom,xo-clk-gpio"
|
||||
#define SW_CTRL_GPIO "qcom,sw-ctrl-gpio"
|
||||
#define WLAN_SW_CTRL_GPIO "qcom,wlan-sw-ctrl-gpio"
|
||||
#define WLAN_EN_ACTIVE "wlan_en_active"
|
||||
#define WLAN_EN_SLEEP "wlan_en_sleep"
|
||||
@@ -795,6 +796,17 @@ int cnss_get_pinctrl(struct cnss_plat_data *plat_priv)
|
||||
} else {
|
||||
pinctrl_info->xo_clk_gpio = -EINVAL;
|
||||
}
|
||||
|
||||
if (of_find_property(dev->of_node, SW_CTRL_GPIO, NULL)) {
|
||||
pinctrl_info->sw_ctrl_gpio = of_get_named_gpio(dev->of_node,
|
||||
SW_CTRL_GPIO,
|
||||
0);
|
||||
cnss_pr_dbg("Switch control GPIO: %d\n",
|
||||
pinctrl_info->sw_ctrl_gpio);
|
||||
} else {
|
||||
pinctrl_info->sw_ctrl_gpio = -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
out:
|
||||
return ret;
|
||||
@@ -969,6 +981,23 @@ set_wlan_en:
|
||||
return ret;
|
||||
}
|
||||
|
||||
int cnss_get_input_gpio_value(struct cnss_plat_data *plat_priv, int gpio_num)
|
||||
{
|
||||
int ret;
|
||||
|
||||
if (gpio_num < 0)
|
||||
return -EINVAL;
|
||||
|
||||
ret = gpio_direction_input(gpio_num);
|
||||
if (ret) {
|
||||
cnss_pr_err("Failed to set direction of GPIO(%d), err = %d",
|
||||
gpio_num, ret);
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return gpio_get_value(gpio_num);
|
||||
}
|
||||
|
||||
int cnss_power_on_device(struct cnss_plat_data *plat_priv)
|
||||
{
|
||||
int ret = 0;
|
||||
|
Référencer dans un nouveau ticket
Bloquer un utilisateur