1 /* SPDX-License-Identifier: GPL-2.0 */
5 #include <linux/types.h>
6 #include <linux/blkdev.h>
7 #include <linux/blk-mq.h>
8 #include <linux/mmc/core.h>
9 #include <linux/mmc/host.h>
14 MMC_REQ_FAILED_TO_START,
25 static inline struct mmc_queue_req *req_to_mmc_queue_req(struct request *rq)
27 return blk_mq_rq_to_pdu(rq);
32 static inline struct request *mmc_queue_req_to_req(struct mmc_queue_req *mqr)
34 return blk_mq_rq_from_pdu(mqr);
38 struct mmc_blk_ioc_data;
40 struct mmc_blk_request {
41 struct mmc_request mrq;
42 struct mmc_command sbc;
43 struct mmc_command cmd;
44 struct mmc_command stop;
49 * enum mmc_drv_op - enumerates the operations in the mmc_queue_req
50 * @MMC_DRV_OP_IOCTL: ioctl operation
51 * @MMC_DRV_OP_IOCTL_RPMB: RPMB-oriented ioctl operation
52 * @MMC_DRV_OP_BOOT_WP: write protect boot partitions
53 * @MMC_DRV_OP_GET_CARD_STATUS: get card status
54 * @MMC_DRV_OP_GET_EXT_CSD: get the EXT CSD from an eMMC card
58 MMC_DRV_OP_IOCTL_RPMB,
60 MMC_DRV_OP_GET_CARD_STATUS,
61 MMC_DRV_OP_GET_EXT_CSD,
64 struct mmc_queue_req {
65 struct mmc_blk_request brq;
66 struct scatterlist *sg;
67 enum mmc_drv_op drv_op;
70 unsigned int ioc_count;
75 struct mmc_card *card;
77 struct blk_mq_tag_set tag_set;
78 struct mmc_blk_data *blkdata;
79 struct request_queue *queue;
81 int in_flight[MMC_ISSUE_MAX];
82 unsigned int cqe_busy;
83 #define MMC_CQE_DCMD_BUSY BIT(0)
89 struct work_struct recovery_work;
90 wait_queue_head_t wait;
91 struct request *recovery_req;
92 struct request *complete_req;
93 struct mutex complete_lock;
94 struct work_struct complete_work;
97 struct gendisk *mmc_init_queue(struct mmc_queue *mq, struct mmc_card *card);
98 extern void mmc_cleanup_queue(struct mmc_queue *);
99 extern void mmc_queue_suspend(struct mmc_queue *);
100 extern void mmc_queue_resume(struct mmc_queue *);
101 extern unsigned int mmc_queue_map_sg(struct mmc_queue *,
102 struct mmc_queue_req *);
104 void mmc_cqe_check_busy(struct mmc_queue *mq);
105 void mmc_cqe_recovery_notifier(struct mmc_request *mrq);
107 enum mmc_issue_type mmc_issue_type(struct mmc_queue *mq, struct request *req);
109 static inline int mmc_tot_in_flight(struct mmc_queue *mq)
111 return mq->in_flight[MMC_ISSUE_SYNC] +
112 mq->in_flight[MMC_ISSUE_DCMD] +
113 mq->in_flight[MMC_ISSUE_ASYNC];
116 static inline int mmc_cqe_qcnt(struct mmc_queue *mq)
118 return mq->in_flight[MMC_ISSUE_DCMD] +
119 mq->in_flight[MMC_ISSUE_ASYNC];