u32 i;
        u32 ptr;        /* SRAM byte address of log data */
        u32 ev, time, data; /* event log data */
-       unsigned long reg_flags;
 
        if (mode == 0)
                ptr = base + (4 * sizeof(u32)) + (start_idx * 2 * sizeof(u32));
                ptr = base + (4 * sizeof(u32)) + (start_idx * 3 * sizeof(u32));
 
        /* Make sure device is powered up for SRAM reads */
-       if (!iwl_trans_grab_nic_access(priv->trans, ®_flags))
+       if (!iwl_trans_grab_nic_access(priv->trans))
                return;
 
        /* Set starting address; reads will auto-increment */
                }
        }
        /* Allow device to power down */
-       iwl_trans_release_nic_access(priv->trans, ®_flags);
+       iwl_trans_release_nic_access(priv->trans);
 }
 
 static void iwl_continuous_event_trace(struct iwl_priv *priv)
        u32 event_size; /* 2 u32s, or 3 u32s if timestamp recorded */
        u32 ptr;        /* SRAM byte address of log data */
        u32 ev, time, data; /* event log data */
-       unsigned long reg_flags;
 
        struct iwl_trans *trans = priv->trans;
 
        ptr = base + EVENT_START_OFFSET + (start_idx * event_size);
 
        /* Make sure device is powered up for SRAM reads */
-       if (!iwl_trans_grab_nic_access(trans, ®_flags))
+       if (!iwl_trans_grab_nic_access(trans))
                return pos;
 
        /* Set starting address; reads will auto-increment */
        }
 
        /* Allow device to power down */
-       iwl_trans_release_nic_access(trans, ®_flags);
+       iwl_trans_release_nic_access(trans);
        return pos;
 }
 
 
 /******************************************************************************
  *
  * Copyright(c) 2007 - 2014 Intel Corporation. All rights reserved.
- * Copyright (C) 2018 Intel Corporation
+ * Copyright (C) 2018, 2020 Intel Corporation
  *
  * Portions of this file are derived from the ipw3945 project, as well
  * as portions of the ieee80211 subsystem header files.
        struct iwl_priv *priv = from_timer(priv, t,
                                           thermal_throttle.ct_kill_exit_tm);
        struct iwl_tt_mgmt *tt = &priv->thermal_throttle;
-       unsigned long flags;
 
        if (test_bit(STATUS_EXIT_PENDING, &priv->status))
                return;
                        priv->thermal_throttle.ct_kill_toggle = true;
                }
                iwl_read32(priv->trans, CSR_UCODE_DRV_GP1);
-               if (iwl_trans_grab_nic_access(priv->trans, &flags))
-                       iwl_trans_release_nic_access(priv->trans, &flags);
+               if (iwl_trans_grab_nic_access(priv->trans))
+                       iwl_trans_release_nic_access(priv->trans);
 
                /* Reschedule the ct_kill timer to occur in
                 * CT_KILL_EXIT_DURATION seconds to ensure we get a
 
                                struct iwl_fw_error_dump_data **dump_data)
 {
        u8 *pos = (void *)(*dump_data)->data;
-       unsigned long flags;
        int i;
 
        IWL_DEBUG_INFO(fwrt, "WRT radio registers dump\n");
 
-       if (!iwl_trans_grab_nic_access(fwrt->trans, &flags))
+       if (!iwl_trans_grab_nic_access(fwrt->trans))
                return;
 
        (*dump_data)->type = cpu_to_le32(IWL_FW_ERROR_DUMP_RADIO_REG);
 
        *dump_data = iwl_fw_error_next_data(*dump_data);
 
-       iwl_trans_release_nic_access(fwrt->trans, &flags);
+       iwl_trans_release_nic_access(fwrt->trans);
 }
 
 static void iwl_fwrt_dump_rxf(struct iwl_fw_runtime *fwrt,
                            struct iwl_fw_error_dump_data **dump_data)
 {
        struct iwl_fwrt_shared_mem_cfg *cfg = &fwrt->smem_cfg;
-       unsigned long flags;
 
        IWL_DEBUG_INFO(fwrt, "WRT RX FIFO dump\n");
 
-       if (!iwl_trans_grab_nic_access(fwrt->trans, &flags))
+       if (!iwl_trans_grab_nic_access(fwrt->trans))
                return;
 
        if (iwl_fw_dbg_type_on(fwrt, IWL_FW_ERROR_DUMP_RXF)) {
                                          LMAC2_PRPH_OFFSET, 2);
        }
 
-       iwl_trans_release_nic_access(fwrt->trans, &flags);
+       iwl_trans_release_nic_access(fwrt->trans);
 }
 
 static void iwl_fw_dump_txf(struct iwl_fw_runtime *fwrt,
        struct iwl_fwrt_shared_mem_cfg *cfg = &fwrt->smem_cfg;
        u32 *fifo_data;
        u32 fifo_len;
-       unsigned long flags;
        int i, j;
 
        IWL_DEBUG_INFO(fwrt, "WRT TX FIFO dump\n");
 
-       if (!iwl_trans_grab_nic_access(fwrt->trans, &flags))
+       if (!iwl_trans_grab_nic_access(fwrt->trans))
                return;
 
        if (iwl_fw_dbg_type_on(fwrt, IWL_FW_ERROR_DUMP_TXF)) {
                }
        }
 
-       iwl_trans_release_nic_access(fwrt->trans, &flags);
+       iwl_trans_release_nic_access(fwrt->trans);
 }
 
 #define IWL8260_ICCM_OFFSET            0x44000 /* Only for B-step */
        struct iwl_trans *trans = fwrt->trans;
        struct iwl_fw_error_dump_data **data =
                (struct iwl_fw_error_dump_data **)ptr;
