2014-10-28 09:58:25 +01:00
|
|
|
/*
|
|
|
|
* Copyright 2010 ChaN
|
2016-03-23 18:31:03 +01:00
|
|
|
* Copyright 2016 INRIA
|
2014-10-28 09:58:25 +01:00
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2013-11-27 16:28:31 +01:00
|
|
|
/**
|
2015-11-19 17:13:33 +01:00
|
|
|
* @defgroup drivers_diskio Disk IO Driver
|
2017-02-07 11:16:38 +01:00
|
|
|
* @ingroup drivers_storage
|
2013-11-27 17:54:30 +01:00
|
|
|
* @brief Low level disk interface
|
2014-02-11 18:15:43 +01:00
|
|
|
*
|
2013-11-27 17:54:30 +01:00
|
|
|
* @{
|
|
|
|
*
|
2015-05-22 07:34:41 +02:00
|
|
|
* @file
|
2013-11-27 17:54:30 +01:00
|
|
|
*
|
2016-03-23 18:31:03 +01:00
|
|
|
* @author Oliver Hahm <oliver.hahm@inria.fr>
|
2013-11-27 16:28:31 +01:00
|
|
|
*/
|
|
|
|
|
2017-01-18 13:00:05 +01:00
|
|
|
#ifndef DISKIO_H
|
|
|
|
#define DISKIO_H
|
2011-12-12 17:50:22 +01:00
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/* These functions are defined in asmfunc.S */
|
2011-12-12 17:50:22 +01:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Copy aligned to unaligned
|
2016-03-23 18:31:03 +01:00
|
|
|
*
|
|
|
|
* @param[out] dst Pointer to unaligned destination address
|
|
|
|
* @param[in] src Pointer to aligned source address
|
|
|
|
* @param[in] count Number of bytes to copy
|
2011-12-12 17:50:22 +01:00
|
|
|
*/
|
2016-03-23 18:31:03 +01:00
|
|
|
void copy_al2un(unsigned char *dst, const unsigned long *src, int count);
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Copy unaligned to aligned
|
2016-03-23 18:31:03 +01:00
|
|
|
*
|
|
|
|
* @param[out] dst Pointer to unaligned destination address
|
|
|
|
* @param[in] src Pointer to aligned source address
|
|
|
|
* @param[in] count Number of bytes to copy
|
|
|
|
*/
|
|
|
|
void copy_un2al(unsigned long *dst, const unsigned char *src, int count);
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/** Results of Disk Functions */
|
2011-12-12 17:50:22 +01:00
|
|
|
typedef enum {
|
2016-03-23 18:31:03 +01:00
|
|
|
DISKIO_RES_OK = 0, /**< 0: Successful */
|
|
|
|
DISKIO_RES_ERROR, /**< 1: R/W Error */
|
|
|
|
DISKIO_RES_WRPRT, /**< 2: Write Protected */
|
|
|
|
DISKIO_RES_NOTRDY, /**< 3: Not Ready */
|
|
|
|
DISKIO_RES_PARERR /**< 4: Invalid Parameter */
|
|
|
|
} diskio_result_t;
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Disk Status Bits
|
2016-03-23 18:31:03 +01:00
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
DISKIO_STA_NOINIT = 0x01, /**< Drive not initialized */
|
|
|
|
DISKIO_STA_NODISK = 0x02, /**< No medium in the drive */
|
|
|
|
DISKIO_STA_PROTECT = 0x04 /**< Write protected */
|
|
|
|
} diskio_sta_t;
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/**
|
2019-09-14 15:47:10 +02:00
|
|
|
* @name Command code for disk_ioctrl function
|
2016-03-23 18:31:03 +01:00
|
|
|
* @{
|
|
|
|
*/
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/**
|
|
|
|
* @name Generic ioctl command (defined for FatFs)
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define CTRL_SYNC 0 /**< Flush disk cache (for write functions) */
|
|
|
|
#define GET_SECTOR_COUNT 1 /**< Get media size (for only f_mkfs()) */
|
|
|
|
#define GET_SECTOR_SIZE 2 /**< Get sector size (for multiple sector size (_MAX_SS >= 1024)) */
|
|
|
|
#define GET_BLOCK_SIZE 3 /**< Get erase block size (for only f_mkfs()) */
|
|
|
|
#define CTRL_ERASE_SECTOR 4 /**< Force erased a block of sectors (for only _USE_ERASE) */
|
|
|
|
/** @} */
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @name Generic ioctl command
|
2016-03-23 18:31:03 +01:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define CTRL_POWER 5 /**< Get/Set power status */
|
|
|
|
#define CTRL_LOCK 6 /**< Lock/Unlock media removal */
|
|
|
|
#define CTRL_EJECT 7 /**< Eject media */
|
|
|
|
/** @} */
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @name MMC/SDC specific ioctl command
|
2016-03-23 18:31:03 +01:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define MMC_GET_TYPE 10 /**< Get card type */
|
|
|
|
#define MMC_GET_CSD 11 /**< Get CSD */
|
|
|
|
#define MMC_GET_CID 12 /**< Get CID */
|
|
|
|
#define MMC_GET_OCR 13 /**< Get OCR */
|
|
|
|
#define MMC_GET_SDSTAT 14 /**< Get SD status */
|
|
|
|
/** @} */
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/** @} */
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Initialize media control interface (MCI)
|
2016-03-23 18:31:03 +01:00
|
|
|
*
|
|
|
|
* @returns 0 on success
|
|
|
|
* @returns a @ref diskio_sta_t value on error
|
|
|
|
*/
|
|
|
|
diskio_sta_t mci_initialize(void);
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Get the status of the media control interface (MCI)
|
2016-03-23 18:31:03 +01:00
|
|
|
*
|
|
|
|
* @returns 0 on success
|
|
|
|
* @returns a @ref diskio_sta_t value on error
|
|
|
|
*/
|
|
|
|
diskio_sta_t mci_status(void);
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Read sectors over the media control interface (MCI)
|
2016-03-23 18:31:03 +01:00
|
|
|
*
|
|
|
|
* @param[out] buff Pointer to the data buffer to store read data
|
|
|
|
* @param[in] sector Start sector number (LBA)
|
|
|
|
* @param[in] count Sector count (1..127)
|
|
|
|
*
|
|
|
|
* @return @ref DISKIO_RES_OK on success
|
|
|
|
* @return any other @ref diskio_result_t value on error
|
|
|
|
*/
|
|
|
|
diskio_result_t mci_read(unsigned char *buff, unsigned long sector, unsigned char count);
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Write sectors over the media control interface (MCI)
|
2016-03-23 18:31:03 +01:00
|
|
|
* @param[in] buff Pointer to the data to be written
|
|
|
|
* @param[in] sector Start sector number (LBA)
|
|
|
|
* @param[in] count Sector count (1..127)
|
|
|
|
*
|
|
|
|
* @return @ref DISKIO_RES_OK on success
|
|
|
|
* @return any other @ref diskio_result_t value on error
|
|
|
|
*/
|
|
|
|
diskio_result_t mci_write(const unsigned char *buff, unsigned long sector, unsigned char count);
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2016-03-23 18:31:03 +01:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief IOCTL functions for the media control interface (MCI)
|
2016-03-23 18:31:03 +01:00
|
|
|
*
|
|
|
|
* @param[in] ctrl Control code
|
|
|
|
* @param[in,out] buff Buffer to send/receive data block
|
|
|
|
*
|
|
|
|
* @return @ref DISKIO_RES_OK on success
|
|
|
|
* @return any other @ref diskio_result_t value on error
|
|
|
|
*/
|
|
|
|
diskio_result_t mci_ioctl(unsigned char ctrl, void *buff);
|
2011-12-12 17:50:22 +01:00
|
|
|
|
2014-10-13 15:49:17 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-01-18 13:00:05 +01:00
|
|
|
#endif /* DISKIO_H */
|
2017-08-29 18:00:46 +02:00
|
|
|
/** @} */
|