{
        int tag, org_last_tag, end;
 
-       org_last_tag = last_tag = TAG_TO_BIT(last_tag);
+       org_last_tag = last_tag;
        end = bm->depth;
        do {
 restart:
        int index, i, tag;
 
        last_tag = org_last_tag = *tag_cache;
-       index = TAG_TO_INDEX(last_tag);
+       index = TAG_TO_INDEX(bt, last_tag);
 
        for (i = 0; i < bt->map_nr; i++) {
-               tag = __bt_get_word(&bt->map[index], last_tag);
+               tag = __bt_get_word(&bt->map[index], TAG_TO_BIT(bt, last_tag));
                if (tag != -1) {
-                       tag += index * BITS_PER_LONG;
+                       tag += (index << bt->bits_per_word);
                        goto done;
                }
 
 
 static void bt_clear_tag(struct blk_mq_bitmap_tags *bt, unsigned int tag)
 {
-       const int index = TAG_TO_INDEX(tag);
+       const int index = TAG_TO_INDEX(bt, tag);
        struct bt_wait_state *bs;
 
-       clear_bit(TAG_TO_BIT(tag), &bt->map[index].word);
+       clear_bit(TAG_TO_BIT(bt, tag), &bt->map[index].word);
 
        bs = bt_wake_ptr(bt);
        if (bs && atomic_dec_and_test(&bs->wait_cnt)) {
                        bit++;
                } while (1);
 
-               off += BITS_PER_LONG;
+               off += (1 << bt->bits_per_word);
        }
 }
 
 {
        int i;
 
+       bt->bits_per_word = ilog2(BITS_PER_LONG);
+
        /*
         * Depth can be zero for reserved tags, that's not a failure
         * condition.
         */
        if (depth) {
-               int nr, i, map_depth;
+               unsigned int nr, i, map_depth, tags_per_word;
+
+               tags_per_word = (1 << bt->bits_per_word);
+
+               /*
+                * If the tag space is small, shrink the number of tags
+                * per word so we spread over a few cachelines, at least.
+                * If less than 4 tags, just forget about it, it's not
+                * going to work optimally anyway.
+                */
+               if (depth >= 4) {
+                       while (tags_per_word * 4 > depth) {
+                               bt->bits_per_word--;
+                               tags_per_word = (1 << bt->bits_per_word);
+                       }
+               }
 
-               nr = ALIGN(depth, BITS_PER_LONG) / BITS_PER_LONG;
+               nr = ALIGN(depth, tags_per_word) / tags_per_word;
                bt->map = kzalloc_node(nr * sizeof(struct blk_mq_bitmap),
                                                GFP_KERNEL, node);
                if (!bt->map)
                bt->map_nr = nr;
                map_depth = depth;
                for (i = 0; i < nr; i++) {
-                       bt->map[i].depth = min(map_depth, BITS_PER_LONG);
-                       map_depth -= BITS_PER_LONG;
+                       bt->map[i].depth = min(map_depth, tags_per_word);
+                       map_depth -= tags_per_word;
                }
        }
 
        if (!tags)
                return 0;
 
-       page += sprintf(page, "nr_tags=%u, reserved_tags=%u\n",
-                       tags->nr_tags, tags->nr_reserved_tags);
+       page += sprintf(page, "nr_tags=%u, reserved_tags=%u, "
+                       "bits_per_word=%u\n",
+                       tags->nr_tags, tags->nr_reserved_tags,
+                       tags->bitmap_tags.bits_per_word);
 
        free = bt_unused_tags(&tags->bitmap_tags);
        res = bt_unused_tags(&tags->breserved_tags);
 
        wait_queue_head_t wait;
 } ____cacheline_aligned_in_smp;
 
-#define TAG_TO_INDEX(tag)      ((tag) / BITS_PER_LONG)
-#define TAG_TO_BIT(tag)                ((tag) & (BITS_PER_LONG - 1))
+#define TAG_TO_INDEX(bt, tag)  ((tag) >> (bt)->bits_per_word)
+#define TAG_TO_BIT(bt, tag)    ((tag) & ((1 << (bt)->bits_per_word) - 1))
 
 struct blk_mq_bitmap {
        unsigned long word;
 struct blk_mq_bitmap_tags {
        unsigned int depth;
        unsigned int wake_cnt;
+       unsigned int bits_per_word;
 
-       struct blk_mq_bitmap *map;
        unsigned int map_nr;
+       struct blk_mq_bitmap *map;
 
        unsigned int wake_index;
        struct bt_wait_state *bs;