This commit refactors ks_wlan_translate_scan function with
the following changes:

    - reorder local variables
    - use ether_addr_copy to copy ethernet addresses
    - change style in 'current_ev' variable assignments
    - make use of some ternaries avoiding if-else code
    - use preferred style for comments
    - extract common code into a new ks_wlan_add_leader_event
      function

After this changes readability has been improved.

Signed-off-by: Sergio Paracuellos <sergio.paracuel...@gmail.com>
---
 drivers/staging/ks7010/ks_wlan_net.c | 150 +++++++++++++++--------------------
 1 file changed, 66 insertions(+), 84 deletions(-)

diff --git a/drivers/staging/ks7010/ks_wlan_net.c 
b/drivers/staging/ks7010/ks_wlan_net.c
index b1933b3..5c2cc75 100644
--- a/drivers/staging/ks7010/ks_wlan_net.c
+++ b/drivers/staging/ks7010/ks_wlan_net.c
@@ -1143,6 +1143,33 @@ static int ks_wlan_set_scan(struct net_device *dev,
        return 0;
 }
 
+static char *ks_wlan_add_leader_event(const char *rsn_leader, char *end_buf,
+                                     char *current_ev, struct rsn_ie *rsn,
+                                     struct iw_event *iwe,
+                                     struct iw_request_info *info)
+{
+       char buffer[RSN_IE_BODY_MAX * 2 + 30];
+       char *pbuf;
+       int i;
+
+       pbuf = &buffer[0];
+       memset(iwe, 0, sizeof(*iwe));
+       iwe->cmd = IWEVCUSTOM;
+       memcpy(buffer, rsn_leader, sizeof(rsn_leader) - 1);
+       iwe->u.data.length += sizeof(rsn_leader) - 1;
+       pbuf += sizeof(rsn_leader) - 1;
+       pbuf += sprintf(pbuf, "%02x", rsn->id);
+       pbuf += sprintf(pbuf, "%02x", rsn->size);
+       iwe->u.data.length += 4;
+
+       for (i = 0; i < rsn->size; i++)
+               pbuf += sprintf(pbuf, "%02x", rsn->body[i]);
+
+       iwe->u.data.length += rsn->size * 2;
+
+       return iwe_stream_add_point(info, current_ev, end_buf, iwe, &buffer[0]);
+}
+
 /*
  * Translate scan data returned from the card to a card independent
  * format that the Wireless Tools will understand - Jean II
@@ -1153,22 +1180,19 @@ static inline char *ks_wlan_translate_scan(struct 
net_device *dev,
                                           struct local_ap *ap)
 {
        /* struct ks_wlan_private *priv = (struct ks_wlan_private *)dev->priv; 
*/
+       static const char rsn_leader[] = "rsn_ie=";
+       static const char wpa_leader[] = "wpa_ie=";
        struct iw_event iwe;    /* Temporary buffer */
        u16 capabilities;
        char *current_val;      /* For rates */
        int i;
-       static const char rsn_leader[] = "rsn_ie=";
-       static const char wpa_leader[] = "wpa_ie=";
-       char buf0[RSN_IE_BODY_MAX * 2 + 30];
-       char buf1[RSN_IE_BODY_MAX * 2 + 30];
-       char *pbuf;
+
        /* First entry *MUST* be the AP MAC address */
        iwe.cmd = SIOCGIWAP;
        iwe.u.ap_addr.sa_family = ARPHRD_ETHER;
-       memcpy(iwe.u.ap_addr.sa_data, ap->bssid, ETH_ALEN);
-       current_ev =
-           iwe_stream_add_event(info, current_ev, end_buf, &iwe,
-                                IW_EV_ADDR_LEN);
+       ether_addr_copy(iwe.u.ap_addr.sa_data, ap->bssid);
+       current_ev = iwe_stream_add_event(info, current_ev,
+                                         end_buf, &iwe, IW_EV_ADDR_LEN);
 
        /* Other entries will be displayed in the order we give them */
 
