shost->cmd_per_lun = sht->cmd_per_lun;
        shost->unchecked_isa_dma = sht->unchecked_isa_dma;
        shost->no_write_same = sht->no_write_same;
+       shost->host_tagset = sht->host_tagset;
 
        if (shost_eh_deadline == -1 || !sht->eh_host_reset_handler)
                shost->eh_deadline = -1;
 
        tag_set->flags |=
                BLK_ALLOC_POLICY_TO_MQ_FLAG(shost->hostt->tag_alloc_policy);
        tag_set->driver_data = shost;
+       if (shost->host_tagset)
+               tag_set->flags |= BLK_MQ_F_TAG_HCTX_SHARED;
 
        return blk_mq_alloc_tag_set(tag_set);
 }
 
        /* True if the controller does not support WRITE SAME */
        unsigned no_write_same:1;
 
+       /* True if the host uses host-wide tagspace */
+       unsigned host_tagset:1;
+
        /*
         * Countdown for host blocking with no commands outstanding.
         */
         *
         * Note: it is assumed that each hardware queue has a queue depth of
         * can_queue. In other words, the total queue depth per host
-        * is nr_hw_queues * can_queue.
+        * is nr_hw_queues * can_queue. However, for when host_tagset is set,
+        * the total queue depth is can_queue.
         */
        unsigned nr_hw_queues;
        unsigned active_mode:2;
        /* The controller does not support WRITE SAME */
        unsigned no_write_same:1;
 
+       /* True if the host uses host-wide tagspace */
+       unsigned host_tagset:1;
+
        /* Host responded with short (<36 bytes) INQUIRY result */
        unsigned short_inquiry:1;