1da61fa5fSPaul Burton /* 2da61fa5fSPaul Burton * Copyright 2008,2010 Freescale Semiconductor, Inc 3da61fa5fSPaul Burton * Andy Fleming 4da61fa5fSPaul Burton * 5da61fa5fSPaul Burton * Based (loosely) on the Linux code 6da61fa5fSPaul Burton * 7da61fa5fSPaul Burton * SPDX-License-Identifier: GPL-2.0+ 8da61fa5fSPaul Burton */ 9da61fa5fSPaul Burton 10da61fa5fSPaul Burton #ifndef _MMC_PRIVATE_H_ 11da61fa5fSPaul Burton #define _MMC_PRIVATE_H_ 12da61fa5fSPaul Burton 13da61fa5fSPaul Burton #include <mmc.h> 14da61fa5fSPaul Burton 15da61fa5fSPaul Burton extern int mmc_send_cmd(struct mmc *mmc, struct mmc_cmd *cmd, 16da61fa5fSPaul Burton struct mmc_data *data); 17da61fa5fSPaul Burton extern int mmc_send_status(struct mmc *mmc, int timeout); 18da61fa5fSPaul Burton extern int mmc_set_blocklen(struct mmc *mmc, int len); 195a8dbdc6SYangbo Lu #ifdef CONFIG_FSL_ESDHC_ADAPTER_IDENT 205a8dbdc6SYangbo Lu void mmc_adapter_card_type_ident(void); 215a8dbdc6SYangbo Lu #endif 22da61fa5fSPaul Burton 23da61fa5fSPaul Burton #ifndef CONFIG_SPL_BUILD 24da61fa5fSPaul Burton 254101f687SSimon Glass unsigned long mmc_berase(struct blk_desc *block_dev, lbaint_t start, 267c4213f6SStephen Warren lbaint_t blkcnt); 27da61fa5fSPaul Burton 284101f687SSimon Glass unsigned long mmc_bwrite(struct blk_desc *block_dev, lbaint_t start, 297c4213f6SStephen Warren lbaint_t blkcnt, const void *src); 30da61fa5fSPaul Burton 31da61fa5fSPaul Burton #else /* CONFIG_SPL_BUILD */ 32da61fa5fSPaul Burton 33da61fa5fSPaul Burton /* SPL will never write or erase, declare dummies to reduce code size. */ 34da61fa5fSPaul Burton 354101f687SSimon Glass static inline unsigned long mmc_berase(struct blk_desc *block_dev, 367c4213f6SStephen Warren lbaint_t start, lbaint_t blkcnt) 37da61fa5fSPaul Burton { 38da61fa5fSPaul Burton return 0; 39da61fa5fSPaul Burton } 40da61fa5fSPaul Burton 414101f687SSimon Glass static inline ulong mmc_bwrite(struct blk_desc *block_dev, lbaint_t start, 427c4213f6SStephen Warren lbaint_t blkcnt, const void *src) 43da61fa5fSPaul Burton { 44da61fa5fSPaul Burton return 0; 45da61fa5fSPaul Burton } 46da61fa5fSPaul Burton 47da61fa5fSPaul Burton #endif /* CONFIG_SPL_BUILD */ 48da61fa5fSPaul Burton 49*c40fdca6SSimon Glass /** 50*c40fdca6SSimon Glass * mmc_get_next_devnum() - Get the next available MMC device number 51*c40fdca6SSimon Glass * 52*c40fdca6SSimon Glass * @return next available device number (0 = first), or -ve on error 53*c40fdca6SSimon Glass */ 54*c40fdca6SSimon Glass int mmc_get_next_devnum(void); 55*c40fdca6SSimon Glass 56*c40fdca6SSimon Glass /** 57*c40fdca6SSimon Glass * mmc_do_preinit() - Get an MMC device ready for use 58*c40fdca6SSimon Glass */ 59*c40fdca6SSimon Glass void mmc_do_preinit(void); 60*c40fdca6SSimon Glass 61*c40fdca6SSimon Glass /** 62*c40fdca6SSimon Glass * mmc_list_init() - Set up the list of MMC devices 63*c40fdca6SSimon Glass */ 64*c40fdca6SSimon Glass void mmc_list_init(void); 65*c40fdca6SSimon Glass 66*c40fdca6SSimon Glass /** 67*c40fdca6SSimon Glass * mmc_list_add() - Add a new MMC device to the list of devices 68*c40fdca6SSimon Glass * 69*c40fdca6SSimon Glass * @mmc: Device to add 70*c40fdca6SSimon Glass */ 71*c40fdca6SSimon Glass void mmc_list_add(struct mmc *mmc); 72*c40fdca6SSimon Glass 73da61fa5fSPaul Burton #endif /* _MMC_PRIVATE_H_ */ 74