static int sdebug_sectors_per;         /* sectors per cylinder */
 
 static LIST_HEAD(sdebug_host_list);
-static DEFINE_SPINLOCK(sdebug_host_list_lock);
+static DEFINE_MUTEX(sdebug_host_list_mutex);
 
 static struct xarray per_store_arr;
 static struct xarray *per_store_ap = &per_store_arr;
        struct sdebug_host_info *sdbg_host;
        struct Scsi_Host *hpnt;
 
-       spin_lock(&sdebug_host_list_lock);
+       mutex_lock(&sdebug_host_list_mutex);
        list_for_each_entry(sdbg_host, &sdebug_host_list, host_list) {
                hpnt = sdbg_host->shost;
                if ((hpnt->this_id >= 0) &&
                /* sdebug_max_luns; */
                hpnt->max_lun = SCSI_W_LUN_REPORT_LUNS + 1;
        }
-       spin_unlock(&sdebug_host_list_lock);
+       mutex_unlock(&sdebug_host_list_mutex);
 }
 
 enum sdeb_cmd_data {SDEB_IN_DATA = 0, SDEB_IN_CDB = 1};
        struct Scsi_Host *shost;
        struct scsi_device *sdev;
 
-       spin_lock(&sdebug_host_list_lock);
+       mutex_lock(&sdebug_host_list_mutex);
        list_for_each_entry(sdbg_host, &sdebug_host_list, host_list) {
                shost = sdbg_host->shost;
                shost_for_each_device(sdev, shost) {
                        config_cdb_len(sdev);
                }
        }
-       spin_unlock(&sdebug_host_list_lock);
+       mutex_unlock(&sdebug_host_list_mutex);
 }
 
 static void clear_luns_changed_on_target(struct sdebug_dev_info *devip)
        ++num_host_resets;
        if (SDEBUG_OPT_ALL_NOISE & sdebug_opts)
                sdev_printk(KERN_INFO, SCpnt->device, "%s\n", __func__);
-       spin_lock(&sdebug_host_list_lock);
+       mutex_lock(&sdebug_host_list_mutex);
        list_for_each_entry(sdbg_host, &sdebug_host_list, host_list) {
                list_for_each_entry(devip, &sdbg_host->dev_info_list,
                                    dev_list) {
                        ++k;
                }
        }
-       spin_unlock(&sdebug_host_list_lock);
+       mutex_unlock(&sdebug_host_list_mutex);
        stop_all_queued();
        if (SDEBUG_OPT_RESET_NOISE & sdebug_opts)
                sdev_printk(KERN_INFO, SCpnt->device,
                        struct sdebug_host_info *sdhp;
                        struct sdebug_dev_info *dp;
 
-                       spin_lock(&sdebug_host_list_lock);
+                       mutex_lock(&sdebug_host_list_mutex);
                        list_for_each_entry(sdhp, &sdebug_host_list, host_list) {
                                list_for_each_entry(dp, &sdhp->dev_info_list, dev_list) {
                                        set_bit(SDEBUG_UA_LUNS_CHANGED, dp->uas_bm);
                                }
                        }
-                       spin_unlock(&sdebug_host_list_lock);
+                       mutex_unlock(&sdebug_host_list_mutex);
                }
                return count;
        }
                        struct sdebug_host_info *sdhp;
                        struct sdebug_dev_info *dp;
 
-                       spin_lock(&sdebug_host_list_lock);
+                       mutex_lock(&sdebug_host_list_mutex);
                        list_for_each_entry(sdhp, &sdebug_host_list,
                                            host_list) {
                                list_for_each_entry(dp, &sdhp->dev_info_list,
                                                dp->uas_bm);
                                }
                        }
-                       spin_unlock(&sdebug_host_list_lock);
+                       mutex_unlock(&sdebug_host_list_mutex);
                }
                return count;
        }
                        struct sdebug_host_info *sdhp;
                        struct sdebug_dev_info *dp;
 
-                       spin_lock(&sdebug_host_list_lock);
+                       mutex_lock(&sdebug_host_list_mutex);
                        list_for_each_entry(sdhp, &sdebug_host_list,
                                            host_list) {
                                list_for_each_entry(dp, &sdhp->dev_info_list,
                                                dp->uas_bm);
                                }
                        }
-                       spin_unlock(&sdebug_host_list_lock);
+                       mutex_unlock(&sdebug_host_list_mutex);
                }
                return count;
        }
                        goto clean;
        }
 
-       spin_lock(&sdebug_host_list_lock);
+       mutex_lock(&sdebug_host_list_mutex);
        list_add_tail(&sdbg_host->host_list, &sdebug_host_list);
-       spin_unlock(&sdebug_host_list_lock);
+       mutex_unlock(&sdebug_host_list_mutex);
 
        sdbg_host->dev.bus = &pseudo_lld_bus;
        sdbg_host->dev.parent = pseudo_primary;
 
        error = device_register(&sdbg_host->dev);
        if (error) {
-               spin_lock(&sdebug_host_list_lock);
+               mutex_lock(&sdebug_host_list_mutex);
                list_del(&sdbg_host->host_list);
-               spin_unlock(&sdebug_host_list_lock);
+               mutex_unlock(&sdebug_host_list_mutex);
                goto clean;
        }
 
        struct sdebug_host_info *sdbg_host = NULL;
        struct sdebug_host_info *sdbg_host2;
 
-       spin_lock(&sdebug_host_list_lock);
+       mutex_lock(&sdebug_host_list_mutex);
        if (!list_empty(&sdebug_host_list)) {
                sdbg_host = list_entry(sdebug_host_list.prev,
                                       struct sdebug_host_info, host_list);
        }
        if (sdbg_host)
                list_del(&sdbg_host->host_list);
-       spin_unlock(&sdebug_host_list_lock);
+       mutex_unlock(&sdebug_host_list_mutex);
 
        if (!sdbg_host)
                return;