static inline unsigned int
 ath10k_set_ring_byte(unsigned int offset,
-                    struct ath10k_hw_ce_regs_addr_map *addr_map)
+                    const struct ath10k_hw_ce_regs_addr_map *addr_map)
 {
        return ((offset << addr_map->lsb) & addr_map->mask);
 }
                                               u32 ce_ctrl_addr,
                                               unsigned int n)
 {
-       struct ath10k_hw_ce_ctrl1 *ctrl_regs = ar->hw_ce_regs->ctrl1_regs;
+       const struct ath10k_hw_ce_ctrl1 *ctrl_regs = ar->hw_ce_regs->ctrl1_regs;
 
        u32 ctrl1_addr = ath10k_ce_read32(ar, ce_ctrl_addr +
                                          ctrl_regs->addr);
                                                    u32 ce_ctrl_addr,
                                                    unsigned int n)
 {
-       struct ath10k_hw_ce_ctrl1 *ctrl_regs = ar->hw_ce_regs->ctrl1_regs;
+       const struct ath10k_hw_ce_ctrl1 *ctrl_regs = ar->hw_ce_regs->ctrl1_regs;
 
        u32 ctrl1_addr = ath10k_ce_read32(ar, ce_ctrl_addr +
                                          ctrl_regs->addr);
                                                     u32 ce_ctrl_addr,
                                                     unsigned int n)
 {
-       struct ath10k_hw_ce_ctrl1 *ctrl_regs = ar->hw_ce_regs->ctrl1_regs;
+       const struct ath10k_hw_ce_ctrl1 *ctrl_regs = ar->hw_ce_regs->ctrl1_regs;
 
        u32 ctrl1_addr = ath10k_ce_read32(ar, ce_ctrl_addr +
                                          ctrl_regs->addr);
                                                   u32 ce_ctrl_addr,
                                                   unsigned int n)
 {
-       struct ath10k_hw_ce_dst_src_wm_regs *srcr_wm = ar->hw_ce_regs->wm_srcr;
+       const struct ath10k_hw_ce_dst_src_wm_regs *srcr_wm = ar->hw_ce_regs->wm_srcr;
        u32 addr = ath10k_ce_read32(ar, ce_ctrl_addr + srcr_wm->addr);
 
        ath10k_ce_write32(ar, ce_ctrl_addr + srcr_wm->addr,
                                                  u32 ce_ctrl_addr,
                                                  unsigned int n)
 {
-       struct ath10k_hw_ce_dst_src_wm_regs *srcr_wm = ar->hw_ce_regs->wm_srcr;
+       const struct ath10k_hw_ce_dst_src_wm_regs *srcr_wm = ar->hw_ce_regs->wm_srcr;
        u32 addr = ath10k_ce_read32(ar, ce_ctrl_addr + srcr_wm->addr);
 
        ath10k_ce_write32(ar, ce_ctrl_addr + srcr_wm->addr,
                                                    u32 ce_ctrl_addr,
                                                    unsigned int n)
 {
-       struct ath10k_hw_ce_dst_src_wm_regs *dstr_wm = ar->hw_ce_regs->wm_dstr;
+       const struct ath10k_hw_ce_dst_src_wm_regs *dstr_wm = ar->hw_ce_regs->wm_dstr;
        u32 addr = ath10k_ce_read32(ar, ce_ctrl_addr + dstr_wm->addr);
 
        ath10k_ce_write32(ar, ce_ctrl_addr + dstr_wm->addr,
                                                   u32 ce_ctrl_addr,
                                                   unsigned int n)
 {
-       struct ath10k_hw_ce_dst_src_wm_regs *dstr_wm = ar->hw_ce_regs->wm_dstr;
+       const struct ath10k_hw_ce_dst_src_wm_regs *dstr_wm = ar->hw_ce_regs->wm_dstr;
        u32 addr = ath10k_ce_read32(ar, ce_ctrl_addr + dstr_wm->addr);
 
        ath10k_ce_write32(ar, ce_ctrl_addr + dstr_wm->addr,
 static inline void ath10k_ce_copy_complete_inter_enable(struct ath10k *ar,
                                                        u32 ce_ctrl_addr)
 {
-       struct ath10k_hw_ce_host_ie *host_ie = ar->hw_ce_regs->host_ie;
+       const struct ath10k_hw_ce_host_ie *host_ie = ar->hw_ce_regs->host_ie;
 
        u32 host_ie_addr = ath10k_ce_read32(ar, ce_ctrl_addr +
                                            ar->hw_ce_regs->host_ie_addr);
 static inline void ath10k_ce_copy_complete_intr_disable(struct ath10k *ar,
                                                        u32 ce_ctrl_addr)
 {
-       struct ath10k_hw_ce_host_ie *host_ie = ar->hw_ce_regs->host_ie;
+       const struct ath10k_hw_ce_host_ie *host_ie = ar->hw_ce_regs->host_ie;
 
        u32 host_ie_addr = ath10k_ce_read32(ar, ce_ctrl_addr +
                                            ar->hw_ce_regs->host_ie_addr);
 static inline void ath10k_ce_watermark_intr_disable(struct ath10k *ar,
                                                    u32 ce_ctrl_addr)
 {
-       struct ath10k_hw_ce_host_wm_regs *wm_regs = ar->hw_ce_regs->wm_regs;
+       const struct ath10k_hw_ce_host_wm_regs *wm_regs = ar->hw_ce_regs->wm_regs;
 
        u32 host_ie_addr = ath10k_ce_read32(ar, ce_ctrl_addr +
                                            ar->hw_ce_regs->host_ie_addr);
 static inline void ath10k_ce_error_intr_disable(struct ath10k *ar,
                                                u32 ce_ctrl_addr)
 {
-       struct ath10k_hw_ce_misc_regs *misc_regs = ar->hw_ce_regs->misc_regs;
+       const struct ath10k_hw_ce_misc_regs *misc_regs = ar->hw_ce_regs->misc_regs;
 
        u32 misc_ie_addr = ath10k_ce_read32(ar,
                        ce_ctrl_addr + ar->hw_ce_regs->misc_ie_addr);
                                                     u32 ce_ctrl_addr,
                                                     unsigned int mask)
 {
-       struct ath10k_hw_ce_host_wm_regs *wm_regs = ar->hw_ce_regs->wm_regs;
+       const struct ath10k_hw_ce_host_wm_regs *wm_regs = ar->hw_ce_regs->wm_regs;
 
        ath10k_ce_write32(ar, ce_ctrl_addr + wm_regs->addr, mask);
 }
 {
        struct ath10k_ce *ce = ath10k_ce_priv(ar);
        struct ath10k_ce_pipe *ce_state = &ce->ce_states[ce_id];
-       struct ath10k_hw_ce_host_wm_regs *wm_regs = ar->hw_ce_regs->wm_regs;
+       const struct ath10k_hw_ce_host_wm_regs *wm_regs = ar->hw_ce_regs->wm_regs;
        u32 ctrl_addr = ce_state->ctrl_addr;
 
        /*
 
        .pcie_intr_fw_mask                      = 0x00100000,
 };
 
-static struct ath10k_hw_ce_regs_addr_map wcn3990_src_ring = {
+static const struct ath10k_hw_ce_regs_addr_map wcn3990_src_ring = {
        .msb    = 0x00000010,
        .lsb    = 0x00000010,
        .mask   = GENMASK(17, 17),
 };
 
-static struct ath10k_hw_ce_regs_addr_map wcn3990_dst_ring = {
+static const struct ath10k_hw_ce_regs_addr_map wcn3990_dst_ring = {
        .msb    = 0x00000012,
        .lsb    = 0x00000012,
        .mask   = GENMASK(18, 18),
 };
 
-static struct ath10k_hw_ce_regs_addr_map wcn3990_dmax = {
+static const struct ath10k_hw_ce_regs_addr_map wcn3990_dmax = {
        .msb    = 0x00000000,
        .lsb    = 0x00000000,
        .mask   = GENMASK(15, 0),
 };
 
-static struct ath10k_hw_ce_ctrl1 wcn3990_ctrl1 = {
+static const struct ath10k_hw_ce_ctrl1 wcn3990_ctrl1 = {
        .addr           = 0x00000018,
        .src_ring       = &wcn3990_src_ring,
        .dst_ring       = &wcn3990_dst_ring,
        .dmax           = &wcn3990_dmax,
 };
 
-static struct ath10k_hw_ce_regs_addr_map wcn3990_host_ie_cc = {
+static const struct ath10k_hw_ce_regs_addr_map wcn3990_host_ie_cc = {
        .mask   = GENMASK(0, 0),
 };
 
-static struct ath10k_hw_ce_host_ie wcn3990_host_ie = {
+static const struct ath10k_hw_ce_host_ie wcn3990_host_ie = {
        .copy_complete  = &wcn3990_host_ie_cc,
 };
 
-static struct ath10k_hw_ce_host_wm_regs wcn3990_wm_reg = {
+static const struct ath10k_hw_ce_host_wm_regs wcn3990_wm_reg = {
        .dstr_lmask     = 0x00000010,
        .dstr_hmask     = 0x00000008,
        .srcr_lmask     = 0x00000004,
        .addr           = 0x00000030,
 };
 
-static struct ath10k_hw_ce_misc_regs wcn3990_misc_reg = {
+static const struct ath10k_hw_ce_misc_regs wcn3990_misc_reg = {
        .axi_err        = 0x00000100,
        .dstr_add_err   = 0x00000200,
        .srcr_len_err   = 0x00000100,
        .addr           = 0x00000038,
 };
 
-static struct ath10k_hw_ce_regs_addr_map wcn3990_src_wm_low = {
+static const struct ath10k_hw_ce_regs_addr_map wcn3990_src_wm_low = {
        .msb    = 0x00000000,
        .lsb    = 0x00000010,
        .mask   = GENMASK(31, 16),
 };
 
-static struct ath10k_hw_ce_regs_addr_map wcn3990_src_wm_high = {
+static const struct ath10k_hw_ce_regs_addr_map wcn3990_src_wm_high = {
        .msb    = 0x0000000f,
        .lsb    = 0x00000000,
        .mask   = GENMASK(15, 0),
 };
 
-static struct ath10k_hw_ce_dst_src_wm_regs wcn3990_wm_src_ring = {
+static const struct ath10k_hw_ce_dst_src_wm_regs wcn3990_wm_src_ring = {
        .addr           = 0x0000004c,
        .low_rst        = 0x00000000,
        .high_rst       = 0x00000000,
        .wm_high        = &wcn3990_src_wm_high,
 };
 
-static struct ath10k_hw_ce_regs_addr_map wcn3990_dst_wm_low = {
+static const struct ath10k_hw_ce_regs_addr_map wcn3990_dst_wm_low = {
        .lsb    = 0x00000010,
        .mask   = GENMASK(31, 16),
 };
 
-static struct ath10k_hw_ce_regs_addr_map wcn3990_dst_wm_high = {
+static const struct ath10k_hw_ce_regs_addr_map wcn3990_dst_wm_high = {
        .msb    = 0x0000000f,
        .lsb    = 0x00000000,
        .mask   = GENMASK(15, 0),
 };
 
-static struct ath10k_hw_ce_dst_src_wm_regs wcn3990_wm_dst_ring = {
+static const struct ath10k_hw_ce_dst_src_wm_regs wcn3990_wm_dst_ring = {
        .addr           = 0x00000050,
        .low_rst        = 0x00000000,
        .high_rst       = 0x00000000,
        .wm_high        = &wcn3990_dst_wm_high,
 };
 
-static struct ath10k_hw_ce_ctrl1_upd wcn3990_ctrl1_upd = {
+static const struct ath10k_hw_ce_ctrl1_upd wcn3990_ctrl1_upd = {
        .shift = 19,
        .mask = 0x00080000,
        .enable = 0x00000000,
        .ce_desc_meta_data_lsb          = 4,
 };
 
-static struct ath10k_hw_ce_regs_addr_map qcax_src_ring = {
+static const struct ath10k_hw_ce_regs_addr_map qcax_src_ring = {
        .msb    = 0x00000010,
        .lsb    = 0x00000010,
        .mask   = GENMASK(16, 16),
 };
 
-static struct ath10k_hw_ce_regs_addr_map qcax_dst_ring = {
+static const struct ath10k_hw_ce_regs_addr_map qcax_dst_ring = {
        .msb    = 0x00000011,
        .lsb    = 0x00000011,
        .mask   = GENMASK(17, 17),
 };
 
-static struct ath10k_hw_ce_regs_addr_map qcax_dmax = {
+static const struct ath10k_hw_ce_regs_addr_map qcax_dmax = {
        .msb    = 0x0000000f,
        .lsb    = 0x00000000,
        .mask   = GENMASK(15, 0),
 };
 
-static struct ath10k_hw_ce_ctrl1 qcax_ctrl1 = {
+static const struct ath10k_hw_ce_ctrl1 qcax_ctrl1 = {
        .addr           = 0x00000010,
        .hw_mask        = 0x0007ffff,
        .sw_mask        = 0x0007ffff,
        .dmax           = &qcax_dmax,
 };
 
-static struct ath10k_hw_ce_regs_addr_map qcax_cmd_halt_status = {
+static const struct ath10k_hw_ce_regs_addr_map qcax_cmd_halt_status = {
        .msb    = 0x00000003,
        .lsb    = 0x00000003,
        .mask   = GENMASK(3, 3),
 };
 
-static struct ath10k_hw_ce_cmd_halt qcax_cmd_halt = {
+static const struct ath10k_hw_ce_cmd_halt qcax_cmd_halt = {
        .msb            = 0x00000000,
        .mask           = GENMASK(0, 0),
        .status_reset   = 0x00000000,
        .status         = &qcax_cmd_halt_status,
 };
 
-static struct ath10k_hw_ce_regs_addr_map qcax_host_ie_cc = {
+static const struct ath10k_hw_ce_regs_addr_map qcax_host_ie_cc = {
        .msb    = 0x00000000,
        .lsb    = 0x00000000,
        .mask   = GENMASK(0, 0),
 };
 
-static struct ath10k_hw_ce_host_ie qcax_host_ie = {
+static const struct ath10k_hw_ce_host_ie qcax_host_ie = {
        .copy_complete_reset    = 0x00000000,
        .copy_complete          = &qcax_host_ie_cc,
 };
 
-static struct ath10k_hw_ce_host_wm_regs qcax_wm_reg = {
+static const struct ath10k_hw_ce_host_wm_regs qcax_wm_reg = {
        .dstr_lmask     = 0x00000010,
        .dstr_hmask     = 0x00000008,
        .srcr_lmask     = 0x00000004,
        .addr           = 0x00000030,
 };
 
-static struct ath10k_hw_ce_misc_regs qcax_misc_reg = {
+static const struct ath10k_hw_ce_misc_regs qcax_misc_reg = {
        .axi_err        = 0x00000400,
        .dstr_add_err   = 0x00000200,
        .srcr_len_err   = 0x00000100,
        .addr           = 0x00000038,
 };
 
-static struct ath10k_hw_ce_regs_addr_map qcax_src_wm_low = {
+static const struct ath10k_hw_ce_regs_addr_map qcax_src_wm_low = {
        .msb    = 0x0000001f,
        .lsb    = 0x00000010,
        .mask   = GENMASK(31, 16),
 };
 
-static struct ath10k_hw_ce_regs_addr_map qcax_src_wm_high = {
+static const struct ath10k_hw_ce_regs_addr_map qcax_src_wm_high = {
        .msb    = 0x0000000f,
        .lsb    = 0x00000000,
        .mask   = GENMASK(15, 0),
 };
 
-static struct ath10k_hw_ce_dst_src_wm_regs qcax_wm_src_ring = {
+static const struct ath10k_hw_ce_dst_src_wm_regs qcax_wm_src_ring = {
        .addr           = 0x0000004c,
        .low_rst        = 0x00000000,
        .high_rst       = 0x00000000,
        .wm_high        = &qcax_src_wm_high,
 };
 
-static struct ath10k_hw_ce_regs_addr_map qcax_dst_wm_low = {
+static const struct ath10k_hw_ce_regs_addr_map qcax_dst_wm_low = {
        .lsb    = 0x00000010,
        .mask   = GENMASK(31, 16),
 };
 
-static struct ath10k_hw_ce_regs_addr_map qcax_dst_wm_high = {
+static const struct ath10k_hw_ce_regs_addr_map qcax_dst_wm_high = {
        .msb    = 0x0000000f,
        .lsb    = 0x00000000,
        .mask   = GENMASK(15, 0),
 };
 
-static struct ath10k_hw_ce_dst_src_wm_regs qcax_wm_dst_ring = {
+static const struct ath10k_hw_ce_dst_src_wm_regs qcax_wm_dst_ring = {
        .addr           = 0x00000050,
        .low_rst        = 0x00000000,
        .high_rst       = 0x00000000,
 
        u32 sw_wr_mask;
        u32 reset_mask;
        u32 reset;
-       struct ath10k_hw_ce_regs_addr_map *src_ring;
-       struct ath10k_hw_ce_regs_addr_map *dst_ring;
-       struct ath10k_hw_ce_regs_addr_map *dmax; };
+       const struct ath10k_hw_ce_regs_addr_map *src_ring;
+       const struct ath10k_hw_ce_regs_addr_map *dst_ring;
+       const struct ath10k_hw_ce_regs_addr_map *dmax;
+};
 
 struct ath10k_hw_ce_cmd_halt {
        u32 status_reset;
        u32 msb;
        u32 mask;
-       struct ath10k_hw_ce_regs_addr_map *status; };
+       const struct ath10k_hw_ce_regs_addr_map *status;
+};
 
 struct ath10k_hw_ce_host_ie {
        u32 copy_complete_reset;
-       struct ath10k_hw_ce_regs_addr_map *copy_complete; };
+       const struct ath10k_hw_ce_regs_addr_map *copy_complete;
+};
 
 struct ath10k_hw_ce_host_wm_regs {
        u32 dstr_lmask;
        u32 addr;
        u32 low_rst;
        u32 high_rst;
-       struct ath10k_hw_ce_regs_addr_map *wm_low;
-       struct ath10k_hw_ce_regs_addr_map *wm_high; };
+       const struct ath10k_hw_ce_regs_addr_map *wm_low;
+       const struct ath10k_hw_ce_regs_addr_map *wm_high;
+};
 
 struct ath10k_hw_ce_ctrl1_upd {
        u32 shift;
        u32 ce_rri_low;
        u32 ce_rri_high;
        u32 host_ie_addr;
-       struct ath10k_hw_ce_host_wm_regs *wm_regs;
-       struct ath10k_hw_ce_misc_regs *misc_regs;
-       struct ath10k_hw_ce_ctrl1 *ctrl1_regs;
-       struct ath10k_hw_ce_cmd_halt *cmd_halt;
-       struct ath10k_hw_ce_host_ie *host_ie;
-       struct ath10k_hw_ce_dst_src_wm_regs *wm_srcr;
-       struct ath10k_hw_ce_dst_src_wm_regs *wm_dstr;
-       struct ath10k_hw_ce_ctrl1_upd *upd;
+       const struct ath10k_hw_ce_host_wm_regs *wm_regs;
+       const struct ath10k_hw_ce_misc_regs *misc_regs;
+       const struct ath10k_hw_ce_ctrl1 *ctrl1_regs;
+       const struct ath10k_hw_ce_cmd_halt *cmd_halt;
+       const struct ath10k_hw_ce_host_ie *host_ie;
+       const struct ath10k_hw_ce_dst_src_wm_regs *wm_srcr;
+       const struct ath10k_hw_ce_dst_src_wm_regs *wm_dstr;
+       const struct ath10k_hw_ce_ctrl1_upd *upd;
 };
 
 struct ath10k_hw_values {