mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
mwifiex: Fix reporting 'operation not supported' error code
ENOTSUPP (double PP) is internal linux kernel code 524 available only in kernel include file linux/errno.h and not exported to userspace. EOPNOTSUPP (OP; double PP) is standard code 95 for reporting 'operation not supported' available via kernel include file uapi/asm-generic/errno.h. ENOTSUP (single P) is alias for EOPNOTSUPP defined only in userspace include file bits/errno.h and not available in kernel. Because Linux kernel does not support ENOTSUP (single P) and because userspace does not support ENOTSUPP (double PP), report error code for 'operation not supported' via EOPNOTSUPP macro. This patch fixes problem that mwifiex kernel driver sends to userspace unsupported error codes like: "failed: -524 (No error information)". After applying this patch userspace see: "failed: -95 (Not supported)". Signed-off-by: Pali Rohár <pali@kernel.org> Acked-by: Ganapathi Bhat <ganapathi.bhat@nxp.com> Signed-off-by: Kalle Valo <kvalo@codeaurora.org> Link: https://lore.kernel.org/r/20200703112151.18917-1-pali@kernel.org
This commit is contained in:
parent
2c3601e6a3
commit
9187f4e840
@ -3727,11 +3727,11 @@ mwifiex_cfg80211_tdls_mgmt(struct wiphy *wiphy, struct net_device *dev,
|
|||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (!(wiphy->flags & WIPHY_FLAG_SUPPORTS_TDLS))
|
if (!(wiphy->flags & WIPHY_FLAG_SUPPORTS_TDLS))
|
||||||
return -ENOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
/* make sure we are in station mode and connected */
|
/* make sure we are in station mode and connected */
|
||||||
if (!(priv->bss_type == MWIFIEX_BSS_TYPE_STA && priv->media_connected))
|
if (!(priv->bss_type == MWIFIEX_BSS_TYPE_STA && priv->media_connected))
|
||||||
return -ENOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
switch (action_code) {
|
switch (action_code) {
|
||||||
case WLAN_TDLS_SETUP_REQUEST:
|
case WLAN_TDLS_SETUP_REQUEST:
|
||||||
@ -3799,11 +3799,11 @@ mwifiex_cfg80211_tdls_oper(struct wiphy *wiphy, struct net_device *dev,
|
|||||||
|
|
||||||
if (!(wiphy->flags & WIPHY_FLAG_SUPPORTS_TDLS) ||
|
if (!(wiphy->flags & WIPHY_FLAG_SUPPORTS_TDLS) ||
|
||||||
!(wiphy->flags & WIPHY_FLAG_TDLS_EXTERNAL_SETUP))
|
!(wiphy->flags & WIPHY_FLAG_TDLS_EXTERNAL_SETUP))
|
||||||
return -ENOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
/* make sure we are in station mode and connected */
|
/* make sure we are in station mode and connected */
|
||||||
if (!(priv->bss_type == MWIFIEX_BSS_TYPE_STA && priv->media_connected))
|
if (!(priv->bss_type == MWIFIEX_BSS_TYPE_STA && priv->media_connected))
|
||||||
return -ENOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
mwifiex_dbg(priv->adapter, MSG,
|
mwifiex_dbg(priv->adapter, MSG,
|
||||||
"TDLS peer=%pM, oper=%d\n", peer, action);
|
"TDLS peer=%pM, oper=%d\n", peer, action);
|
||||||
@ -3833,7 +3833,7 @@ mwifiex_cfg80211_tdls_oper(struct wiphy *wiphy, struct net_device *dev,
|
|||||||
default:
|
default:
|
||||||
mwifiex_dbg(priv->adapter, ERROR,
|
mwifiex_dbg(priv->adapter, ERROR,
|
||||||
"tdls_oper: operation not supported\n");
|
"tdls_oper: operation not supported\n");
|
||||||
return -ENOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
|
||||||
return mwifiex_tdls_oper(priv, peer, action);
|
return mwifiex_tdls_oper(priv, peer, action);
|
||||||
@ -3914,11 +3914,11 @@ mwifiex_cfg80211_add_station(struct wiphy *wiphy, struct net_device *dev,
|
|||||||
struct mwifiex_private *priv = mwifiex_netdev_get_priv(dev);
|
struct mwifiex_private *priv = mwifiex_netdev_get_priv(dev);
|
||||||
|
|
||||||
if (!(params->sta_flags_set & BIT(NL80211_STA_FLAG_TDLS_PEER)))
|
if (!(params->sta_flags_set & BIT(NL80211_STA_FLAG_TDLS_PEER)))
|
||||||
return -ENOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
/* make sure we are in station mode and connected */
|
/* make sure we are in station mode and connected */
|
||||||
if ((priv->bss_type != MWIFIEX_BSS_TYPE_STA) || !priv->media_connected)
|
if ((priv->bss_type != MWIFIEX_BSS_TYPE_STA) || !priv->media_connected)
|
||||||
return -ENOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
return mwifiex_tdls_oper(priv, mac, MWIFIEX_TDLS_CREATE_LINK);
|
return mwifiex_tdls_oper(priv, mac, MWIFIEX_TDLS_CREATE_LINK);
|
||||||
}
|
}
|
||||||
@ -4151,11 +4151,11 @@ mwifiex_cfg80211_change_station(struct wiphy *wiphy, struct net_device *dev,
|
|||||||
|
|
||||||
/* we support change_station handler only for TDLS peers*/
|
/* we support change_station handler only for TDLS peers*/
|
||||||
if (!(params->sta_flags_set & BIT(NL80211_STA_FLAG_TDLS_PEER)))
|
if (!(params->sta_flags_set & BIT(NL80211_STA_FLAG_TDLS_PEER)))
|
||||||
return -ENOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
/* make sure we are in station mode and connected */
|
/* make sure we are in station mode and connected */
|
||||||
if ((priv->bss_type != MWIFIEX_BSS_TYPE_STA) || !priv->media_connected)
|
if ((priv->bss_type != MWIFIEX_BSS_TYPE_STA) || !priv->media_connected)
|
||||||
return -ENOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
priv->sta_params = params;
|
priv->sta_params = params;
|
||||||
|
|
||||||
|
@ -953,7 +953,7 @@ int mwifiex_set_mac_address(struct mwifiex_private *priv,
|
|||||||
} else {
|
} else {
|
||||||
/* Internal mac address change */
|
/* Internal mac address change */
|
||||||
if (priv->bss_type == MWIFIEX_BSS_TYPE_ANY)
|
if (priv->bss_type == MWIFIEX_BSS_TYPE_ANY)
|
||||||
return -ENOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
mac_addr = old_mac_addr;
|
mac_addr = old_mac_addr;
|
||||||
|
|
||||||
|
@ -1723,7 +1723,7 @@ mwifiex_cmd_tdls_config(struct mwifiex_private *priv,
|
|||||||
default:
|
default:
|
||||||
mwifiex_dbg(priv->adapter, ERROR,
|
mwifiex_dbg(priv->adapter, ERROR,
|
||||||
"Unknown TDLS configuration\n");
|
"Unknown TDLS configuration\n");
|
||||||
return -ENOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
|
||||||
le16_unaligned_add_cpu(&cmd->size, len);
|
le16_unaligned_add_cpu(&cmd->size, len);
|
||||||
@ -1849,7 +1849,7 @@ mwifiex_cmd_tdls_oper(struct mwifiex_private *priv,
|
|||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
mwifiex_dbg(priv->adapter, ERROR, "Unknown TDLS operation\n");
|
mwifiex_dbg(priv->adapter, ERROR, "Unknown TDLS operation\n");
|
||||||
return -ENOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
|
||||||
le16_unaligned_add_cpu(&cmd->size, config_len);
|
le16_unaligned_add_cpu(&cmd->size, config_len);
|
||||||
|
Loading…
Reference in New Issue
Block a user