#include "iwl-io.h"
 #include "iwl-prph.h"
 
-struct iwl_dbgfs_mvm_ctx {
-       struct iwl_mvm *mvm;
-       struct ieee80211_vif *vif;
-};
-
 static ssize_t iwl_dbgfs_tx_flush_write(struct file *file,
                                        const char __user *user_buf,
                                        size_t count, loff_t *ppos)
 {
        struct iwl_mvm *mvm = file->private_data;
-
-       char buf[16];
-       int buf_size, ret;
+       char buf[16] = {};
+       size_t buf_size = min(count, sizeof(buf) - 1);
+       int ret;
        u32 scd_q_msk;
 
        if (!mvm->ucode_loaded || mvm->cur_ucode != IWL_UCODE_REGULAR)
                return -EIO;
 
-       memset(buf, 0, sizeof(buf));
-       buf_size = min(count, sizeof(buf) - 1);
        if (copy_from_user(buf, user_buf, buf_size))
                return -EFAULT;
 
 {
        struct iwl_mvm *mvm = file->private_data;
        struct ieee80211_sta *sta;
-
-       char buf[8];
-       int buf_size, sta_id, drain, ret;
+       char buf[8] = {};
+       size_t buf_size = min(count, sizeof(buf) - 1);
+       int sta_id, drain, ret;
 
        if (!mvm->ucode_loaded || mvm->cur_ucode != IWL_UCODE_REGULAR)
                return -EIO;
 
-       memset(buf, 0, sizeof(buf));
-       buf_size = min(count, sizeof(buf) - 1);
        if (copy_from_user(buf, user_buf, buf_size))
                return -EFAULT;
 
                                    loff_t *ppos)
 {
        struct iwl_mvm *mvm = file->private_data;
-       char buf[64];
-       int buf_size;
+       char buf[64] = {};
+       size_t buf_size = min(count, sizeof(buf) -  1);
        u32 offset, len;
 
-       memset(buf, 0, sizeof(buf));
-       buf_size = min(count, sizeof(buf) -  1);
        if (copy_from_user(buf, user_buf, buf_size))
                return -EFAULT;
 
 {
        struct iwl_mvm *mvm = file->private_data;
        char buf[64] = {};
+       size_t buf_size = min(count, sizeof(buf) - 1);
        int ret;
        int val;
 
        if (!mvm->ucode_loaded)
                return -EIO;
 
-       count = min_t(size_t, count, sizeof(buf) - 1);
-       if (copy_from_user(buf, user_buf, count))
+       if (copy_from_user(buf, user_buf, buf_size))
                return -EFAULT;
 
        if (!strncmp("disable_power_off_d0=", buf, 21)) {
                int dtimper_msec = dtimper * vif->bss_conf.beacon_int;
 
                IWL_DEBUG_POWER(mvm, "debugfs: set keep_alive= %d sec\n", val);
-               if (val * MSEC_PER_SEC < 3 * dtimper_msec) {
+               if (val * MSEC_PER_SEC < 3 * dtimper_msec)
                        IWL_WARN(mvm,
                                 "debugfs: keep alive period (%ld msec) is less than minimum required (%d msec)\n",
                                 val * MSEC_PER_SEC, 3 * dtimper_msec);
-               }
                dbgfs_pm->keep_alive_seconds = val;
                break;
        }
        struct iwl_mvm *mvm = mvmvif->dbgfs_data;
        enum iwl_dbgfs_pm_mask param;
        char buf[32] = {};
+       size_t buf_size = min(count, sizeof(buf) - 1);
        int val;
        int ret;
 
-       count = min_t(size_t, count, sizeof(buf) - 1);
-       if (copy_from_user(buf, user_buf, count))
+       if (copy_from_user(buf, user_buf, buf_size))
                return -EFAULT;
 
        if (!strncmp("keep_alive=", buf, 11)) {
        pos += scnprintf(buf+pos, bufsz-pos, "bssid: %pM\n",
                         vif->bss_conf.bssid);
        pos += scnprintf(buf+pos, bufsz-pos, "QoS:\n");
-       for (i = 0; i < ARRAY_SIZE(mvmvif->queue_params); i++) {
+       for (i = 0; i < ARRAY_SIZE(mvmvif->queue_params); i++)
                pos += scnprintf(buf+pos, bufsz-pos,
                                 "\t%d: txop:%d - cw_min:%d - cw_max = %d - aifs = %d upasd = %d\n",
                                 i, mvmvif->queue_params[i].txop,
                                 mvmvif->queue_params[i].cw_max,
                                 mvmvif->queue_params[i].aifs,
                                 mvmvif->queue_params[i].uapsd);
-       }
 
        if (vif->type == NL80211_IFTYPE_STATION &&
            ap_sta_id != IWL_MVM_STATION_COUNT) {
 
        rcu_read_lock();
        chanctx_conf = rcu_dereference(vif->chanctx_conf);
-       if (chanctx_conf) {
+       if (chanctx_conf)
                pos += scnprintf(buf+pos, bufsz-pos,
                                 "idle rx chains %d, active rx chains: %d\n",
                                 chanctx_conf->rx_chains_static,
                                 chanctx_conf->rx_chains_dynamic);
-       }
        rcu_read_unlock();
 
        mutex_unlock(&mvm->mutex);
                                 size_t count, loff_t *ppos)
 {
        struct iwl_mvm *mvm = file->private_data;
-       char buf[8];
-       int buf_size;
+       char buf[8] = {};
+       size_t buf_size = min(count, sizeof(buf) - 1);
        u8 scan_rx_ant;
 
-       memset(buf, 0, sizeof(buf));
-       buf_size = min(count, sizeof(buf) - 1);
-
-       /* get the argument from the user and check if it is valid */
        if (copy_from_user(buf, user_buf, buf_size))
                return -EFAULT;
        if (sscanf(buf, "%hhx", &scan_rx_ant) != 1)
        if (scan_rx_ant & ~iwl_fw_valid_rx_ant(mvm->fw))
                return -EINVAL;
 
-       /* change the rx antennas for scan command */
        mvm->scan_rx_ant = scan_rx_ant;
 
        return count;
        struct iwl_mvm_vif *mvmvif = iwl_mvm_vif_from_mac80211(vif);
        struct iwl_mvm *mvm = mvmvif->dbgfs_data;
        enum iwl_dbgfs_bf_mask param;
-       char buf[256];
-       int buf_size;
-       int value;
-       int ret = 0;
+       char buf[256] = {};
+       size_t buf_size = min(count, sizeof(buf) - 1);
+       int value, ret = 0;
 
-       memset(buf, 0, sizeof(buf));
-       buf_size = min(count, sizeof(buf) - 1);
        if (copy_from_user(buf, user_buf, buf_size))
                return -EFAULT;
 
 
        mutex_lock(&mvm->mutex);
        iwl_dbgfs_update_bf(vif, param, value);
-       if (param == MVM_DEBUGFS_BF_ENABLE_BEACON_FILTER && !value) {
+       if (param == MVM_DEBUGFS_BF_ENABLE_BEACON_FILTER && !value)
                ret = iwl_mvm_disable_beacon_filter(mvm, vif);
-       } else {
+       else
                ret = iwl_mvm_enable_beacon_filter(mvm, vif);
-       }
        mutex_unlock(&mvm->mutex);
 
        return ret ?: count;
 {
        struct iwl_mvm *mvm = file->private_data;
        char buf[8] = {};
+       size_t buf_size = min(count, sizeof(buf) - 1);
        int store;
 
-       count = min_t(size_t, count, sizeof(buf) - 1);
-       if (copy_from_user(buf, user_buf, count))
+       if (copy_from_user(buf, user_buf, buf_size))
                return -EFAULT;
 
        if (sscanf(buf, "%d", &store) != 1)
 #endif
 
 #define MVM_DEBUGFS_READ_FILE_OPS(name)                                        \
-static const struct file_operations iwl_dbgfs_##name##_ops = { \
+static const struct file_operations iwl_dbgfs_##name##_ops = {         \
        .read = iwl_dbgfs_##name##_read,                                \
        .open = simple_open,                                            \
        .llseek = generic_file_llseek,                                  \
 }
 
 #define MVM_DEBUGFS_READ_WRITE_FILE_OPS(name)                          \
-static const struct file_operations iwl_dbgfs_##name##_ops = { \
+static const struct file_operations iwl_dbgfs_##name##_ops = {         \
        .write = iwl_dbgfs_##name##_write,                              \
        .read = iwl_dbgfs_##name##_read,                                \
        .open = simple_open,                                            \
 };
 
 #define MVM_DEBUGFS_WRITE_FILE_OPS(name)                               \
-static const struct file_operations iwl_dbgfs_##name##_ops = { \
+static const struct file_operations iwl_dbgfs_##name##_ops = {         \
        .write = iwl_dbgfs_##name##_write,                              \
        .open = simple_open,                                            \
        .llseek = generic_file_llseek,                                  \