block: don't assume last put of shared tags is for the host
authorChristoph Hellwig <hch@lst.de>
Tue, 8 Jul 2014 10:25:28 +0000 (12:25 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 31 Jul 2014 19:52:54 +0000 (12:52 -0700)
commit0b9f20dad0bc659261f88294192c1f1c7763fc2a
tree552aa8cc04f63f92070a3a5b59cffd3d191f1457
parent3b968e0cc905310a19bc0b8f0f77600abf1aed2d
block: don't assume last put of shared tags is for the host

commit d45b3279a5a2252cafcd665bbf2db8c9b31ef783 upstream.

There is no inherent reason why the last put of a tag structure must be
the one for the Scsi_Host, as device model objects can be held for
arbitrary periods.  Merge blk_free_tags and __blk_free_tags into a single
funtion that just release a references and get rid of the BUG() when the
host reference wasn't the last.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Jens Axboe <axboe@fb.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
block/blk-tag.c