blob: 8a5a0d4b357fe3f70573ff1041df403c5cc40cb4 [file] [log] [blame]
Bart Van Asschebca6b062018-09-26 14:01:03 -07001/* SPDX-License-Identifier: GPL-2.0 */
2
3#ifndef _BLOCK_BLK_PM_H_
4#define _BLOCK_BLK_PM_H_
5
6#include <linux/pm_runtime.h>
7
8#ifdef CONFIG_PM
Alan Stern52abca62020-12-08 21:29:51 -08009static inline int blk_pm_resume_queue(const bool pm, struct request_queue *q)
Bart Van Assche154b00d2018-09-26 14:01:05 -070010{
Alan Stern52abca62020-12-08 21:29:51 -080011 if (!q->dev || !blk_queue_pm_only(q))
12 return 1; /* Nothing to do */
13 if (pm && q->rpm_status != RPM_SUSPENDED)
14 return 1; /* Request allowed */
15 pm_request_resume(q->dev);
16 return 0;
Bart Van Assche154b00d2018-09-26 14:01:05 -070017}
18
19static inline void blk_pm_mark_last_busy(struct request *rq)
20{
21 if (rq->q->dev && !(rq->rq_flags & RQF_PM))
22 pm_runtime_mark_last_busy(rq->q->dev);
23}
Bart Van Asschebca6b062018-09-26 14:01:03 -070024#else
Alan Stern52abca62020-12-08 21:29:51 -080025static inline int blk_pm_resume_queue(const bool pm, struct request_queue *q)
Bart Van Assche154b00d2018-09-26 14:01:05 -070026{
Alan Stern52abca62020-12-08 21:29:51 -080027 return 1;
Bart Van Assche154b00d2018-09-26 14:01:05 -070028}
29
30static inline void blk_pm_mark_last_busy(struct request *rq)
31{
32}
Bart Van Asschebca6b062018-09-26 14:01:03 -070033#endif
34
35#endif /* _BLOCK_BLK_PM_H_ */