-       unsigned long flags;
        u32 i;
 
        if (!data)
 
        IWL_DEBUG_INFO(trans, "WRT PRPH dump\n");
 
-       if (!iwl_trans_grab_nic_access(trans, &flags))
+       if (!iwl_trans_grab_nic_access(trans))
                return;
 
        for (i = 0; i < range_len; i++) {
                *data = iwl_fw_error_next_data(*data);
        }
 
-       iwl_trans_release_nic_access(trans, &flags);
+       iwl_trans_release_nic_access(trans);
 }
 
 /*
        u32 addr = le32_to_cpu(reg->addrs[idx]);
        u32 dphy_state;
        u32 dphy_addr;
-       unsigned long flags;
        int i;
 
        range->internal_base_addr = cpu_to_le32(addr);
        indirect_wr_addr += le32_to_cpu(reg->dev_addr.offset);
        indirect_rd_addr += le32_to_cpu(reg->dev_addr.offset);
 
-       if (!iwl_trans_grab_nic_access(fwrt->trans, &flags))
+       if (!iwl_trans_grab_nic_access(fwrt->trans))
                return -EBUSY;
 
        dphy_addr = (reg->dev_addr.offset) ? WFPM_LMAC2_PS_CTL_RW :
                *val++ = cpu_to_le32(prph_val);
        }
 
-       iwl_trans_release_nic_access(fwrt->trans, &flags);
+       iwl_trans_release_nic_access(fwrt->trans);
        return sizeof(*range) + le32_to_cpu(range->range_data_size);
 }
 
        u32 registers_num = iwl_tlv_array_len(reg_data->reg_tlv, reg, addrs);
        u32 registers_size = registers_num * sizeof(*reg_dump);
        __le32 *data;
-       unsigned long flags;
        int i;
 
        if (!iwl_ini_txf_iter(fwrt, reg_data, idx))
                return -EIO;
 
-       if (!iwl_trans_grab_nic_access(fwrt->trans, &flags))
+       if (!iwl_trans_grab_nic_access(fwrt->trans))
                return -EBUSY;
 
        range->fifo_hdr.fifo_num = cpu_to_le32(iter->fifo);
                *data++ = cpu_to_le32(iwl_read_prph_no_grab(fwrt->trans, addr));
 
 out:
-       iwl_trans_release_nic_access(fwrt->trans, &flags);
+       iwl_trans_release_nic_access(fwrt->trans);
 
        return sizeof(*range) + le32_to_cpu(range->range_data_size);
 }
        u32 registers_num = iwl_tlv_array_len(reg_data->reg_tlv, reg, addrs);
        u32 registers_size = registers_num * sizeof(*reg_dump);
        __le32 *data;
-       unsigned long flags;
        int i;
 
        iwl_ini_get_rxf_data(fwrt, reg_data, &rxf_data);
        if (!rxf_data.size)
                return -EIO;
 
-       if (!iwl_trans_grab_nic_access(fwrt->trans, &flags))
+       if (!iwl_trans_grab_nic_access(fwrt->trans))
                return -EBUSY;
 
        range->fifo_hdr.fifo_num = cpu_to_le32(rxf_data.fifo_num);
                *data++ = cpu_to_le32(iwl_read_prph_no_grab(fwrt->trans, addr));
 
 out:
-       iwl_trans_release_nic_access(fwrt->trans, &flags);
+       iwl_trans_release_nic_access(fwrt->trans);
 
        return sizeof(*range) + le32_to_cpu(range->range_data_size);
 }
 {
        struct iwl_fw_ini_region_tlv *reg = (void *)reg_data->reg_tlv->data;
        u32 alloc_id = le32_to_cpu(reg->dram_alloc_id);
-       unsigned long flags;
 
-       if (!iwl_trans_grab_nic_access(fwrt->trans, &flags)) {
+       if (!iwl_trans_grab_nic_access(fwrt->trans)) {
                IWL_ERR(fwrt, "Failed to get monitor header\n");
                return NULL;
        }
        data->cur_frag = iwl_get_mon_reg(fwrt, alloc_id,
                                         &addrs->cur_frag);
 
-       iwl_trans_release_nic_access(fwrt->trans, &flags);
+       iwl_trans_release_nic_access(fwrt->trans);
 
        data->header.version = cpu_to_le32(IWL_INI_DUMP_VER);
 
 void iwl_fw_error_print_fseq_regs(struct iwl_fw_runtime *fwrt)
 {
        struct iwl_trans *trans = fwrt->trans;
-       unsigned long flags;
        int i;
        struct {
                u32 addr;
                FSEQ_REG(CNVR_SCU_SD_REGS_SD_REG_ACTIVE_VDIG_MIRROR),
        };
 
-       if (!iwl_trans_grab_nic_access(trans, &flags))
+       if (!iwl_trans_grab_nic_access(trans))
                return;
 
        IWL_ERR(fwrt, "Fseq Registers:\n");
                        iwl_read_prph_no_grab(trans, fseq_regs[i].addr),
                        fseq_regs[i].str);
 
-       iwl_trans_release_nic_access(trans, &flags);
+       iwl_trans_release_nic_access(trans);
 }
 IWL_EXPORT_SYMBOL(iwl_fw_error_print_fseq_regs);
 
 
 u32 iwl_read_direct32(struct iwl_trans *trans, u32 reg)
 {
        u32 value = 0x5a5a5a5a;
-       unsigned long flags;
-       if (iwl_trans_grab_nic_access(trans, &flags)) {
+
+       if (iwl_trans_grab_nic_access(trans)) {
                value = iwl_read32(trans, reg);
-               iwl_trans_release_nic_access(trans, &flags);
+               iwl_trans_release_nic_access(trans);
        }
 
        return value;
 
 void iwl_write_direct32(struct iwl_trans *trans, u32 reg, u32 value)
 {
-       unsigned long flags;
-
-       if (iwl_trans_grab_nic_access(trans, &flags)) {
+       if (iwl_trans_grab_nic_access(trans)) {
                iwl_write32(trans, reg, value);
-               iwl_trans_release_nic_access(trans, &flags);
+               iwl_trans_release_nic_access(trans);
        }
 }
 IWL_EXPORT_SYMBOL(iwl_write_direct32);
 
 void iwl_write_direct64(struct iwl_trans *trans, u64 reg, u64 value)
 {
-       unsigned long flags;
-
-       if (iwl_trans_grab_nic_access(trans, &flags)) {
+       if (iwl_trans_grab_nic_access(trans)) {
                iwl_write64(trans, reg, value);
-               iwl_trans_release_nic_access(trans, &flags);
+               iwl_trans_release_nic_access(trans);
        }
 }
 IWL_EXPORT_SYMBOL(iwl_write_direct64);
 
 u32 iwl_read_prph(struct iwl_trans *trans, u32 ofs)
 {
-       unsigned long flags;
        u32 val = 0x5a5a5a5a;
 
-       if (iwl_trans_grab_nic_access(trans, &flags)) {
+       if (iwl_trans_grab_nic_access(trans)) {
                val = iwl_read_prph_no_grab(trans, ofs);
-               iwl_trans_release_nic_access(trans, &flags);
+               iwl_trans_release_nic_access(trans);
        }
        return val;
 }
 
 void iwl_write_prph_delay(struct iwl_trans *trans, u32 ofs, u32 val, u32 delay_ms)
 {
-       unsigned long flags;
-
-       if (iwl_trans_grab_nic_access(trans, &flags)) {
+       if (iwl_trans_grab_nic_access(trans)) {
                mdelay(delay_ms);
                iwl_write_prph_no_grab(trans, ofs, val);
-               iwl_trans_release_nic_access(trans, &flags);
+               iwl_trans_release_nic_access(trans);
        }
 }
 IWL_EXPORT_SYMBOL(iwl_write_prph_delay);
 
 void iwl_set_bits_prph(struct iwl_trans *trans, u32 ofs, u32 mask)
 {
-       unsigned long flags;
-
-       if (iwl_trans_grab_nic_access(trans, &flags)) {
+       if (iwl_trans_grab_nic_access(trans)) {
                iwl_write_prph_no_grab(trans, ofs,
                                       iwl_read_prph_no_grab(trans, ofs) |
                                       mask);
-               iwl_trans_release_nic_access(trans, &flags);
+               iwl_trans_release_nic_access(trans);
        }
 }
 IWL_EXPORT_SYMBOL(iwl_set_bits_prph);
 void iwl_set_bits_mask_prph(struct iwl_trans *trans, u32 ofs,
                            u32 bits, u32 mask)
 {
-       unsigned long flags;
-
-       if (iwl_trans_grab_nic_access(trans, &flags)) {
+       if (iwl_trans_grab_nic_access(trans)) {
                iwl_write_prph_no_grab(trans, ofs,
                                       (iwl_read_prph_no_grab(trans, ofs) &
                                        mask) | bits);
-               iwl_trans_release_nic_access(trans, &flags);
+               iwl_trans_release_nic_access(trans);
        }
 }
 IWL_EXPORT_SYMBOL(iwl_set_bits_mask_prph);
 
 void iwl_clear_bits_prph(struct iwl_trans *trans, u32 ofs, u32 mask)
 {
-       unsigned long flags;
        u32 val;
 
-       if (iwl_trans_grab_nic_access(trans, &flags)) {
+       if (iwl_trans_grab_nic_access(trans)) {
                val = iwl_read_prph_no_grab(trans, ofs);
                iwl_write_prph_no_grab(trans, ofs, (val & ~mask));
-               iwl_trans_release_nic_access(trans, &flags);
+               iwl_trans_release_nic_access(trans);
        }
 }
 IWL_EXPORT_SYMBOL(iwl_clear_bits_prph);
 
                          const struct iwl_trans_config *trans_cfg);
        void (*set_pmi)(struct iwl_trans *trans, bool state);
        void (*sw_reset)(struct iwl_trans *trans);
-       bool (*grab_nic_access)(struct iwl_trans *trans, unsigned long *flags);
-       void (*release_nic_access)(struct iwl_trans *trans,
-                                  unsigned long *flags);
+       bool (*grab_nic_access)(struct iwl_trans *trans);
+       void (*release_nic_access)(struct iwl_trans *trans);
        void (*set_bits_mask)(struct iwl_trans *trans, u32 reg, u32 mask,
                              u32 value);
 
        trans->ops->set_bits_mask(trans, reg, mask, value);
 }
 
-#define iwl_trans_grab_nic_access(trans, flags)        \
+#define iwl_trans_grab_nic_access(trans)               \
        __cond_lock(nic_access,                         \
-                   likely((trans)->ops->grab_nic_access(trans, flags)))
+                   likely((trans)->ops->grab_nic_access(trans)))
 
 static inline void __releases(nic_access)
-iwl_trans_release_nic_access(struct iwl_trans *trans, unsigned long *flags)
+iwl_trans_release_nic_access(struct iwl_trans *trans)
 {
-       trans->ops->release_nic_access(trans, flags);
+       trans->ops->release_nic_access(trans);
        __release(nic_access);
 }
 
 
 {
        struct iwl_trans_pcie *trans_pcie = IWL_TRANS_GET_PCIE_TRANS(trans);
        u32 rb_size;
-       unsigned long flags;
        const u32 rfdnlog = RX_QUEUE_SIZE_LOG; /* 256 RBDs */
 
        switch (trans_pcie->rx_buf_size) {
                rb_size = FH_RCSR_RX_CONFIG_REG_VAL_RB_SIZE_4K;
        }
 
