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 à :
Mohammed Siddiq
2022-04-18 14:45:13 +05:30
révisé par Gerrit - the friendly Code Review server
Parent 83cc8e3076
révision 8ebc3d7e4f
3 fichiers modifiés avec 37 ajouts et 0 suppressions

Voir le fichier

@@ -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 */

Voir le fichier

@@ -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;
}

Voir le fichier

@@ -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;