blob: 35170d03abb7f02f0745ee599db684972ed21b1f [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Paul Burtonda61fa52013-09-09 15:30:26 +01002/*
3 * Copyright 2008,2010 Freescale Semiconductor, Inc
4 * Andy Fleming
5 *
6 * Based (loosely) on the Linux code
Paul Burtonda61fa52013-09-09 15:30:26 +01007 */
8
9#ifndef _MMC_PRIVATE_H_
10#define _MMC_PRIVATE_H_
11
12#include <mmc.h>
13
Jean-Jacques Hiblot863d1002019-07-02 10:53:52 +020014int mmc_send_cmd(struct mmc *mmc, struct mmc_cmd *cmd, struct mmc_data *data);
15int mmc_send_status(struct mmc *mmc, unsigned int *status);
16int mmc_poll_for_busy(struct mmc *mmc, int timeout);
17
18int mmc_set_blocklen(struct mmc *mmc, int len);
Yangbo Lu5a8dbdc2015-04-22 13:57:00 +080019#ifdef CONFIG_FSL_ESDHC_ADAPTER_IDENT
20void mmc_adapter_card_type_ident(void);
21#endif
Paul Burtonda61fa52013-09-09 15:30:26 +010022
Simon Glassc4d660d2017-07-04 13:31:19 -060023#if CONFIG_IS_ENABLED(BLK)
Simon Glass7dba0b92016-06-12 23:30:15 -060024ulong mmc_bread(struct udevice *dev, lbaint_t start, lbaint_t blkcnt,
25 void *dst);
26#else
27ulong mmc_bread(struct blk_desc *block_dev, lbaint_t start, lbaint_t blkcnt,
28 void *dst);
29#endif
30
Jean-Jacques Hiblotd6400c32018-01-04 15:23:32 +010031#if CONFIG_IS_ENABLED(MMC_WRITE)
Paul Burtonda61fa52013-09-09 15:30:26 +010032
Simon Glassc4d660d2017-07-04 13:31:19 -060033#if CONFIG_IS_ENABLED(BLK)
Simon Glass33fb2112016-05-01 13:52:41 -060034ulong mmc_bwrite(struct udevice *dev, lbaint_t start, lbaint_t blkcnt,
35 const void *src);
Simon Glass561e6242016-10-01 14:43:17 -060036ulong mmc_berase(struct udevice *dev, lbaint_t start, lbaint_t blkcnt);
Simon Glass33fb2112016-05-01 13:52:41 -060037#else
38ulong mmc_bwrite(struct blk_desc *block_dev, lbaint_t start, lbaint_t blkcnt,
39 const void *src);
Simon Glass561e6242016-10-01 14:43:17 -060040ulong mmc_berase(struct blk_desc *block_dev, lbaint_t start, lbaint_t blkcnt);
Simon Glass33fb2112016-05-01 13:52:41 -060041#endif
Paul Burtonda61fa52013-09-09 15:30:26 +010042
Jean-Jacques Hiblotd6400c32018-01-04 15:23:32 +010043#else /* CONFIG_SPL_MMC_WRITE is not defined */
Paul Burtonda61fa52013-09-09 15:30:26 +010044
B, Ravid2d9bdf2016-09-28 14:46:18 +053045/* declare dummies to reduce code size. */
Paul Burtonda61fa52013-09-09 15:30:26 +010046
Simon Glassc4d660d2017-07-04 13:31:19 -060047#if CONFIG_IS_ENABLED(BLK)
Simon Glasse419a3e2016-05-14 14:03:09 -060048static inline unsigned long mmc_berase(struct udevice *dev,
49 lbaint_t start, lbaint_t blkcnt)
50{
51 return 0;
52}
53
54static inline ulong mmc_bwrite(struct udevice *dev, lbaint_t start,
55 lbaint_t blkcnt, const void *src)
56{
57 return 0;
58}
59#else
Simon Glass4101f682016-02-29 15:25:34 -070060static inline unsigned long mmc_berase(struct blk_desc *block_dev,
Stephen Warren7c4213f2015-12-07 11:38:48 -070061 lbaint_t start, lbaint_t blkcnt)
Paul Burtonda61fa52013-09-09 15:30:26 +010062{
63 return 0;
64}
65
Simon Glass4101f682016-02-29 15:25:34 -070066static inline ulong mmc_bwrite(struct blk_desc *block_dev, lbaint_t start,
Stephen Warren7c4213f2015-12-07 11:38:48 -070067 lbaint_t blkcnt, const void *src)
Paul Burtonda61fa52013-09-09 15:30:26 +010068{
69 return 0;
70}
Simon Glasse419a3e2016-05-14 14:03:09 -060071#endif
Paul Burtonda61fa52013-09-09 15:30:26 +010072
73#endif /* CONFIG_SPL_BUILD */
74
Simon Glassc0c76eb2016-06-12 23:30:20 -060075#ifdef CONFIG_MMC_TRACE
76void mmmc_trace_before_send(struct mmc *mmc, struct mmc_cmd *cmd);
77void mmmc_trace_after_send(struct mmc *mmc, struct mmc_cmd *cmd, int ret);
78void mmc_trace_state(struct mmc *mmc, struct mmc_cmd *cmd);
79#else
80static inline void mmmc_trace_before_send(struct mmc *mmc, struct mmc_cmd *cmd)
81{
82}
83
84static inline void mmmc_trace_after_send(struct mmc *mmc, struct mmc_cmd *cmd,
85 int ret)
86{
87}
88
89static inline void mmc_trace_state(struct mmc *mmc, struct mmc_cmd *cmd)
90{
91}
92#endif
93
Simon Glassc40fdca2016-05-01 13:52:35 -060094/**
95 * mmc_get_next_devnum() - Get the next available MMC device number
96 *
97 * @return next available device number (0 = first), or -ve on error
98 */
99int mmc_get_next_devnum(void);
100
101/**
102 * mmc_do_preinit() - Get an MMC device ready for use
103 */
104void mmc_do_preinit(void);
105
106/**
107 * mmc_list_init() - Set up the list of MMC devices
108 */
109void mmc_list_init(void);
110
111/**
112 * mmc_list_add() - Add a new MMC device to the list of devices
113 *
114 * @mmc: Device to add
115 */
116void mmc_list_add(struct mmc *mmc);
117
Simon Glass7dba0b92016-06-12 23:30:15 -0600118/**
119 * mmc_switch_part() - Switch to a new MMC hardware partition
120 *
121 * @mmc: MMC device
122 * @part_num: Hardware partition number
123 * @return 0 if OK, -ve on error
124 */
125int mmc_switch_part(struct mmc *mmc, unsigned int part_num);
126
Simon Glassc40704f2016-06-12 23:30:18 -0600127/**
128 * mmc_switch() - Issue and MMC switch mode command
129 *
130 * @mmc: MMC device
131 * @set: Unused
132 * @index: Cmdarg index
133 * @value: Cmdarg value
134 * @return 0 if OK, -ve on error
135 */
136int mmc_switch(struct mmc *mmc, u8 set, u8 index, u8 value);
137
Paul Burtonda61fa52013-09-09 15:30:26 +0100138#endif /* _MMC_PRIVATE_H_ */