struct priority_group *current_pg;
        struct priority_group *next_pg; /* Switch to this PG if set */
 
-       bool queue_io:1;                /* Must we queue all I/O? */
-       bool queue_if_no_path:1;        /* Queue I/O if last path fails? */
-       bool saved_queue_if_no_path:1;  /* Saved state during suspension */
-       bool retain_attached_hw_handler:1; /* If there's already a hw_handler present, don't change it. */
-       bool pg_init_disabled:1;        /* pg_init is not currently allowed */
-       bool pg_init_required:1;        /* pg_init needs calling? */
-       bool pg_init_delay_retry:1;     /* Delay pg_init retry? */
+       unsigned long flags;            /* Multipath state flags */
 
        unsigned pg_init_retries;       /* Number of times to retry pg_init */
        unsigned pg_init_count;         /* Number of times pg_init called */
 static void trigger_event(struct work_struct *work);
 static void activate_path(struct work_struct *work);
 
+/*-----------------------------------------------
+ * Multipath state flags.
+ *-----------------------------------------------*/
+
+#define MPATHF_QUEUE_IO 0                      /* Must we queue all I/O? */
+#define MPATHF_QUEUE_IF_NO_PATH 1              /* Queue I/O if last path fails? */
+#define MPATHF_SAVED_QUEUE_IF_NO_PATH 2                /* Saved state during suspension */
+#define MPATHF_RETAIN_ATTACHED_HW_HANDLER 3    /* If there's already a hw_handler present, don't change it. */
+#define MPATHF_PG_INIT_DISABLED 4              /* pg_init is not currently allowed */
+#define MPATHF_PG_INIT_REQUIRED 5              /* pg_init needs calling? */
+#define MPATHF_PG_INIT_DELAY_RETRY 6           /* Delay pg_init retry? */
 
 /*-----------------------------------------------
  * Allocation routines
        if (m) {
                INIT_LIST_HEAD(&m->priority_groups);
                spin_lock_init(&m->lock);
-               m->queue_io = true;
+               set_bit(MPATHF_QUEUE_IO, &m->flags);
                m->pg_init_delay_msecs = DM_PG_INIT_DELAY_DEFAULT;
                INIT_WORK(&m->trigger_event, trigger_event);
                init_waitqueue_head(&m->pg_init_wait);
        struct pgpath *pgpath;
        unsigned long pg_init_delay = 0;
 
-       if (m->pg_init_in_progress || m->pg_init_disabled)
+       if (m->pg_init_in_progress || test_bit(MPATHF_PG_INIT_DISABLED, &m->flags))
                return 0;
 
        m->pg_init_count++;
-       m->pg_init_required = false;
+       clear_bit(MPATHF_PG_INIT_REQUIRED, &m->flags);
 
        /* Check here to reset pg_init_required */
        if (!m->current_pg)
                return 0;
 
