iwlwifi: avoid void pointer arithmetic
authorJohannes Berg <johannes.berg@intel.com>
Fri, 28 Jan 2022 13:34:29 +0000 (15:34 +0200)
committerLuca Coelho <luciano.coelho@intel.com>
Fri, 18 Feb 2022 08:40:50 +0000 (10:40 +0200)
Avoid void pointer arithmetic since it's technically
undefined and causes warnings in some places that use
our code.

Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: Luca Coelho <luciano.coelho@intel.com>
Link: https://lore.kernel.org/r/iwlwifi.20220128153014.e349104ecd94.Iadc937f475158b9437becdfefb361a97e7eaa934@changeid
Signed-off-by: Luca Coelho <luciano.coelho@intel.com>
14 files changed:
drivers/net/wireless/intel/iwlwifi/fw/dbg.c
drivers/net/wireless/intel/iwlwifi/fw/paging.c
drivers/net/wireless/intel/iwlwifi/mvm/d3.c
drivers/net/wireless/intel/iwlwifi/mvm/debugfs.c
drivers/net/wireless/intel/iwlwifi/mvm/fw.c
drivers/net/wireless/intel/iwlwifi/mvm/rx.c
drivers/net/wireless/intel/iwlwifi/mvm/rxmq.c
drivers/net/wireless/intel/iwlwifi/mvm/scan.c
drivers/net/wireless/intel/iwlwifi/pcie/internal.h
drivers/net/wireless/intel/iwlwifi/pcie/rx.c
drivers/net/wireless/intel/iwlwifi/pcie/trans.c
drivers/net/wireless/intel/iwlwifi/pcie/tx.c
drivers/net/wireless/intel/iwlwifi/queue/tx.c
drivers/net/wireless/intel/iwlwifi/queue/tx.h

index 7ad9cee925da53cba8b36be1cfd0dddda85e483b..cef3f54908fac8c945002c3b36f0563fc3247651 100644 (file)
@@ -1992,7 +1992,7 @@ static u32 iwl_dump_ini_mem(struct iwl_fw_runtime *fwrt, struct list_head *list,
        u32 type = reg->type;
        u32 id = le32_to_cpu(reg->id);
        u32 num_of_ranges, i, size;
-       void *range;
+       u8 *range;
 
        /*
         * The higher part of the ID from 2 is irrelevant for
index 89ec3693c6ac9424c530e65b517720fbc69c7340..945bc4160cc95c1834a7ba5138aeb30ad6bd22d8 100644 (file)
@@ -197,7 +197,7 @@ static int iwl_fill_paging_mem(struct iwl_fw_runtime *fwrt,
                }
 
                memcpy(page_address(block->fw_paging_block),
-                      image->sec[sec_idx].data + offset, len);
+                      (const u8 *)image->sec[sec_idx].data + offset, len);
                block->fw_offs = image->sec[sec_idx].offset + offset;
                dma_sync_single_for_device(fwrt->trans->dev,
                                           block->fw_paging_phys,
index b1dffcde4a9ac623de17824dcbf05538d1bfc9b4..9f0e436f11f3734ad093a0e2f5902d399ffb71e0 100644 (file)
@@ -1084,7 +1084,7 @@ static int iwl_mvm_wowlan_config_key_params(struct iwl_mvm *mvm,
                                        sizeof(struct iwl_wowlan_kek_kck_material_cmd_v2);
                        /* skip the sta_id at the beginning */
                        _kek_kck_cmd = (void *)
-                               ((u8 *)_kek_kck_cmd) + sizeof(kek_kck_cmd.sta_id);
+                               ((u8 *)_kek_kck_cmd + sizeof(kek_kck_cmd.sta_id));
                }
 
                IWL_DEBUG_WOWLAN(mvm, "setting akm %d\n",
index d256652a6ce3aa973eb5445b05054e2b22a4b54a..be11161bc57d9defa3d66d732ba7b2f3f89f0b95 100644 (file)
@@ -1945,7 +1945,7 @@ static ssize_t iwl_dbgfs_mem_read(struct file *file, char __user *user_buf,
                goto out;
        }
 
-       ret = len - copy_to_user(user_buf, (void *)rsp->data + delta, len);
+       ret = len - copy_to_user(user_buf, (u8 *)rsp->data + delta, len);
        *ppos += ret;
 
 out:
index dde979b345337ea84a5a58a6742272bce1051875..fcbe7c3656add32b3cb1db3f383c53c46c26cd03 100644 (file)
@@ -735,7 +735,7 @@ out:
                mvm->nvm_data->bands[0].n_channels = 1;
                mvm->nvm_data->bands[0].n_bitrates = 1;
                mvm->nvm_data->bands[0].bitrates =
-                       (void *)mvm->nvm_data->channels + 1;
+                       (void *)((u8 *)mvm->nvm_data->channels + 1);
                mvm->nvm_data->bands[0].bitrates->hw_value = 10;
        }
 
