/* FW debug data parsed for driver usage */
        bool dbg_dest_tlv_init;
-       u8 *dbg_dest_ver;
+       const u8 *dbg_dest_ver;
        union {
-               struct iwl_fw_dbg_dest_tlv *dbg_dest_tlv;
-               struct iwl_fw_dbg_dest_tlv_v1 *dbg_dest_tlv_v1;
+               const struct iwl_fw_dbg_dest_tlv *dbg_dest_tlv;
+               const struct iwl_fw_dbg_dest_tlv_v1 *dbg_dest_tlv_v1;
        };
-       struct iwl_fw_dbg_conf_tlv *dbg_conf_tlv[FW_DBG_CONF_MAX];
+       const struct iwl_fw_dbg_conf_tlv *dbg_conf_tlv[FW_DBG_CONF_MAX];
        size_t dbg_conf_tlv_len[FW_DBG_CONF_MAX];
-       struct iwl_fw_dbg_trigger_tlv *dbg_trigger_tlv[FW_DBG_TRIGGER_MAX];
+       const struct iwl_fw_dbg_trigger_tlv *dbg_trigger_tlv[FW_DBG_TRIGGER_MAX];
        size_t dbg_trigger_tlv_len[FW_DBG_TRIGGER_MAX];
        struct iwl_fw_dbg_mem_seg_tlv *dbg_mem_tlv;
        size_t n_mem_tlv;
 static int iwl_store_cscheme(struct iwl_fw *fw, const u8 *data, const u32 len)
 {
        int i, j;
-       struct iwl_fw_cscheme_list *l = (struct iwl_fw_cscheme_list *)data;
-       struct iwl_fw_cipher_scheme *fwcs;
+       const struct iwl_fw_cscheme_list *l =
+               (const struct iwl_fw_cscheme_list *)data;
+       const struct iwl_fw_cipher_scheme *fwcs;
 
        if (len < sizeof(*l) ||
            len < sizeof(l->size) + l->size * sizeof(l->cs[0]))
 {
        struct fw_img_parsing *img;
        struct fw_sec *sec;
-       struct fw_sec_parsing *sec_parse;
+       const struct fw_sec_parsing *sec_parse;
        size_t alloc_size;
 
        if (WARN_ON(!pieces || !data || type >= IWL_UCODE_TYPE_MAX))
                return -1;
 
-       sec_parse = (struct fw_sec_parsing *)data;
+       sec_parse = (const struct fw_sec_parsing *)data;
 
        img = &pieces->img[type];
 
 
 static int iwl_set_default_calib(struct iwl_drv *drv, const u8 *data)
 {
-       struct iwl_tlv_calib_data *def_calib =
-                                       (struct iwl_tlv_calib_data *)data;
+       const struct iwl_tlv_calib_data *def_calib =
+                                       (const struct iwl_tlv_calib_data *)data;
        u32 ucode_type = le32_to_cpu(def_calib->ucode_type);
        if (ucode_type >= IWL_UCODE_TYPE_MAX) {
                IWL_ERR(drv, "Wrong ucode_type %u for default calibration.\n",
 static void iwl_set_ucode_api_flags(struct iwl_drv *drv, const u8 *data,
                                    struct iwl_ucode_capabilities *capa)
 {
-       const struct iwl_ucode_api *ucode_api = (void *)data;
+       const struct iwl_ucode_api *ucode_api = (const void *)data;
        u32 api_index = le32_to_cpu(ucode_api->api_index);
        u32 api_flags = le32_to_cpu(ucode_api->api_flags);
        int i;
 static void iwl_set_ucode_capabilities(struct iwl_drv *drv, const u8 *data,
                                       struct iwl_ucode_capabilities *capa)
 {
-       const struct iwl_ucode_capa *ucode_capa = (void *)data;
+       const struct iwl_ucode_capa *ucode_capa = (const void *)data;
        u32 api_index = le32_to_cpu(ucode_capa->api_index);
        u32 api_flags = le32_to_cpu(ucode_capa->api_capa);
        int i;
                                    const struct firmware *ucode_raw,
                                    struct iwl_firmware_pieces *pieces)
 {
-       struct iwl_ucode_header *ucode = (void *)ucode_raw->data;
+       const struct iwl_ucode_header *ucode = (const void *)ucode_raw->data;
        u32 api_ver, hdr_size, build;
        char buildstr[25];
        const u8 *src;
                                struct iwl_ucode_capabilities *capa,
                                bool *usniffer_images)
 {
-       struct iwl_tlv_ucode_header *ucode = (void *)ucode_raw->data;
+       const struct iwl_tlv_ucode_header *ucode = (const void *)ucode_raw->data;
        const struct iwl_ucode_tlv *tlv;
        size_t len = ucode_raw->size;
        const u8 *data;
 
        while (len >= sizeof(*tlv)) {
                len -= sizeof(*tlv);
-               tlv = (void *)data;
 
+               tlv = (const void *)data;
                tlv_len = le32_to_cpu(tlv->length);
                tlv_type = le32_to_cpu(tlv->type);
                tlv_data = tlv->data;
                        if (tlv_len != sizeof(u32))
                                goto invalid_tlv_len;
                        capa->max_probe_length =
-                                       le32_to_cpup((__le32 *)tlv_data);
+                                       le32_to_cpup((const __le32 *)tlv_data);
                        break;
                case IWL_UCODE_TLV_PAN:
                        if (tlv_len)
                         * will not work with the new firmware, or
                         * it'll not take advantage of new features.
                         */
-                       capa->flags = le32_to_cpup((__le32 *)tlv_data);
+                       capa->flags = le32_to_cpup((const __le32 *)tlv_data);
                        break;
                case IWL_UCODE_TLV_API_CHANGES_SET:
                        if (tlv_len != sizeof(struct iwl_ucode_api))
                        if (tlv_len != sizeof(u32))
                                goto invalid_tlv_len;
                        pieces->init_evtlog_ptr =
-                                       le32_to_cpup((__le32 *)tlv_data);
+                                       le32_to_cpup((const __le32 *)tlv_data);
                        break;
                case IWL_UCODE_TLV_INIT_EVTLOG_SIZE:
                        if (tlv_len != sizeof(u32))
                                goto invalid_tlv_len;
                        pieces->init_evtlog_size =
-                                       le32_to_cpup((__le32 *)tlv_data);
+                                       le32_to_cpup((const __le32 *)tlv_data);
                        break;
                case IWL_UCODE_TLV_INIT_ERRLOG_PTR:
                        if (tlv_len != sizeof(u32))
                                goto invalid_tlv_len;
                        pieces->init_errlog_ptr =
-                                       le32_to_cpup((__le32 *)tlv_data);
+                                       le32_to_cpup((const __le32 *)tlv_data);
                        break;
                case IWL_UCODE_TLV_RUNT_EVTLOG_PTR:
                        if (tlv_len != sizeof(u32))
                                goto invalid_tlv_len;
                        pieces->inst_evtlog_ptr =
-                                       le32_to_cpup((__le32 *)tlv_data);
+                                       le32_to_cpup((const __le32 *)tlv_data);
                        break;
                case IWL_UCODE_TLV_RUNT_EVTLOG_SIZE:
                        if (tlv_len != sizeof(u32))
                                goto invalid_tlv_len;
                        pieces->inst_evtlog_size =
-                                       le32_to_cpup((__le32 *)tlv_data);
+                                       le32_to_cpup((const __le32 *)tlv_data);
                        break;
                case IWL_UCODE_TLV_RUNT_ERRLOG_PTR:
                        if (tlv_len != sizeof(u32))
                                goto invalid_tlv_len;
                        pieces->inst_errlog_ptr =
-                                       le32_to_cpup((__le32 *)tlv_data);
+                                       le32_to_cpup((const __le32 *)tlv_data);
                        break;
                case IWL_UCODE_TLV_ENHANCE_SENS_TBL:
                        if (tlv_len)
                        if (tlv_len != sizeof(u32))
                                goto invalid_tlv_len;
                        capa->standard_phy_calibration_size =
-                                       le32_to_cpup((__le32 *)tlv_data);
+                                       le32_to_cpup((const __le32 *)tlv_data);
                        break;
                case IWL_UCODE_TLV_SEC_RT:
                        iwl_store_ucode_sec(pieces, tlv_data, IWL_UCODE_REGULAR,
                case IWL_UCODE_TLV_PHY_SKU:
                        if (tlv_len != sizeof(u32))
                                goto invalid_tlv_len;
-                       drv->fw.phy_config = le32_to_cpup((__le32 *)tlv_data);
+                       drv->fw.phy_config = le32_to_cpup((const __le32 *)tlv_data);
                        drv->fw.valid_tx_ant = (drv->fw.phy_config &
                                                FW_PHY_CFG_TX_CHAIN) >>
                                                FW_PHY_CFG_TX_CHAIN_POS;
                        if (tlv_len != sizeof(u32))
                                goto invalid_tlv_len;
                        num_of_cpus =
-                               le32_to_cpup((__le32 *)tlv_data);
+                               le32_to_cpup((const __le32 *)tlv_data);
 
                        if (num_of_cpus == 2) {
                                drv->fw.img[IWL_UCODE_REGULAR].is_dual_cpus =
                        if (tlv_len != sizeof(u32))
                                goto invalid_tlv_len;
                        capa->n_scan_channels =
-                               le32_to_cpup((__le32 *)tlv_data);
+                               le32_to_cpup((const __le32 *)tlv_data);
                        break;
                case IWL_UCODE_TLV_FW_VERSION: {
-                       __le32 *ptr = (void *)tlv_data;
+                       const __le32 *ptr = (const void *)tlv_data;
                        u32 major, minor;
                        u8 local_comp;
 
                        break;
                        }
                case IWL_UCODE_TLV_FW_DBG_DEST: {
-                       struct iwl_fw_dbg_dest_tlv *dest = NULL;
-                       struct iwl_fw_dbg_dest_tlv_v1 *dest_v1 = NULL;
+                       const struct iwl_fw_dbg_dest_tlv *dest = NULL;
+                       const struct iwl_fw_dbg_dest_tlv_v1 *dest_v1 = NULL;
                        u8 mon_mode;
 
-                       pieces->dbg_dest_ver = (u8 *)tlv_data;
+                       pieces->dbg_dest_ver = (const u8 *)tlv_data;
                        if (*pieces->dbg_dest_ver == 1) {
-                               dest = (void *)tlv_data;
+                               dest = (const void *)tlv_data;
                        } else if (*pieces->dbg_dest_ver == 0) {
-                               dest_v1 = (void *)tlv_data;
+                               dest_v1 = (const void *)tlv_data;
                        } else {
                                IWL_ERR(drv,
                                        "The version is %d, and it is invalid\n",
                        break;
                        }
                case IWL_UCODE_TLV_FW_DBG_CONF: {
-                       struct iwl_fw_dbg_conf_tlv *conf = (void *)tlv_data;
+                       const struct iwl_fw_dbg_conf_tlv *conf =
+                               (const void *)tlv_data;
 
                        if (!pieces->dbg_dest_tlv_init) {
                                IWL_ERR(drv,
                        break;
                        }
                case IWL_UCODE_TLV_FW_DBG_TRIGGER: {
-                       struct iwl_fw_dbg_trigger_tlv *trigger =
-                               (void *)tlv_data;
+                       const struct iwl_fw_dbg_trigger_tlv *trigger =
+                               (const void *)tlv_data;
                        u32 trigger_id = le32_to_cpu(trigger->id);
 
                        if (trigger_id >= ARRAY_SIZE(drv->fw.dbg.trigger_tlv)) {
                        }
 
                        drv->fw.dbg.dump_mask =
-                               le32_to_cpup((__le32 *)tlv_data);
+                               le32_to_cpup((const __le32 *)tlv_data);
                        break;
                        }
                case IWL_UCODE_TLV_SEC_RT_USNIFFER:
                case IWL_UCODE_TLV_PAGING:
                        if (tlv_len != sizeof(u32))
                                goto invalid_tlv_len;
-                       paging_mem_size = le32_to_cpup((__le32 *)tlv_data);
+                       paging_mem_size = le32_to_cpup((const __le32 *)tlv_data);
 
                        IWL_DEBUG_FW(drv,
                                     "Paging: paging enabled (size = %u bytes)\n",
                        /* ignored */
                        break;
                case IWL_UCODE_TLV_FW_MEM_SEG: {
-                       struct iwl_fw_dbg_mem_seg_tlv *dbg_mem =
-                               (void *)tlv_data;
+                       const struct iwl_fw_dbg_mem_seg_tlv *dbg_mem =
+                               (const void *)tlv_data;
                        size_t size;
                        struct iwl_fw_dbg_mem_seg_tlv *n;
 
                        break;
                        }
                case IWL_UCODE_TLV_FW_RECOVERY_INFO: {
-                       struct {
+                       const struct {
                                __le32 buf_addr;
                                __le32 buf_size;
-                       } *recov_info = (void *)tlv_data;
+                       } *recov_info = (const void *)tlv_data;
 
                        if (tlv_len != sizeof(*recov_info))
                                goto invalid_tlv_len;
                        }
                        break;
                case IWL_UCODE_TLV_FW_FSEQ_VERSION: {
-                       struct {
+                       const struct {
                                u8 version[32];
                                u8 sha1[20];
-                       } *fseq_ver = (void *)tlv_data;
+                       } *fseq_ver = (const void *)tlv_data;
 
                        if (tlv_len != sizeof(*fseq_ver))
                                goto invalid_tlv_len;
                case IWL_UCODE_TLV_FW_NUM_STATIONS:
                        if (tlv_len != sizeof(u32))
                                goto invalid_tlv_len;
-                       if (le32_to_cpup((__le32 *)tlv_data) >
+                       if (le32_to_cpup((const __le32 *)tlv_data) >
                            IWL_MVM_STATION_COUNT_MAX) {
                                IWL_ERR(drv,
                                        "%d is an invalid number of station\n",
-                                       le32_to_cpup((__le32 *)tlv_data));
+                                       le32_to_cpup((const __le32 *)tlv_data));
                                goto tlv_error;
                        }
                        capa->num_stations =
-                               le32_to_cpup((__le32 *)tlv_data);
+                               le32_to_cpup((const __le32 *)tlv_data);
                        break;
                case IWL_UCODE_TLV_UMAC_DEBUG_ADDRS: {
-                       struct iwl_umac_debug_addrs *dbg_ptrs =
-                               (void *)tlv_data;
+                       const struct iwl_umac_debug_addrs *dbg_ptrs =
+                               (const void *)tlv_data;
 
                        if (tlv_len != sizeof(*dbg_ptrs))
                                goto invalid_tlv_len;
                        break;
                        }
                case IWL_UCODE_TLV_LMAC_DEBUG_ADDRS: {
-                       struct iwl_lmac_debug_addrs *dbg_ptrs =
-                               (void *)tlv_data;
+                       const struct iwl_lmac_debug_addrs *dbg_ptrs =
+                               (const void *)tlv_data;
 
                        if (tlv_len != sizeof(*dbg_ptrs))
                                goto invalid_tlv_len;
 {
        struct iwl_drv *drv = context;
        struct iwl_fw *fw = &drv->fw;
-       struct iwl_ucode_header *ucode;
+       const struct iwl_ucode_header *ucode;
        struct iwlwifi_opmode_table *op;
        int err;
        struct iwl_firmware_pieces *pieces;
        }
 
        /* Data from ucode file:  header followed by uCode images */
-       ucode = (struct iwl_ucode_header *)ucode_raw->data;
+       ucode = (const struct iwl_ucode_header *)ucode_raw->data;
 
        if (ucode->ver)
                err = iwl_parse_v1_v2_firmware(drv, ucode_raw, pieces);
 
 
                if (v4)
                        ch_flags =
-                               __le32_to_cpup((__le32 *)nvm_ch_flags + ch_idx);
+                               __le32_to_cpup((const __le32 *)nvm_ch_flags + ch_idx);
                else
                        ch_flags =
-                               __le16_to_cpup((__le16 *)nvm_ch_flags + ch_idx);
+                               __le16_to_cpup((const __le16 *)nvm_ch_flags + ch_idx);
 
                if (band == NL80211_BAND_5GHZ &&
                    !data->sku_cap_band_52ghz_enable)
        if (cfg->nvm_type != IWL_NVM_EXT)
                return le16_to_cpup(nvm_sw + SKU);
 
-       return le32_to_cpup((__le32 *)(phy_sku + SKU_FAMILY_8000));
+       return le32_to_cpup((const __le32 *)(phy_sku + SKU_FAMILY_8000));
 }
 
 static int iwl_get_nvm_version(const struct iwl_cfg *cfg, const __le16 *nvm_sw)
        if (cfg->nvm_type != IWL_NVM_EXT)
                return le16_to_cpup(nvm_sw + NVM_VERSION);
        else
-               return le32_to_cpup((__le32 *)(nvm_sw +
-                                              NVM_VERSION_EXT_NVM));
+               return le32_to_cpup((const __le32 *)(nvm_sw +
+                                                    NVM_VERSION_EXT_NVM));
 }
 
 static int iwl_get_radio_cfg(const struct iwl_cfg *cfg, const __le16 *nvm_sw,
        if (cfg->nvm_type != IWL_NVM_EXT)
                return le16_to_cpup(nvm_sw + RADIO_CFG);
 
-       return le32_to_cpup((__le32 *)(phy_sku + RADIO_CFG_FAMILY_EXT_NVM));
+       return le32_to_cpup((const __le32 *)(phy_sku + RADIO_CFG_FAMILY_EXT_NVM));
 
 }
 
        if (cfg->nvm_type != IWL_NVM_EXT)
                return le16_to_cpup(nvm_sw + N_HW_ADDRS);
 
-       n_hw_addr = le32_to_cpup((__le32 *)(nvm_sw + N_HW_ADDRS_FAMILY_8000));
+       n_hw_addr = le32_to_cpup((const __le32 *)(nvm_sw + N_HW_ADDRS_FAMILY_8000));
 
        return n_hw_addr & N_HW_ADDR_MASK;
 }
        }
 
        eof = fw_entry->data + fw_entry->size;
-       dword_buff = (__le32 *)fw_entry->data;
+       dword_buff = (const __le32 *)fw_entry->data;
 
        /* some NVM file will contain a header.
         * The header is identified by 2 dwords header as follow:
        if (fw_entry->size > NVM_HEADER_SIZE &&
            dword_buff[0] == cpu_to_le32(NVM_HEADER_0) &&
            dword_buff[1] == cpu_to_le32(NVM_HEADER_1)) {
-               file_sec = (void *)(fw_entry->data + NVM_HEADER_SIZE);
+               file_sec = (const void *)(fw_entry->data + NVM_HEADER_SIZE);
                IWL_INFO(trans, "NVM Version %08X\n", le32_to_cpu(dword_buff[2]));
                IWL_INFO(trans, "NVM Manufacturing date %08X\n",
                         le32_to_cpu(dword_buff[3]));
                        goto out;
                }
        } else {
-               file_sec = (void *)fw_entry->data;
+               file_sec = (const void *)fw_entry->data;
        }
 
        while (true) {
                nvm_sections[section_id].length = section_size;
 
                /* advance to the next section */
-               file_sec = (void *)(file_sec->data + section_size);
+               file_sec = (const void *)(file_sec->data + section_size);
        }
 out:
        release_firmware(fw_entry);