-       if (m->pg_init_delay_retry)
+       if (test_bit(MPATHF_PG_INIT_DELAY_RETRY, &m->flags))
                pg_init_delay = msecs_to_jiffies(m->pg_init_delay_msecs != DM_PG_INIT_DELAY_DEFAULT ?
                                                 m->pg_init_delay_msecs : DM_PG_INIT_DELAY_MSECS);
        list_for_each_entry(pgpath, &m->current_pg->pgpaths, list) {
 
        /* Must we initialise the PG first, and queue I/O till it's ready? */
        if (m->hw_handler_name) {
-               m->pg_init_required = true;
-               m->queue_io = true;
+               set_bit(MPATHF_PG_INIT_REQUIRED, &m->flags);
+               set_bit(MPATHF_QUEUE_IO, &m->flags);
        } else {
-               m->pg_init_required = false;
-               m->queue_io = false;
+               clear_bit(MPATHF_PG_INIT_REQUIRED, &m->flags);
+               clear_bit(MPATHF_QUEUE_IO, &m->flags);
        }
 
        m->pg_init_count = 0;
        bool bypassed = true;
 
        if (!m->nr_valid_paths) {
-               m->queue_io = false;
+               clear_bit(MPATHF_QUEUE_IO, &m->flags);
                goto failed;
        }
 
                                continue;
                        if (!__choose_path_in_pg(m, pg, nr_bytes)) {
                                if (!bypassed)
-                                       m->pg_init_delay_retry = true;
+                                       set_bit(MPATHF_PG_INIT_DELAY_RETRY, &m->flags);
                                return;
                        }
                }
  */
 static int __must_push_back(struct multipath *m)
 {
-       return (m->queue_if_no_path ||
-               (m->queue_if_no_path != m->saved_queue_if_no_path &&
+       return (test_bit(MPATHF_QUEUE_IF_NO_PATH, &m->flags) ||
+               ((test_bit(MPATHF_QUEUE_IF_NO_PATH, &m->flags) !=
+                 test_bit(MPATHF_SAVED_QUEUE_IF_NO_PATH, &m->flags)) &&
                 dm_noflush_suspending(m->ti)));
 }
 
        spin_lock_irq(&m->lock);
 
        /* Do we need to select a new pgpath? */
-       if (!m->current_pgpath || !m->queue_io)
+       if (!m->current_pgpath || !test_bit(MPATHF_QUEUE_IO, &m->flags))
                __choose_pgpath(m, nr_bytes);
 
        pgpath = m->current_pgpath;
                if (!__must_push_back(m))
                        r = -EIO;       /* Failed */
                goto out_unlock;
-       } else if (m->queue_io || m->pg_init_required) {
+       } else if (test_bit(MPATHF_QUEUE_IO, &m->flags) ||
+                  test_bit(MPATHF_PG_INIT_REQUIRED, &m->flags)) {
                __pg_init_all_paths(m);
                goto out_unlock;
        }
 
        spin_lock_irqsave(&m->lock, flags);
 
-       if (save_old_value)
-               m->saved_queue_if_no_path = m->queue_if_no_path;
+       if (save_old_value) {
+               if (test_bit(MPATHF_QUEUE_IF_NO_PATH, &m->flags))
+                       set_bit(MPATHF_SAVED_QUEUE_IF_NO_PATH, &m->flags);
+               else
+                       clear_bit(MPATHF_SAVED_QUEUE_IF_NO_PATH, &m->flags);
+       } else {
+               if (queue_if_no_path)
+                       set_bit(MPATHF_SAVED_QUEUE_IF_NO_PATH, &m->flags);
+               else
+                       clear_bit(MPATHF_SAVED_QUEUE_IF_NO_PATH, &m->flags);
+       }
+       if (queue_if_no_path)
+               set_bit(MPATHF_QUEUE_IF_NO_PATH, &m->flags);
        else
-               m->saved_queue_if_no_path = queue_if_no_path;
-       m->queue_if_no_path = queue_if_no_path;
+               clear_bit(MPATHF_QUEUE_IF_NO_PATH, &m->flags);
+
        spin_unlock_irqrestore(&m->lock, flags);
 
        if (!queue_if_no_path)
                goto bad;
        }
 
-       if (m->retain_attached_hw_handler || m->hw_handler_name)
+       if (test_bit(MPATHF_RETAIN_ATTACHED_HW_HANDLER, &m->flags) || m->hw_handler_name)
                q = bdev_get_queue(p->path.dev->bdev);
 
-       if (m->retain_attached_hw_handler) {
+       if (test_bit(MPATHF_RETAIN_ATTACHED_HW_HANDLER, &m->flags)) {
 retain:
                attached_handler_name = scsi_dh_attached_handler_name(q, GFP_KERNEL);
                if (attached_handler_name) {
                }
 
                if (!strcasecmp(arg_name, "retain_attached_hw_handler")) {
-                       m->retain_attached_hw_handler = true;
+                       set_bit(MPATHF_RETAIN_ATTACHED_HW_HANDLER, &m->flags);
                        continue;
                }
 
 
 static void flush_multipath_work(struct multipath *m)
 {
-       unsigned long flags;
-
-       spin_lock_irqsave(&m->lock, flags);
-       m->pg_init_disabled = true;
-       spin_unlock_irqrestore(&m->lock, flags);
+       set_bit(MPATHF_PG_INIT_DISABLED, &m->flags);
+       smp_mb__after_atomic();
 
        flush_workqueue(kmpath_handlerd);
        multipath_wait_for_pg_init_completion(m);
        flush_workqueue(kmultipathd);
        flush_work(&m->trigger_event);
 
-       spin_lock_irqsave(&m->lock, flags);
-       m->pg_init_disabled = false;
-       spin_unlock_irqrestore(&m->lock, flags);
+       clear_bit(MPATHF_PG_INIT_DISABLED, &m->flags);
+       smp_mb__after_atomic();
 }
 
 static void multipath_dtr(struct dm_target *ti)
 
        spin_lock_irqsave(&m->lock, flags);
 
-       if (m->pg_init_count <= m->pg_init_retries && !m->pg_init_disabled)
-               m->pg_init_required = true;
+       if (m->pg_init_count <= m->pg_init_retries && !test_bit(MPATHF_PG_INIT_DISABLED, &m->flags))
+               set_bit(MPATHF_PG_INIT_REQUIRED, &m->flags);
        else
                limit_reached = true;
 
                        m->current_pgpath = NULL;
                        m->current_pg = NULL;
                }
-       } else if (!m->pg_init_required)
+       } else if (!test_bit(MPATHF_PG_INIT_REQUIRED, &m->flags))
                pg->bypassed = false;
 
        if (--m->pg_init_in_progress)
                /* Activations of other paths are still on going */
                goto out;
 
