xref: /openbmc/linux/drivers/mmc/core/queue.h (revision 762f99f4f3cb41a775b5157dd761217beba65873)
1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */
2f397c8d8SUlf Hansson #ifndef MMC_QUEUE_H
3f397c8d8SUlf Hansson #define MMC_QUEUE_H
4f397c8d8SUlf Hansson 
5066185d6SUlf Hansson #include <linux/types.h>
6066185d6SUlf Hansson #include <linux/blkdev.h>
7304419d8SLinus Walleij #include <linux/blk-mq.h>
8066185d6SUlf Hansson #include <linux/mmc/core.h>
9066185d6SUlf Hansson #include <linux/mmc/host.h>
10066185d6SUlf Hansson 
1181196976SAdrian Hunter enum mmc_issued {
1281196976SAdrian Hunter 	MMC_REQ_STARTED,
1381196976SAdrian Hunter 	MMC_REQ_BUSY,
1481196976SAdrian Hunter 	MMC_REQ_FAILED_TO_START,
1581196976SAdrian Hunter 	MMC_REQ_FINISHED,
1681196976SAdrian Hunter };
1781196976SAdrian Hunter 
1881196976SAdrian Hunter enum mmc_issue_type {
1981196976SAdrian Hunter 	MMC_ISSUE_SYNC,
201e8e55b6SAdrian Hunter 	MMC_ISSUE_DCMD,
2181196976SAdrian Hunter 	MMC_ISSUE_ASYNC,
2281196976SAdrian Hunter 	MMC_ISSUE_MAX,
2381196976SAdrian Hunter };
2481196976SAdrian Hunter 
req_to_mmc_queue_req(struct request * rq)25304419d8SLinus Walleij static inline struct mmc_queue_req *req_to_mmc_queue_req(struct request *rq)
26304419d8SLinus Walleij {
27304419d8SLinus Walleij 	return blk_mq_rq_to_pdu(rq);
28304419d8SLinus Walleij }
29304419d8SLinus Walleij 
3067e69d52SLinus Walleij struct mmc_queue_req;
3167e69d52SLinus Walleij 
mmc_queue_req_to_req(struct mmc_queue_req * mqr)3267e69d52SLinus Walleij static inline struct request *mmc_queue_req_to_req(struct mmc_queue_req *mqr)
3367e69d52SLinus Walleij {
3467e69d52SLinus Walleij 	return blk_mq_rq_from_pdu(mqr);
3567e69d52SLinus Walleij }
3667e69d52SLinus Walleij 
37f397c8d8SUlf Hansson struct mmc_blk_data;
38614f0388SLinus Walleij struct mmc_blk_ioc_data;
39f397c8d8SUlf Hansson 
40f397c8d8SUlf Hansson struct mmc_blk_request {
41f397c8d8SUlf Hansson 	struct mmc_request	mrq;
42f397c8d8SUlf Hansson 	struct mmc_command	sbc;
43f397c8d8SUlf Hansson 	struct mmc_command	cmd;
44f397c8d8SUlf Hansson 	struct mmc_command	stop;
45f397c8d8SUlf Hansson 	struct mmc_data		data;
46f397c8d8SUlf Hansson };
47f397c8d8SUlf Hansson 
4802166a01SLinus Walleij /**
4902166a01SLinus Walleij  * enum mmc_drv_op - enumerates the operations in the mmc_queue_req
5002166a01SLinus Walleij  * @MMC_DRV_OP_IOCTL: ioctl operation
5197548575SLinus Walleij  * @MMC_DRV_OP_IOCTL_RPMB: RPMB-oriented ioctl operation
520493f6feSLinus Walleij  * @MMC_DRV_OP_BOOT_WP: write protect boot partitions
53627c3ccfSLinus Walleij  * @MMC_DRV_OP_GET_CARD_STATUS: get card status
54627c3ccfSLinus Walleij  * @MMC_DRV_OP_GET_EXT_CSD: get the EXT CSD from an eMMC card
5502166a01SLinus Walleij  */
5602166a01SLinus Walleij enum mmc_drv_op {
5702166a01SLinus Walleij 	MMC_DRV_OP_IOCTL,
5897548575SLinus Walleij 	MMC_DRV_OP_IOCTL_RPMB,
590493f6feSLinus Walleij 	MMC_DRV_OP_BOOT_WP,
60627c3ccfSLinus Walleij 	MMC_DRV_OP_GET_CARD_STATUS,
61627c3ccfSLinus Walleij 	MMC_DRV_OP_GET_EXT_CSD,
6202166a01SLinus Walleij };
6302166a01SLinus Walleij 
64f397c8d8SUlf Hansson struct mmc_queue_req {
65f397c8d8SUlf Hansson 	struct mmc_blk_request	brq;
66f397c8d8SUlf Hansson 	struct scatterlist	*sg;
6702166a01SLinus Walleij 	enum mmc_drv_op		drv_op;
680493f6feSLinus Walleij 	int			drv_op_result;
6969f7599eSLinus Walleij 	void			*drv_op_data;
703ecd8cf2SLinus Walleij 	unsigned int		ioc_count;
7181196976SAdrian Hunter 	int			retries;
72f397c8d8SUlf Hansson };
73f397c8d8SUlf Hansson 
74f397c8d8SUlf Hansson struct mmc_queue {
75f397c8d8SUlf Hansson 	struct mmc_card		*card;
7681196976SAdrian Hunter 	struct mmc_ctx		ctx;
7781196976SAdrian Hunter 	struct blk_mq_tag_set	tag_set;
78f397c8d8SUlf Hansson 	struct mmc_blk_data	*blkdata;
79f397c8d8SUlf Hansson 	struct request_queue	*queue;
80f5d72c5cSChristoph Hellwig 	spinlock_t		lock;
8181196976SAdrian Hunter 	int			in_flight[MMC_ISSUE_MAX];
821e8e55b6SAdrian Hunter 	unsigned int		cqe_busy;
831e8e55b6SAdrian Hunter #define MMC_CQE_DCMD_BUSY	BIT(0)
8426caddf2SAdrian Hunter 	bool			busy;
851e8e55b6SAdrian Hunter 	bool			recovery_needed;
861e8e55b6SAdrian Hunter 	bool			in_recovery;
8781196976SAdrian Hunter 	bool			rw_wait;
8881196976SAdrian Hunter 	bool			waiting;
891e8e55b6SAdrian Hunter 	struct work_struct	recovery_work;
9081196976SAdrian Hunter 	wait_queue_head_t	wait;
9110f21df4SAdrian Hunter 	struct request		*recovery_req;
9281196976SAdrian Hunter 	struct request		*complete_req;
9381196976SAdrian Hunter 	struct mutex		complete_lock;
9481196976SAdrian Hunter 	struct work_struct	complete_work;
95f397c8d8SUlf Hansson };
96f397c8d8SUlf Hansson 
97*607d968aSChristoph Hellwig struct gendisk *mmc_init_queue(struct mmc_queue *mq, struct mmc_card *card);
98f397c8d8SUlf Hansson extern void mmc_cleanup_queue(struct mmc_queue *);
99f397c8d8SUlf Hansson extern void mmc_queue_suspend(struct mmc_queue *);
100f397c8d8SUlf Hansson extern void mmc_queue_resume(struct mmc_queue *);
101f397c8d8SUlf Hansson extern unsigned int mmc_queue_map_sg(struct mmc_queue *,
102f397c8d8SUlf Hansson 				     struct mmc_queue_req *);
103f397c8d8SUlf Hansson 
1041e8e55b6SAdrian Hunter void mmc_cqe_check_busy(struct mmc_queue *mq);
1051e8e55b6SAdrian Hunter void mmc_cqe_recovery_notifier(struct mmc_request *mrq);
1061e8e55b6SAdrian Hunter 
10781196976SAdrian Hunter enum mmc_issue_type mmc_issue_type(struct mmc_queue *mq, struct request *req);
10881196976SAdrian Hunter 
mmc_tot_in_flight(struct mmc_queue * mq)10981196976SAdrian Hunter static inline int mmc_tot_in_flight(struct mmc_queue *mq)
11081196976SAdrian Hunter {
11181196976SAdrian Hunter 	return mq->in_flight[MMC_ISSUE_SYNC] +
1121e8e55b6SAdrian Hunter 	       mq->in_flight[MMC_ISSUE_DCMD] +
1131e8e55b6SAdrian Hunter 	       mq->in_flight[MMC_ISSUE_ASYNC];
1141e8e55b6SAdrian Hunter }
1151e8e55b6SAdrian Hunter 
mmc_cqe_qcnt(struct mmc_queue * mq)1161e8e55b6SAdrian Hunter static inline int mmc_cqe_qcnt(struct mmc_queue *mq)
1171e8e55b6SAdrian Hunter {
1181e8e55b6SAdrian Hunter 	return mq->in_flight[MMC_ISSUE_DCMD] +
11981196976SAdrian Hunter 	       mq->in_flight[MMC_ISSUE_ASYNC];
12081196976SAdrian Hunter }
12181196976SAdrian Hunter 
122f397c8d8SUlf Hansson #endif
123