wl18xx: export low/high band component values as module params
authorLuciano Coelho <coelho@ti.com>
Thu, 10 May 2012 09:14:17 +0000 (12:14 +0300)
committerLuciano Coelho <coelho@ti.com>
Tue, 5 Jun 2012 12:58:51 +0000 (15:58 +0300)
We use hardcoded values for the different board types.  In some cases
we may need to override the defaults, so export the values as module
params.  If not defined, the defaults for the specified board type
will be used.

Signed-off-by: Luciano Coelho <coelho@ti.com>
Signed-off-by: Arik Nemtsov <arik@wizery.com>
drivers/net/wireless/ti/wl18xx/main.c

index ab3dd11..6baeb26 100644 (file)
@@ -49,6 +49,10 @@ static int n_antennas_2_param = 1;
 static int n_antennas_5_param = 1;
 static bool checksum_param = true;
 static bool enable_11a_param = true;
+static int low_band_component = -1;
+static int low_band_component_type = -1;
+static int high_band_component = -1;
+static int high_band_component_type = -1;
 
 static const u8 wl18xx_rate_to_idx_2ghz[] = {
        /* MCS rates are used only with 11n */
@@ -1160,6 +1164,32 @@ int __devinit wl18xx_probe(struct platform_device *pdev)
                goto out_free;
        }
 
+       /*
+        * If the module param is not set, update it with the one from
+        * conf.  If it is set, overwrite conf with it.
+        */
+       if (low_band_component == -1)
+               low_band_component = priv->conf.phy.low_band_component;
+       else
+               priv->conf.phy.low_band_component = low_band_component;
+       if (low_band_component_type == -1)
+               low_band_component_type =
+                       priv->conf.phy.low_band_component_type;
+       else
+               priv->conf.phy.low_band_component_type =
+                       low_band_component_type;
+
+       if (high_band_component == -1)
+               high_band_component = priv->conf.phy.high_band_component;
+       else
+               priv->conf.phy.high_band_component = high_band_component;
+       if (high_band_component_type == -1)
+               high_band_component_type =
+                       priv->conf.phy.high_band_component_type;
+       else
+               priv->conf.phy.high_band_component_type =
+                       high_band_component_type;
+
        if (!checksum_param) {
                wl18xx_ops.set_rx_csum = NULL;
                wl18xx_ops.init_vif = NULL;
@@ -1224,6 +1254,22 @@ MODULE_PARM_DESC(checksum, "Enable TCP checksum: boolean (defaults to true)");
 module_param_named(enable_11a, enable_11a_param, bool, S_IRUSR);
 MODULE_PARM_DESC(enable_11a, "Enable 11a (5GHz): boolean (defaults to true)");
 
+module_param(low_band_component, uint, S_IRUSR);
+MODULE_PARM_DESC(low_band_component, "Low band component: u8 "
+                "(default is 0x01)");
+
+module_param(low_band_component_type, uint, S_IRUSR);
+MODULE_PARM_DESC(low_band_component_type, "Low band component type: u8 "
+                "(default is 0x05 or 0x06 depending on the board_type)");
+
+module_param(high_band_component, uint, S_IRUSR);
+MODULE_PARM_DESC(high_band_component, "High band component: u8, "
+                "(default is 0x01)");
+
+module_param(high_band_component_type, uint, S_IRUSR);
+MODULE_PARM_DESC(high_band_component_type, "High band component type: u8 "
+                "(default is 0x09)");
+
 MODULE_LICENSE("GPL v2");
 MODULE_AUTHOR("Luciano Coelho <coelho@ti.com>");
 MODULE_FIRMWARE(WL18XX_FW_NAME);