iwlwifi: move device_pointers from iwl_priv to iwl_shared
authorDon Fry <donald.h.fry@intel.com>
Thu, 1 Dec 2011 00:12:59 +0000 (16:12 -0800)
committerWey-Yi Guy <wey-yi.w.guy@intel.com>
Thu, 8 Dec 2011 23:55:15 +0000 (15:55 -0800)
Move the low level ucode device_pointers structure to iwl_shared.

Signed-off-by: Don Fry <donald.h.fry@intel.com>
Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com>
drivers/net/wireless/iwlwifi/iwl-agn-rx.c
drivers/net/wireless/iwlwifi/iwl-agn.c
drivers/net/wireless/iwlwifi/iwl-dev.h
drivers/net/wireless/iwlwifi/iwl-mac80211.c
drivers/net/wireless/iwlwifi/iwl-shared.h
drivers/net/wireless/iwlwifi/iwl-trans-pcie-rx.c
drivers/net/wireless/iwlwifi/iwl-ucode.c

index 90c55ea4cc39a05309f909a1c3986acf5b04c7a0..9001c23f27bb1f6a8f4e8b42265ab46d6e489a42 100644 (file)
@@ -1165,7 +1165,7 @@ int iwl_rx_dispatch(struct iwl_priv *priv, struct iwl_rx_mem_buffer *rxb,
                                pkt->hdr.cmd);
                        w->triggered = true;
                        if (w->fn)
-                               w->fn(priv, pkt, w->fn_data);
+                               w->fn(trans(priv), pkt, w->fn_data);
                }
                spin_unlock(&priv->shrd->notif_wait_lock);
 
index 6b99448d45484dcbfefe2d1bf497ec94d13258c8..02927faa61783a259d415db542c118e410ae1207 100644 (file)
@@ -366,7 +366,7 @@ static void iwl_continuous_event_trace(struct iwl_priv *priv)
        u32 num_wraps;  /* # times uCode wrapped to top of log */
        u32 next_entry; /* index of next entry to be written by uCode */
 