-       if (m->pg_init_required) {
-               m->pg_init_delay_retry = delay_retry;
+       if (test_bit(MPATHF_PG_INIT_REQUIRED, &m->flags)) {
+               if (delay_retry)
+                       set_bit(MPATHF_PG_INIT_DELAY_RETRY, &m->flags);
+               else
+                       clear_bit(MPATHF_PG_INIT_DELAY_RETRY, &m->flags);
+
                if (__pg_init_all_paths(m))
                        goto out;
        }
-       m->queue_io = false;
+       clear_bit(MPATHF_QUEUE_IO, &m->flags);
 
        /*
         * Wake up any thread waiting to suspend.
 
        spin_lock_irqsave(&m->lock, flags);
        if (!m->nr_valid_paths) {
-               if (!m->queue_if_no_path) {
+               if (!test_bit(MPATHF_QUEUE_IF_NO_PATH, &m->flags)) {
                        if (!__must_push_back(m))
                                r = -EIO;
                } else {
 static void multipath_resume(struct dm_target *ti)
 {
        struct multipath *m = ti->private;
-       unsigned long flags;
 
-       spin_lock_irqsave(&m->lock, flags);
-       m->queue_if_no_path = m->saved_queue_if_no_path;
-       spin_unlock_irqrestore(&m->lock, flags);
+       if (test_bit(MPATHF_SAVED_QUEUE_IF_NO_PATH, &m->flags))
+               set_bit(MPATHF_QUEUE_IF_NO_PATH, &m->flags);
+       else
+               clear_bit(MPATHF_QUEUE_IF_NO_PATH, &m->flags);
+       smp_mb__after_atomic();
 }
 
 /*
 
        /* Features */
        if (type == STATUSTYPE_INFO)
-               DMEMIT("2 %u %u ", m->queue_io, m->pg_init_count);
+               DMEMIT("2 %u %u ", test_bit(MPATHF_QUEUE_IO, &m->flags), m->pg_init_count);
        else {
-               DMEMIT("%u ", m->queue_if_no_path +
+               DMEMIT("%u ", test_bit(MPATHF_QUEUE_IF_NO_PATH, &m->flags) +
                              (m->pg_init_retries > 0) * 2 +
                              (m->pg_init_delay_msecs != DM_PG_INIT_DELAY_DEFAULT) * 2 +
-                             m->retain_attached_hw_handler);
-               if (m->queue_if_no_path)
+                             test_bit(MPATHF_RETAIN_ATTACHED_HW_HANDLER, &m->flags));
+               if (test_bit(MPATHF_QUEUE_IF_NO_PATH, &m->flags))
                        DMEMIT("queue_if_no_path ");
                if (m->pg_init_retries)
                        DMEMIT("pg_init_retries %u ", m->pg_init_retries);
                if (m->pg_init_delay_msecs != DM_PG_INIT_DELAY_DEFAULT)
                        DMEMIT("pg_init_delay_msecs %u ", m->pg_init_delay_msecs);
-               if (m->retain_attached_hw_handler)
+               if (test_bit(MPATHF_RETAIN_ATTACHED_HW_HANDLER, &m->flags))
                        DMEMIT("retain_attached_hw_handler ");
        }
 
                __choose_pgpath(m, 0);
 
        if (m->current_pgpath) {
-               if (!m->queue_io) {
+               if (!test_bit(MPATHF_QUEUE_IO, &m->flags)) {
                        *bdev = m->current_pgpath->path.dev->bdev;
                        *mode = m->current_pgpath->path.dev->mode;
                        r = 0;
                }
        } else {
                /* No path is available */
-               if (m->queue_if_no_path)
+               if (test_bit(MPATHF_QUEUE_IF_NO_PATH, &m->flags))
                        r = -ENOTCONN;
                else
                        r = -EIO;
                        /* Path status changed, redo selection */
                        __choose_pgpath(m, 0);
                }
-               if (m->pg_init_required)
+               if (test_bit(MPATHF_PG_INIT_REQUIRED, &m->flags))
                        __pg_init_all_paths(m);
                spin_unlock_irqrestore(&m->lock, flags);
                dm_table_run_md_queue_async(m->ti->table);
 
        /* pg_init in progress or no paths available */
        if (m->pg_init_in_progress ||
-           (!m->nr_valid_paths && m->queue_if_no_path)) {
+           (!m->nr_valid_paths && test_bit(MPATHF_QUEUE_IF_NO_PATH, &m->flags))) {
                busy = true;
                goto out;
        }