@@ -1178,21 +1202,17 @@ static inline char *ks_wlan_translate_scan(struct 
net_device *dev,
                iwe.u.data.length = 32;
        iwe.cmd = SIOCGIWESSID;
        iwe.u.data.flags = 1;
-       current_ev =
-           iwe_stream_add_point(info, current_ev, end_buf, &iwe,
-                                ap->ssid.body);
+       current_ev = iwe_stream_add_point(info, current_ev,
+                                         end_buf, &iwe, ap->ssid.body);
 
        /* Add mode */
        iwe.cmd = SIOCGIWMODE;
        capabilities = ap->capability;
        if (capabilities & (WLAN_CAPABILITY_ESS | WLAN_CAPABILITY_IBSS)) {
-               if (capabilities & WLAN_CAPABILITY_ESS)
-                       iwe.u.mode = IW_MODE_INFRA;
-               else
-                       iwe.u.mode = IW_MODE_ADHOC;
-               current_ev =
-                   iwe_stream_add_event(info, current_ev, end_buf, &iwe,
-                                        IW_EV_UINT_LEN);
+               iwe.u.mode = (capabilities & WLAN_CAPABILITY_ESS) ?
+                             IW_MODE_INFRA : IW_MODE_ADHOC;
+               current_ev = iwe_stream_add_event(info, current_ev,
+                                                 end_buf, &iwe, 
IW_EV_UINT_LEN);
        }
 
        /* Add frequency */
@@ -1200,32 +1220,29 @@ static inline char *ks_wlan_translate_scan(struct 
net_device *dev,
        iwe.u.freq.m = ap->channel;
        iwe.u.freq.m = frequency_list[iwe.u.freq.m - 1] * 100000;
        iwe.u.freq.e = 1;
-       current_ev =
-           iwe_stream_add_event(info, current_ev, end_buf, &iwe,
-                                IW_EV_FREQ_LEN);
+       current_ev = iwe_stream_add_event(info, current_ev,
+                                         end_buf, &iwe, IW_EV_FREQ_LEN);
 
        /* Add quality statistics */
        iwe.cmd = IWEVQUAL;
        iwe.u.qual.level = 256 - ap->rssi;
        iwe.u.qual.qual = ap->sq;
        iwe.u.qual.noise = 0;   /* invalid noise value */
-       current_ev =
-           iwe_stream_add_event(info, current_ev, end_buf, &iwe,
-                                IW_EV_QUAL_LEN);
+       current_ev = iwe_stream_add_event(info, current_ev, end_buf,
+                                         &iwe, IW_EV_QUAL_LEN);
 
        /* Add encryption capability */
        iwe.cmd = SIOCGIWENCODE;
-       if (capabilities & WLAN_CAPABILITY_PRIVACY)
-               iwe.u.data.flags = IW_ENCODE_ENABLED | IW_ENCODE_NOKEY;
-       else
-               iwe.u.data.flags = IW_ENCODE_DISABLED;
+       iwe.u.data.flags = (capabilities & WLAN_CAPABILITY_PRIVACY) ?
+                           (IW_ENCODE_ENABLED | IW_ENCODE_NOKEY) :
+                            IW_ENCODE_DISABLED;
        iwe.u.data.length = 0;
-       current_ev =
-           iwe_stream_add_point(info, current_ev, end_buf, &iwe,
-                                ap->ssid.body);
+       current_ev = iwe_stream_add_point(info, current_ev, end_buf,
+                                         &iwe, ap->ssid.body);
 
-       /* Rate : stuffing multiple values in a single event require a bit
-        * more of magic - Jean II
+       /*
+        * Rate : stuffing multiple values in a single event
+        * require a bit more of magic - Jean II
         */
        current_val = current_ev + IW_EV_LCP_LEN;
 
@@ -1243,9 +1260,9 @@ static inline char *ks_wlan_translate_scan(struct 
net_device *dev,
                /* Bit rate given in 500 kb/s units (+ 0x80) */
                iwe.u.bitrate.value = ((ap->rate_set.body[i] & 0x7f) * 500000);
                /* Add new value to event */
-               current_val =
-                   iwe_stream_add_value(info, current_ev, current_val, end_buf,
-                                        &iwe, IW_EV_PARAM_LEN);
+               current_val = iwe_stream_add_value(info, current_ev,
+                                                  current_val, end_buf, &iwe,
+                                                  IW_EV_PARAM_LEN);
        }
        /* Check if we added any event */
        if ((current_val - current_ev) > IW_EV_LCP_LEN)
@@ -1253,53 +1270,18 @@ static inline char *ks_wlan_translate_scan(struct 
net_device *dev,
 
 #define GENERIC_INFO_ELEM_ID 0xdd
 #define RSN_INFO_ELEM_ID 0x30
-       if (ap->rsn_ie.id == RSN_INFO_ELEM_ID && ap->rsn_ie.size != 0) {
-               pbuf = &buf0[0];
-               memset(&iwe, 0, sizeof(iwe));
-               iwe.cmd = IWEVCUSTOM;
-               memcpy(buf0, rsn_leader, sizeof(rsn_leader) - 1);
-               iwe.u.data.length += sizeof(rsn_leader) - 1;
-               pbuf += sizeof(rsn_leader) - 1;
-
-               pbuf += sprintf(pbuf, "%02x", ap->rsn_ie.id);
-               pbuf += sprintf(pbuf, "%02x", ap->rsn_ie.size);
-               iwe.u.data.length += 4;
-
-               for (i = 0; i < ap->rsn_ie.size; i++)
-                       pbuf += sprintf(pbuf, "%02x", ap->rsn_ie.body[i]);
-               iwe.u.data.length += (ap->rsn_ie.size) * 2;
-
-               netdev_dbg(dev, "ap->rsn.size=%d\n", ap->rsn_ie.size);
-
-               current_ev =
-                   iwe_stream_add_point(info, current_ev, end_buf, &iwe,
-                                        &buf0[0]);
-       }
-       if (ap->wpa_ie.id == GENERIC_INFO_ELEM_ID && ap->wpa_ie.size != 0) {
-               pbuf = &buf1[0];
-               memset(&iwe, 0, sizeof(iwe));
-               iwe.cmd = IWEVCUSTOM;
-               memcpy(buf1, wpa_leader, sizeof(wpa_leader) - 1);
-               iwe.u.data.length += sizeof(wpa_leader) - 1;
-               pbuf += sizeof(wpa_leader) - 1;
-
-               pbuf += sprintf(pbuf, "%02x", ap->wpa_ie.id);
-               pbuf += sprintf(pbuf, "%02x", ap->wpa_ie.size);
-               iwe.u.data.length += 4;
-
-               for (i = 0; i < ap->wpa_ie.size; i++)
-                       pbuf += sprintf(pbuf, "%02x", ap->wpa_ie.body[i]);
-               iwe.u.data.length += (ap->wpa_ie.size) * 2;
-
-               netdev_dbg(dev, "ap->rsn.size=%d\n", ap->wpa_ie.size);
-               netdev_dbg(dev, "iwe.u.data.length=%d\n", iwe.u.data.length);
-
-               current_ev =
-                   iwe_stream_add_point(info, current_ev, end_buf, &iwe,
-                                        &buf1[0]);
-       }
-
-       /* The other data in the scan result are not really
+       if (ap->rsn_ie.id == RSN_INFO_ELEM_ID && ap->rsn_ie.size != 0)
+               current_ev = ks_wlan_add_leader_event(rsn_leader, end_buf,
+                                                     current_ev, &ap->rsn_ie,
+                                                     &iwe, info);
+
+       if (ap->wpa_ie.id == GENERIC_INFO_ELEM_ID && ap->wpa_ie.size != 0)
+               current_ev = ks_wlan_add_leader_event(wpa_leader, end_buf,
+                                                     current_ev, &ap->wpa_ie,
+                                                     &iwe, info);
+
+       /*
+        * The other data in the scan result are not really
         * interesting, so for now drop it - Jean II
         */
        return current_ev;
-- 
2.7.4

_______________________________________________
devel mailing list
de...@linuxdriverproject.org
http://driverdev.linuxdriverproject.org/mailman/listinfo/driverdev-devel

Reply via email to