]> git.openfabrics.org - ~shefty/rdma-dev.git/commitdiff
iwlwifi: configure transport layer from dvm op mode
authorMeenakshi Venkataraman <meenakshi.venkataraman@intel.com>
Wed, 7 Mar 2012 17:52:35 +0000 (09:52 -0800)
committerJohn W. Linville <linville@tuxdriver.com>
Thu, 8 Mar 2012 18:59:55 +0000 (13:59 -0500)
Introduce the iwl_trans_config struct which contains
state variables that only the op mode can determine,
but which the transport layer needs to know.

Signed-off-by: Meenakshi Venkataraman <meenakshi.venkataraman@intel.com>
Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/iwlwifi/iwl-agn.c
drivers/net/wireless/iwlwifi/iwl-trans.h

index 6ed2f782177be26b4d21f432e0ad5e816c46fd8b..83018ec11bc7f0bab2fb45db78e6d832dc188ccb 100644 (file)
@@ -1185,6 +1185,7 @@ static struct iwl_op_mode *iwl_op_mode_dvm_start(struct iwl_trans *trans,
        struct iwl_op_mode *op_mode;
        u16 num_mac;
        u32 ucode_flags;
+       struct iwl_trans_config trans_cfg;
 
        /************************
         * 1. Allocating HW data
@@ -1205,7 +1206,14 @@ static struct iwl_op_mode *iwl_op_mode_dvm_start(struct iwl_trans *trans,
        /* TODO: remove fw from shared data later */
        priv->shrd->fw = fw;
 
-       iwl_trans_configure(trans(priv), op_mode);
+       /*
+        * Populate the state variables that the transport layer needs
+        * to know about.
+        */
+       trans_cfg.op_mode = op_mode;
+
+       /* Configure transport layer */
+       iwl_trans_configure(trans(priv), &trans_cfg);
 
        /* At this point both hw and priv are allocated. */
 
index ed6ab449e439c5f14557e09b7c3e1e77ffb7893f..b6fd4277962479ff34081523d06c2caea32dad48 100644 (file)
@@ -274,6 +274,16 @@ static inline struct page *rxb_steal_page(struct iwl_rx_cmd_buffer *r)
        return p;
 }
 
+/**
+ * struct iwl_trans_config - transport configuration
+ *
+ * @op_mode: pointer to the upper layer.
+ *     Must be set before any other call.
+ */
+struct iwl_trans_config {
+       struct iwl_op_mode *op_mode;
+};
+
 /**
  * struct iwl_trans_ops - transport specific operations
  *
@@ -408,13 +418,13 @@ struct iwl_trans {
 };
 
 static inline void iwl_trans_configure(struct iwl_trans *trans,
-                                      struct iwl_op_mode *op_mode)
+                                      const struct iwl_trans_config *trans_cfg)
 {
        /*
         * only set the op_mode for the moment. Later on, this function will do
         * more
         */
-       trans->op_mode = op_mode;
+       trans->op_mode = trans_cfg->op_mode;
 }
 
 static inline int iwl_trans_start_hw(struct iwl_trans *trans)