xref: /openbmc/u-boot/drivers/mmc/mmc_private.h (revision e8f80a5a)
1*83d290c5STom Rini /* SPDX-License-Identifier: GPL-2.0+ */
2da61fa5fSPaul Burton /*
3da61fa5fSPaul Burton  * Copyright 2008,2010 Freescale Semiconductor, Inc
4da61fa5fSPaul Burton  * Andy Fleming
5da61fa5fSPaul Burton  *
6da61fa5fSPaul Burton  * Based (loosely) on the Linux code
7da61fa5fSPaul Burton  */
8da61fa5fSPaul Burton 
9da61fa5fSPaul Burton #ifndef _MMC_PRIVATE_H_
10da61fa5fSPaul Burton #define _MMC_PRIVATE_H_
11da61fa5fSPaul Burton 
12da61fa5fSPaul Burton #include <mmc.h>
13da61fa5fSPaul Burton 
14da61fa5fSPaul Burton extern int mmc_send_cmd(struct mmc *mmc, struct mmc_cmd *cmd,
15da61fa5fSPaul Burton 			struct mmc_data *data);
16da61fa5fSPaul Burton extern int mmc_send_status(struct mmc *mmc, int timeout);
17da61fa5fSPaul Burton extern int mmc_set_blocklen(struct mmc *mmc, int len);
185a8dbdc6SYangbo Lu #ifdef CONFIG_FSL_ESDHC_ADAPTER_IDENT
195a8dbdc6SYangbo Lu void mmc_adapter_card_type_ident(void);
205a8dbdc6SYangbo Lu #endif
21da61fa5fSPaul Burton 
22c4d660d4SSimon Glass #if CONFIG_IS_ENABLED(BLK)
237dba0b93SSimon Glass ulong mmc_bread(struct udevice *dev, lbaint_t start, lbaint_t blkcnt,
247dba0b93SSimon Glass 		void *dst);
257dba0b93SSimon Glass #else
267dba0b93SSimon Glass ulong mmc_bread(struct blk_desc *block_dev, lbaint_t start, lbaint_t blkcnt,
277dba0b93SSimon Glass 		void *dst);
287dba0b93SSimon Glass #endif
297dba0b93SSimon Glass 
30d6400c3fSJean-Jacques Hiblot #if CONFIG_IS_ENABLED(MMC_WRITE)
31da61fa5fSPaul Burton 
32c4d660d4SSimon Glass #if CONFIG_IS_ENABLED(BLK)
3333fb211dSSimon Glass ulong mmc_bwrite(struct udevice *dev, lbaint_t start, lbaint_t blkcnt,
3433fb211dSSimon Glass 		 const void *src);
35561e624cSSimon Glass ulong mmc_berase(struct udevice *dev, lbaint_t start, lbaint_t blkcnt);
3633fb211dSSimon Glass #else
3733fb211dSSimon Glass ulong mmc_bwrite(struct blk_desc *block_dev, lbaint_t start, lbaint_t blkcnt,
3833fb211dSSimon Glass 		 const void *src);
39561e624cSSimon Glass ulong mmc_berase(struct blk_desc *block_dev, lbaint_t start, lbaint_t blkcnt);
4033fb211dSSimon Glass #endif
41da61fa5fSPaul Burton 
42d6400c3fSJean-Jacques Hiblot #else /* CONFIG_SPL_MMC_WRITE is not defined */
43da61fa5fSPaul Burton 
44d2d9bdfcSB, Ravi /* declare dummies to reduce code size. */
45da61fa5fSPaul Burton 
46c4d660d4SSimon Glass #if CONFIG_IS_ENABLED(BLK)
mmc_berase(struct udevice * dev,lbaint_t start,lbaint_t blkcnt)47e419a3ecSSimon Glass static inline unsigned long mmc_berase(struct udevice *dev,
48e419a3ecSSimon Glass 				       lbaint_t start, lbaint_t blkcnt)
49e419a3ecSSimon Glass {
50e419a3ecSSimon Glass 	return 0;
51e419a3ecSSimon Glass }
52e419a3ecSSimon Glass 
mmc_bwrite(struct udevice * dev,lbaint_t start,lbaint_t blkcnt,const void * src)53e419a3ecSSimon Glass static inline ulong mmc_bwrite(struct udevice *dev, lbaint_t start,
54e419a3ecSSimon Glass 			       lbaint_t blkcnt, const void *src)
55e419a3ecSSimon Glass {
56e419a3ecSSimon Glass 	return 0;
57e419a3ecSSimon Glass }
58e419a3ecSSimon Glass #else
mmc_berase(struct blk_desc * block_dev,lbaint_t start,lbaint_t blkcnt)594101f687SSimon Glass static inline unsigned long mmc_berase(struct blk_desc *block_dev,
607c4213f6SStephen Warren 				       lbaint_t start, lbaint_t blkcnt)
61da61fa5fSPaul Burton {
62da61fa5fSPaul Burton 	return 0;
63da61fa5fSPaul Burton }
64da61fa5fSPaul Burton 
mmc_bwrite(struct blk_desc * block_dev,lbaint_t start,lbaint_t blkcnt,const void * src)654101f687SSimon Glass static inline ulong mmc_bwrite(struct blk_desc *block_dev, lbaint_t start,
667c4213f6SStephen Warren 			       lbaint_t blkcnt, const void *src)
67da61fa5fSPaul Burton {
68da61fa5fSPaul Burton 	return 0;
69da61fa5fSPaul Burton }
70e419a3ecSSimon Glass #endif
71da61fa5fSPaul Burton 
72da61fa5fSPaul Burton #endif /* CONFIG_SPL_BUILD */
73da61fa5fSPaul Burton 
74c0c76ebaSSimon Glass #ifdef CONFIG_MMC_TRACE
75c0c76ebaSSimon Glass void mmmc_trace_before_send(struct mmc *mmc, struct mmc_cmd *cmd);
76c0c76ebaSSimon Glass void mmmc_trace_after_send(struct mmc *mmc, struct mmc_cmd *cmd, int ret);
77c0c76ebaSSimon Glass void mmc_trace_state(struct mmc *mmc, struct mmc_cmd *cmd);
78c0c76ebaSSimon Glass #else
mmmc_trace_before_send(struct mmc * mmc,struct mmc_cmd * cmd)79c0c76ebaSSimon Glass static inline void mmmc_trace_before_send(struct mmc *mmc, struct mmc_cmd *cmd)
80c0c76ebaSSimon Glass {
81c0c76ebaSSimon Glass }
82c0c76ebaSSimon Glass 
mmmc_trace_after_send(struct mmc * mmc,struct mmc_cmd * cmd,int ret)83c0c76ebaSSimon Glass static inline void mmmc_trace_after_send(struct mmc *mmc, struct mmc_cmd *cmd,
84c0c76ebaSSimon Glass 					 int ret)
85c0c76ebaSSimon Glass {
86c0c76ebaSSimon Glass }
87c0c76ebaSSimon Glass 
mmc_trace_state(struct mmc * mmc,struct mmc_cmd * cmd)88c0c76ebaSSimon Glass static inline void mmc_trace_state(struct mmc *mmc, struct mmc_cmd *cmd)
89c0c76ebaSSimon Glass {
90c0c76ebaSSimon Glass }
91c0c76ebaSSimon Glass #endif
92c0c76ebaSSimon Glass 
93c40fdca6SSimon Glass /**
94c40fdca6SSimon Glass  * mmc_get_next_devnum() - Get the next available MMC device number
95c40fdca6SSimon Glass  *
96c40fdca6SSimon Glass  * @return next available device number (0 = first), or -ve on error
97c40fdca6SSimon Glass  */
98c40fdca6SSimon Glass int mmc_get_next_devnum(void);
99c40fdca6SSimon Glass 
100c40fdca6SSimon Glass /**
101c40fdca6SSimon Glass  * mmc_do_preinit() - Get an MMC device ready for use
102c40fdca6SSimon Glass  */
103c40fdca6SSimon Glass void mmc_do_preinit(void);
104c40fdca6SSimon Glass 
105c40fdca6SSimon Glass /**
106c40fdca6SSimon Glass  * mmc_list_init() - Set up the list of MMC devices
107c40fdca6SSimon Glass  */
108c40fdca6SSimon Glass void mmc_list_init(void);
109c40fdca6SSimon Glass 
110c40fdca6SSimon Glass /**
111c40fdca6SSimon Glass  * mmc_list_add() - Add a new MMC device to the list of devices
112c40fdca6SSimon Glass  *
113c40fdca6SSimon Glass  * @mmc:	Device to add
114c40fdca6SSimon Glass  */
115c40fdca6SSimon Glass void mmc_list_add(struct mmc *mmc);
116c40fdca6SSimon Glass 
1177dba0b93SSimon Glass /**
1187dba0b93SSimon Glass  * mmc_switch_part() - Switch to a new MMC hardware partition
1197dba0b93SSimon Glass  *
1207dba0b93SSimon Glass  * @mmc:	MMC device
1217dba0b93SSimon Glass  * @part_num:	Hardware partition number
1227dba0b93SSimon Glass  * @return 0 if OK, -ve on error
1237dba0b93SSimon Glass  */
1247dba0b93SSimon Glass int mmc_switch_part(struct mmc *mmc, unsigned int part_num);
1257dba0b93SSimon Glass 
126c40704f4SSimon Glass /**
127c40704f4SSimon Glass  * mmc_switch() - Issue and MMC switch mode command
128c40704f4SSimon Glass  *
129c40704f4SSimon Glass  * @mmc:	MMC device
130c40704f4SSimon Glass  * @set:	Unused
131c40704f4SSimon Glass  * @index:	Cmdarg index
132c40704f4SSimon Glass  * @value:	Cmdarg value
133c40704f4SSimon Glass  * @return 0 if OK, -ve on error
134c40704f4SSimon Glass  */
135c40704f4SSimon Glass int mmc_switch(struct mmc *mmc, u8 set, u8 index, u8 value);
136c40704f4SSimon Glass 
137da61fa5fSPaul Burton #endif /* _MMC_PRIVATE_H_ */
138