-       if (!iwl_trans_grab_nic_access(trans, &flags))
+       if (!iwl_trans_grab_nic_access(trans))
                return;
 
        /* Stop Rx DMA */
                    (RX_RB_TIMEOUT << FH_RCSR_RX_CONFIG_REG_IRQ_RBTH_POS) |
                    (rfdnlog << FH_RCSR_RX_CONFIG_RBDCB_SIZE_POS));
 
-       iwl_trans_release_nic_access(trans, &flags);
+       iwl_trans_release_nic_access(trans);
 
        /* Set interrupt coalescing timer to default (2048 usecs) */
        iwl_write8(trans, CSR_INT_COALESCING, IWL_HOST_INT_TIMEOUT_DEF);
 {
        struct iwl_trans_pcie *trans_pcie = IWL_TRANS_GET_PCIE_TRANS(trans);
        u32 rb_size, enabled = 0;
-       unsigned long flags;
        int i;
 
        switch (trans_pcie->rx_buf_size) {
                rb_size = RFH_RXF_DMA_RB_SIZE_4K;
        }
 
-       if (!iwl_trans_grab_nic_access(trans, &flags))
+       if (!iwl_trans_grab_nic_access(trans))
                return;
 
        /* Stop Rx DMA */
        /* Enable the relevant rx queues */
        iwl_write_prph_no_grab(trans, RFH_RXF_RXQ_ACTIVE, enabled);
 
-       iwl_trans_release_nic_access(trans, &flags);
+       iwl_trans_release_nic_access(trans);
 
        /* Set interrupt coalescing timer to default (2048 usecs) */
        iwl_write8(trans, CSR_INT_COALESCING, IWL_HOST_INT_TIMEOUT_DEF);
 
                                        u32 byte_cnt)
 {
        struct iwl_trans_pcie *trans_pcie = IWL_TRANS_GET_PCIE_TRANS(trans);
-       unsigned long flags;
        int ret;
 
        trans_pcie->ucode_write_complete = false;
 
-       if (!iwl_trans_grab_nic_access(trans, &flags))
+       if (!iwl_trans_grab_nic_access(trans))
                return -EIO;
 
        iwl_pcie_load_firmware_chunk_fh(trans, dst_addr, phy_addr,
                                        byte_cnt);
-       iwl_trans_release_nic_access(trans, &flags);
+       iwl_trans_release_nic_access(trans);
 
        ret = wait_event_timeout(trans_pcie->ucode_write_waitq,
                                 trans_pcie->ucode_write_complete, 5 * HZ);
        module_put(THIS_MODULE);
 }
 