-       base = priv->device_pointers.error_event_table;
+       base = priv->shrd->device_pointers.error_event_table;
        if (iwlagn_hw_valid_rtc_data_addr(base)) {
                capacity = iwl_read_targ_mem(bus(priv), base);
                num_wraps = iwl_read_targ_mem(bus(priv),
index 68f9dc5e9248605325179746be2b5e697616c601..aa225be8dee893b38950c21c47cb04a36b1dde11 100644 (file)
@@ -865,11 +865,6 @@ struct iwl_priv {
 
        __le16 switch_channel;
 
-       struct {
-               u32 error_event_table;
-               u32 log_event_table;
-       } device_pointers;
-
        u16 active_rate;
 
        u8 start_calib;
index 2dd536c9e192069faa472d5fb00534e29af2bea7..b3886d20c272d2ffb66ebd6547377d44ddc91fde 100644 (file)
@@ -427,7 +427,7 @@ static int iwlagn_mac_resume(struct ieee80211_hw *hw)
        iwl_write32(bus(priv), CSR_UCODE_DRV_GP1_CLR,
                          CSR_UCODE_DRV_GP1_BIT_D3_CFG_COMPLETE);
 
-       base = priv->device_pointers.error_event_table;
+       base = priv->shrd->device_pointers.error_event_table;
        if (iwlagn_hw_valid_rtc_data_addr(base)) {
                spin_lock_irqsave(&bus(priv)->reg_lock, flags);
                ret = iwl_grab_nic_access_silent(bus(priv));
index 53cddd32fb74ad77a584daeaedecdc992a2d7c1b..29a7284aa3ef9ff60cb0c9154f70f1b583b39538 100644 (file)
@@ -97,6 +97,7 @@
 struct iwl_cfg;
 struct iwl_bus;
 struct iwl_priv;
+struct iwl_trans;
 struct iwl_sensitivity_ranges;
 struct iwl_trans_ops;
 
@@ -294,7 +295,7 @@ enum iwl_ucode_type {
 struct iwl_notification_wait {
        struct list_head list;
 
-       void (*fn)(struct iwl_priv *priv, struct iwl_rx_packet *pkt,
+       void (*fn)(struct iwl_trans *trans, struct iwl_rx_packet *pkt,
                   void *data);
        void *fn_data;
 
@@ -323,6 +324,7 @@ struct iwl_notification_wait {
  * @notif_waits: things waiting for notification
  * @notif_wait_lock: lock protecting notification
  * @notif_waitq: head of notification wait queue
+ * @device_pointers: pointers to ucode event tables
  */
 struct iwl_shared {
 #ifdef CONFIG_IWLWIFI_DEBUG
@@ -361,6 +363,12 @@ struct iwl_shared {
        struct list_head notif_waits;
        spinlock_t notif_wait_lock;
        wait_queue_head_t notif_waitq;
+
+       struct {
+               u32 error_event_table;
+               u32 log_event_table;
+       } device_pointers;
+
 };
 
 /*Whatever _m is (iwl_trans, iwl_priv, iwl_bus, these macros will work */
@@ -510,7 +518,7 @@ void __acquires(wait_entry)
 iwl_init_notification_wait(struct iwl_shared *shrd,
                              struct iwl_notification_wait *wait_entry,
                              u8 cmd,
-                             void (*fn)(struct iwl_priv *priv,
+                             void (*fn)(struct iwl_trans *trans,
                                         struct iwl_rx_packet *pkt,
                                         void *data),
                              void *fn_data);
index a0d43d6636f38df0f89459d9671e84dbfe104ec8..2ee00e0f39d346e6f71287d5b4ffc057ff3de676 100644 (file)
@@ -594,7 +594,7 @@ static void iwl_dump_nic_error_log(struct iwl_trans *trans)
        struct iwl_trans_pcie *trans_pcie =
                IWL_TRANS_GET_PCIE_TRANS(trans);
 
-       base = priv->device_pointers.error_event_table;
+       base = trans->shrd->device_pointers.error_event_table;
        if (trans->shrd->ucode_type == IWL_UCODE_INIT) {
                if (!base)
                        base = priv->init_errlog_ptr;
@@ -724,7 +724,7 @@ static int iwl_print_event_log(struct iwl_trans *trans, u32 start_idx,
        if (num_events == 0)
                return pos;
 
-       base = priv->device_pointers.log_event_table;
+       base = trans->shrd->device_pointers.log_event_table;
        if (trans->shrd->ucode_type == IWL_UCODE_INIT) {
                if (!base)
                        base = priv->init_evtlog_ptr;
@@ -838,7 +838,7 @@ int iwl_dump_nic_event_log(struct iwl_trans *trans, bool full_log,
        size_t bufsz = 0;
        struct iwl_priv *priv = priv(trans);
 
-       base = priv->device_pointers.log_event_table;
+       base = trans->shrd->device_pointers.log_event_table;
        if (trans->shrd->ucode_type == IWL_UCODE_INIT) {
                logsize = priv->init_evtlog_size;
                if (!base)
index f56066964d88f39af1d6c8432824ff25f0a17ca0..256f647763aa16464a52c3d853c7ba58b427e54b 100644 (file)
@@ -550,7 +550,7 @@ struct iwlagn_alive_data {
        u8 subtype;
 };
 
-static void iwl_alive_fn(struct iwl_priv *priv,
+static void iwl_alive_fn(struct iwl_trans *trans,
                            struct iwl_rx_packet *pkt,
                            void *data)
 {
@@ -559,14 +559,14 @@ static void iwl_alive_fn(struct iwl_priv *priv,
 
        palive = &pkt->u.alive_frame;
 
-       IWL_DEBUG_FW(priv, "Alive ucode status 0x%08X revision "
+       IWL_DEBUG_FW(trans, "Alive ucode status 0x%08X revision "
                       "0x%01X 0x%01X\n",
                       palive->is_valid, palive->ver_type,
                       palive->ver_subtype);
 
-       priv->device_pointers.error_event_table =
+       trans->shrd->device_pointers.error_event_table =
                le32_to_cpu(palive->error_event_table_ptr);
-       priv->device_pointers.log_event_table =
+       trans->shrd->device_pointers.log_event_table =
                le32_to_cpu(palive->log_event_table_ptr);
 
        alive_data->subtype = palive->ver_subtype;
@@ -577,7 +577,7 @@ static void iwl_alive_fn(struct iwl_priv *priv,
 void iwl_init_notification_wait(struct iwl_shared *shrd,
                                   struct iwl_notification_wait *wait_entry,
                                   u8 cmd,
-                                  void (*fn)(struct iwl_priv *priv,
+                                  void (*fn)(struct iwl_trans *trans,
                                              struct iwl_rx_packet *pkt,
                                              void *data),
                                   void *fn_data)