index 64446a11ef9805901253ea34f62dca24e62060c3..40d0e6bf336bf04e63e0493f12a2eba44a093081 100644 (file)
@@ -83,8 +83,8 @@ static void iwl_mvm_pass_packet_to_mac80211(struct iwl_mvm *mvm,
        fraglen = len - hdrlen;
 
        if (fraglen) {
-               int offset = (void *)hdr + hdrlen -
-                            rxb_addr(rxb) + rxb_offset(rxb);
+               int offset = (u8 *)hdr + hdrlen -
+                            (u8 *)rxb_addr(rxb) + rxb_offset(rxb);
 
                skb_add_rx_frag(skb, 0, rxb_steal_page(rxb), offset,
                                fraglen, rxb->truesize);
index 5f3128fc106620c9cef26b35f16eed86dca1f6b9..2c43a9989783cbe2311d48e1d87bda87bb885f0b 100644 (file)
@@ -217,8 +217,8 @@ static int iwl_mvm_create_skb(struct iwl_mvm *mvm, struct sk_buff *skb,
        fraglen = len - headlen;
 
        if (fraglen) {
-               int offset = (void *)hdr + headlen + pad_len -
-                            rxb_addr(rxb) + rxb_offset(rxb);
+               int offset = (u8 *)hdr + headlen + pad_len -
+                            (u8 *)rxb_addr(rxb) + rxb_offset(rxb);
 
                skb_add_rx_frag(skb, 0, rxb_steal_page(rxb), offset,
                                fraglen, rxb->truesize);
index ce7afca36bbffeb5e15f7d279076da193255fe36..0ee766c6cff8cbb470e077504e103ab34a3f3612 100644 (file)
@@ -2158,7 +2158,7 @@ static int iwl_mvm_scan_umac(struct iwl_mvm *mvm, struct ieee80211_vif *vif,
        struct iwl_scan_req_umac *cmd = mvm->scan_cmd;
        struct iwl_scan_umac_chan_param *chan_param;
        void *cmd_data = iwl_mvm_get_scan_req_umac_data(mvm);
-       void *sec_part = cmd_data + sizeof(struct iwl_scan_channel_cfg_umac) *
+       void *sec_part = (u8 *)cmd_data + sizeof(struct iwl_scan_channel_cfg_umac) *
                mvm->fw->ucode_capa.n_scan_channels;
        struct iwl_scan_req_umac_tail_v2 *tail_v2 =
                (struct iwl_scan_req_umac_tail_v2 *)sec_part;
index a43e56c7689f3c2fa1cbae0a9d720b9e2da93f16..6dce36d3269359b8bac33bd7bd22011b081820c4 100644 (file)
@@ -363,7 +363,7 @@ struct iwl_trans_pcie {
 
        /* PCI bus related data */
        struct pci_dev *pci_dev;
-       void __iomem *hw_base;
+       u8 __iomem *hw_base;
 
        bool ucode_write_complete;
        bool sx_complete;
index 9e488f21fde23e0539762fed679b1236c6044e01..21cddfc279d4fff4c1a08f4b827400320847df5f 100644 (file)
@@ -727,7 +727,7 @@ static int iwl_pcie_alloc_rxq_dma(struct iwl_trans *trans,
                        goto err;
        }
 
-       rxq->rb_stts = trans_pcie->base_rb_stts + rxq->id * rb_stts_size;
+       rxq->rb_stts = (u8 *)trans_pcie->base_rb_stts + rxq->id * rb_stts_size;
        rxq->rb_stts_dma =
                trans_pcie->base_rb_stts_dma + rxq->id * rb_stts_size;
 
index ea6823b73b993e5185c229a5d168c98c8698bb49..94efaddfdcc4ab1cd7b8d1331760618fbf4e7964 100644 (file)
@@ -2864,7 +2864,7 @@ static ssize_t iwl_dbgfs_monitor_data_read(struct file *file,
 {
        struct iwl_trans *trans = file->private_data;
        struct iwl_trans_pcie *trans_pcie = IWL_TRANS_GET_PCIE_TRANS(trans);
-       void *cpu_addr = (void *)trans->dbg.fw_mon.block, *curr_buf;
+       u8 *cpu_addr = (void *)trans->dbg.fw_mon.block, *curr_buf;
        struct cont_rec *data = &trans_pcie->fw_mon_data;
        u32 write_ptr_addr, wrap_cnt_addr, write_ptr, wrap_cnt;
        ssize_t size, bytes_copied = 0;
index abe80083fb9beed42afa17a8e2e987b083366e6d..e3b69476f5157877f90f523b4670faa41624b08d 100644 (file)
@@ -154,7 +154,7 @@ static int iwl_pcie_txq_build_tfd(struct iwl_trans *trans, struct iwl_txq *txq,
        void *tfd;
        u32 num_tbs;
 
-       tfd = txq->tfds + trans->txqs.tfd.size * txq->write_ptr;
+       tfd = (u8 *)txq->tfds + trans->txqs.tfd.size * txq->write_ptr;
 
        if (reset)
                memset(tfd, 0, trans->txqs.tfd.size);
index 0730657d54bf8a17fc609abec267ccc0208ab4d4..e31ae5d0e26a67b113f83a50780b6d53e567d13b 100644 (file)
@@ -189,7 +189,7 @@ static struct page *get_workaround_page(struct iwl_trans *trans,
                return NULL;
 
        /* set the chaining pointer to the previous page if there */
-       *(void **)(page_address(ret) + PAGE_SIZE - sizeof(void *)) = *page_ptr;
+       *(void **)((u8 *)page_address(ret) + PAGE_SIZE - sizeof(void *)) = *page_ptr;
        *page_ptr = ret;
 
        return ret;
@@ -314,7 +314,7 @@ alloc:
                return NULL;
        p->pos = page_address(p->page);
        /* set the chaining pointer to NULL */
-       *(void **)(page_address(p->page) + PAGE_SIZE - sizeof(void *)) = NULL;
+       *(void **)((u8 *)page_address(p->page) + PAGE_SIZE - sizeof(void *)) = NULL;
 out:
        *page_ptr = p->page;
        get_page(p->page);
@@ -963,7 +963,7 @@ void iwl_txq_free_tso_page(struct iwl_trans *trans, struct sk_buff *skb)
        while (next) {
                struct page *tmp = next;
 
-               next = *(void **)(page_address(next) + PAGE_SIZE -
+               next = *(void **)((u8 *)page_address(next) + PAGE_SIZE -
                                  sizeof(void *));
                __free_page(tmp);
        }
index 20efc62acf133a1c43c40d504a09640947fef580..19178c88bb229829a1e02b8e54c530361036889b 100644 (file)
@@ -41,7 +41,7 @@ static inline void *iwl_txq_get_tfd(struct iwl_trans *trans,
        if (trans->trans_cfg->use_tfh)
                idx = iwl_txq_get_cmd_index(txq, idx);
 
-       return txq->tfds + trans->txqs.tfd.size * idx;
+       return (u8 *)txq->tfds + trans->txqs.tfd.size * idx;
 }
 
 int iwl_txq_alloc(struct iwl_trans *trans, struct iwl_txq *txq, int slots_num,