1 /* SPDX-License-Identifier: GPL-2.0 */
3 #ifndef _BLOCK_BLK_PM_H_
4 #define _BLOCK_BLK_PM_H_
6 #include <linux/pm_runtime.h>
9 static inline void blk_pm_request_resume(struct request_queue
*q
)
11 if (q
->dev
&& (q
->rpm_status
== RPM_SUSPENDED
||
12 q
->rpm_status
== RPM_SUSPENDING
))
13 pm_request_resume(q
->dev
);
16 static inline void blk_pm_mark_last_busy(struct request
*rq
)
18 if (rq
->q
->dev
&& !(rq
->rq_flags
& RQF_PM
))
19 pm_runtime_mark_last_busy(rq
->q
->dev
);
22 static inline void blk_pm_requeue_request(struct request
*rq
)
24 lockdep_assert_held(&rq
->q
->queue_lock
);
26 if (rq
->q
->dev
&& !(rq
->rq_flags
& RQF_PM
))
30 static inline void blk_pm_add_request(struct request_queue
*q
,
33 lockdep_assert_held(&q
->queue_lock
);
35 if (q
->dev
&& !(rq
->rq_flags
& RQF_PM
))
39 static inline void blk_pm_put_request(struct request
*rq
)
41 lockdep_assert_held(&rq
->q
->queue_lock
);
43 if (rq
->q
->dev
&& !(rq
->rq_flags
& RQF_PM
))
47 static inline void blk_pm_request_resume(struct request_queue
*q
)
51 static inline void blk_pm_mark_last_busy(struct request
*rq
)
55 static inline void blk_pm_requeue_request(struct request
*rq
)
59 static inline void blk_pm_add_request(struct request_queue
*q
,
64 static inline void blk_pm_put_request(struct request
*rq
)
69 #endif /* _BLOCK_BLK_PM_H_ */