staging/rtl8192e: Remove all strcpy() uses
authorLen Baker <len.baker@gmx.com>
Fri, 23 Jul 2021 17:32:16 +0000 (19:32 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 27 Jul 2021 13:20:56 +0000 (15:20 +0200)
strcpy() performs no bounds checking on the destination buffer. This
could result in linear overflows beyond the end of the buffer, leading
to all kinds of misbehaviors. The safe replacement is strscpy().

It is also dangerous a strcpy() followed by a strcat(). In this case,
refactor the code using scnprintf() and avoid this combination.

Signed-off-by: Len Baker <len.baker@gmx.com>
Link: https://lore.kernel.org/r/20210723173216.12157-1-len.baker@gmx.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/rtl8192e/rtl8192e/r8192E_dev.c
drivers/staging/rtl8192e/rtllib_softmac.c
drivers/staging/rtl8192e/rtllib_softmac_wx.c

index b626ac45db8047a11f27a4bad6863cc0b4de9a57..358b629d2cc64c748c07c09d5675c535a4154376 100644 (file)
@@ -2167,7 +2167,7 @@ rtl92e_init_variables(struct net_device  *dev)
 {
        struct r8192_priv *priv = rtllib_priv(dev);
 
-       strcpy(priv->nick, "rtl8192E");
+       strscpy(priv->nick, "rtl8192E", sizeof(priv->nick));
 
        priv->rtllib->softmac_features  = IEEE_SOFTMAC_SCAN |
                IEEE_SOFTMAC_ASSOCIATE | IEEE_SOFTMAC_PROBERQ |
index 25b3d3950a3c632625ff8303d1fb9b1aca693848..d2726d01c7573fe8230e0a7e0f7f811c1ff8cffc 100644 (file)
@@ -2582,7 +2582,8 @@ static void rtllib_start_ibss_wq(void *data)
        mutex_lock(&ieee->wx_mutex);
 
        if (ieee->current_network.ssid_len == 0) {
-               strcpy(ieee->current_network.ssid, RTLLIB_DEFAULT_TX_ESSID);
+               strscpy(ieee->current_network.ssid, RTLLIB_DEFAULT_TX_ESSID,
+                       sizeof(ieee->current_network.ssid));
                ieee->current_network.ssid_len = strlen(RTLLIB_DEFAULT_TX_ESSID);
                ieee->ssid_set = 1;
        }
index f89799d43b1b4d006053c893da5a70ce0d454e4e..57a6d1130b6acdfe038fdc59967bd773cb5fa25f 100644 (file)
@@ -539,18 +539,14 @@ int rtllib_wx_set_rawtx(struct rtllib_device *ieee,
 }
 EXPORT_SYMBOL(rtllib_wx_set_rawtx);
 
-int rtllib_wx_get_name(struct rtllib_device *ieee,
-                            struct iw_request_info *info,
-                            union iwreq_data *wrqu, char *extra)
+int rtllib_wx_get_name(struct rtllib_device *ieee, struct iw_request_info *info,
+                      union iwreq_data *wrqu, char *extra)
 {
-       strcpy(wrqu->name, "802.11");
-
-       if (ieee->modulation & RTLLIB_CCK_MODULATION)
-               strcat(wrqu->name, "b");
-       if (ieee->modulation & RTLLIB_OFDM_MODULATION)
-               strcat(wrqu->name, "g");
-       if (ieee->mode & (IEEE_N_24G | IEEE_N_5G))
-               strcat(wrqu->name, "n");
+       const char *b = ieee->modulation & RTLLIB_CCK_MODULATION ? "b" : "";
+       const char *g = ieee->modulation & RTLLIB_OFDM_MODULATION ? "g" : "";
+       const char *n = ieee->mode & (IEEE_N_24G | IEEE_N_5G) ? "n" : "";
+
+       scnprintf(wrqu->name, sizeof(wrqu->name), "802.11%s%s%s", b, g, n);
        return 0;
 }
 EXPORT_SYMBOL(rtllib_wx_get_name);