浏览代码

blk-mq: Add locking annotations to hctx_lock() and hctx_unlock()

This patch avoids that sparse reports the following:

block/blk-mq.c:637:33: warning: context imbalance in 'hctx_unlock' - unexpected unlock
block/blk-mq.c:642:9: warning: context imbalance in 'hctx_lock' - wrong count at exit

Signed-off-by: Bart Van Assche <bart.vanassche@wdc.com>
Cc: Tejun Heo <tj@kernel.org>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Bart Van Assche 7 年之前
父节点
当前提交
b7435db8b8
共有 1 个文件被更改,包括 2 次插入0 次删除
  1. 2 0
      block/blk-mq.c

+ 2 - 0
block/blk-mq.c

@@ -559,6 +559,7 @@ static void __blk_mq_complete_request(struct request *rq)
 }
 }
 
 
 static void hctx_unlock(struct blk_mq_hw_ctx *hctx, int srcu_idx)
 static void hctx_unlock(struct blk_mq_hw_ctx *hctx, int srcu_idx)
+	__releases(hctx->srcu)
 {
 {
 	if (!(hctx->flags & BLK_MQ_F_BLOCKING))
 	if (!(hctx->flags & BLK_MQ_F_BLOCKING))
 		rcu_read_unlock();
 		rcu_read_unlock();
@@ -567,6 +568,7 @@ static void hctx_unlock(struct blk_mq_hw_ctx *hctx, int srcu_idx)
 }
 }
 
 
 static void hctx_lock(struct blk_mq_hw_ctx *hctx, int *srcu_idx)
 static void hctx_lock(struct blk_mq_hw_ctx *hctx, int *srcu_idx)
+	__acquires(hctx->srcu)
 {
 {
 	if (!(hctx->flags & BLK_MQ_F_BLOCKING)) {
 	if (!(hctx->flags & BLK_MQ_F_BLOCKING)) {
 		/* shut up gcc false positive */
 		/* shut up gcc false positive */