-static bool iwl_trans_pcie_grab_nic_access(struct iwl_trans *trans,
-                                          unsigned long *flags)
+static bool iwl_trans_pcie_grab_nic_access(struct iwl_trans *trans)
 {
        int ret;
        struct iwl_trans_pcie *trans_pcie = IWL_TRANS_GET_PCIE_TRANS(trans);
        return true;
 }
 
-static void iwl_trans_pcie_release_nic_access(struct iwl_trans *trans,
-                                             unsigned long *flags)
+static void iwl_trans_pcie_release_nic_access(struct iwl_trans *trans)
 {
        struct iwl_trans_pcie *trans_pcie = IWL_TRANS_GET_PCIE_TRANS(trans);
 
 static int iwl_trans_pcie_read_mem(struct iwl_trans *trans, u32 addr,
                                   void *buf, int dwords)
 {
-       unsigned long flags;
        int offs = 0;
        u32 *vals = buf;
 
                unsigned long end = jiffies + HZ / 2;
                bool resched = false;
 
-               if (iwl_trans_grab_nic_access(trans, &flags)) {
+               if (iwl_trans_grab_nic_access(trans)) {
                        iwl_write32(trans, HBUS_TARG_MEM_RADDR,
                                    addr + 4 * offs);
 
                                        break;
                                }
                        }
-                       iwl_trans_release_nic_access(trans, &flags);
+                       iwl_trans_release_nic_access(trans);
 
                        if (resched)
                                cond_resched();
 static int iwl_trans_pcie_write_mem(struct iwl_trans *trans, u32 addr,
                                    const void *buf, int dwords)
 {
-       unsigned long flags;
        int offs, ret = 0;
        const u32 *vals = buf;
 
-       if (iwl_trans_grab_nic_access(trans, &flags)) {
+       if (iwl_trans_grab_nic_access(trans)) {
                iwl_write32(trans, HBUS_TARG_MEM_WADDR, addr);
                for (offs = 0; offs < dwords; offs++)
                        iwl_write32(trans, HBUS_TARG_MEM_WDAT,
                                    vals ? vals[offs] : 0);
-               iwl_trans_release_nic_access(trans, &flags);
+               iwl_trans_release_nic_access(trans);
        } else {
                ret = -EBUSY;
        }
                                       struct iwl_fw_error_dump_data **data)
 {
        u32 fh_regs_len = FH_MEM_UPPER_BOUND - FH_MEM_LOWER_BOUND;
-       unsigned long flags;
        __le32 *val;
        int i;
 
-       if (!iwl_trans_grab_nic_access(trans, &flags))
+       if (!iwl_trans_grab_nic_access(trans))
                return 0;
 
        (*data)->type = cpu_to_le32(IWL_FW_ERROR_DUMP_FH_REGS);
                        *val++ = cpu_to_le32(iwl_trans_pcie_read_prph(trans,
                                                                      i));
 
-       iwl_trans_release_nic_access(trans, &flags);
+       iwl_trans_release_nic_access(trans);
 
        *data = iwl_fw_error_next_data(*data);
 
 {
        u32 buf_size_in_dwords = (monitor_len >> 2);
        u32 *buffer = (u32 *)fw_mon_data->data;
-       unsigned long flags;
        u32 i;
 
-       if (!iwl_trans_grab_nic_access(trans, &flags))
+       if (!iwl_trans_grab_nic_access(trans))
                return 0;
 
        iwl_write_umac_prph_no_grab(trans, MON_DMARB_RD_CTL_ADDR, 0x1);
                                                       MON_DMARB_RD_DATA_ADDR);
        iwl_write_umac_prph_no_grab(trans, MON_DMARB_RD_CTL_ADDR, 0x0);
 
-       iwl_trans_release_nic_access(trans, &flags);
+       iwl_trans_release_nic_access(trans);
 
        return monitor_len;
 }
 
 static void iwl_pcie_tx_stop_fh(struct iwl_trans *trans)
 {
        struct iwl_trans_pcie *trans_pcie = IWL_TRANS_GET_PCIE_TRANS(trans);
-       unsigned long flags;
        int ch, ret;
        u32 mask = 0;
 
        spin_lock_bh(&trans_pcie->irq_lock);
 
-       if (!iwl_trans_grab_nic_access(trans, &flags))
+       if (!iwl_trans_grab_nic_access(trans))
                goto out;
 
        /* Stop each Tx DMA channel */
                        "Failing on timeout while stopping DMA channel %d [0x%08x]\n",
                        ch, iwl_read32(trans, FH_TSSR_TX_STATUS_REG));
 
-       iwl_trans_release_nic_access(trans, &flags);
+       iwl_trans_release_nic_access(trans);
 
 out:
        spin_unlock_bh(&trans_pcie->irq_lock);