Subdirectory provided by Embedded Artists

Dependencies:   DM_FATFileSystem DM_HttpServer DM_USBHost EthernetInterface USBDevice mbed-rpc mbed-rtos mbed-src

Dependents:   lpc4088_displaymodule_hello_world_Sept_2018

Fork of DMSupport by Embedded Artists

Committer:
embeddedartists
Date:
Fri Nov 21 11:42:51 2014 +0000
Revision:
0:6b68dac0d986
Child:
9:a33326afd686
First version

Who changed what in which revision?

UserRevisionLine numberNew contents of line
embeddedartists 0:6b68dac0d986 1 /*
embeddedartists 0:6b68dac0d986 2 * Copyright 2013 Embedded Artists AB
embeddedartists 0:6b68dac0d986 3 *
embeddedartists 0:6b68dac0d986 4 * Licensed under the Apache License, Version 2.0 (the "License");
embeddedartists 0:6b68dac0d986 5 * you may not use this file except in compliance with the License.
embeddedartists 0:6b68dac0d986 6 * You may obtain a copy of the License at
embeddedartists 0:6b68dac0d986 7 *
embeddedartists 0:6b68dac0d986 8 * http://www.apache.org/licenses/LICENSE-2.0
embeddedartists 0:6b68dac0d986 9 *
embeddedartists 0:6b68dac0d986 10 * Unless required by applicable law or agreed to in writing, software
embeddedartists 0:6b68dac0d986 11 * distributed under the License is distributed on an "AS IS" BASIS,
embeddedartists 0:6b68dac0d986 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
embeddedartists 0:6b68dac0d986 13 * See the License for the specific language governing permissions and
embeddedartists 0:6b68dac0d986 14 * limitations under the License.
embeddedartists 0:6b68dac0d986 15 */
embeddedartists 0:6b68dac0d986 16
embeddedartists 0:6b68dac0d986 17 #ifndef MCIFILESYSTEM_H
embeddedartists 0:6b68dac0d986 18 #define MCIFILESYSTEM_H
embeddedartists 0:6b68dac0d986 19
embeddedartists 0:6b68dac0d986 20 #include "mbed.h"
embeddedartists 0:6b68dac0d986 21 #include "FATFileSystem.h"
embeddedartists 0:6b68dac0d986 22
embeddedartists 0:6b68dac0d986 23 /** Access the filesystem on an SD Card using MCI
embeddedartists 0:6b68dac0d986 24 *
embeddedartists 0:6b68dac0d986 25 * @code
embeddedartists 0:6b68dac0d986 26 * #include "mbed.h"
embeddedartists 0:6b68dac0d986 27 * #include "MCIFileSystem.h"
embeddedartists 0:6b68dac0d986 28 *
embeddedartists 0:6b68dac0d986 29 * MCIFileSystem mcifs("mci");
embeddedartists 0:6b68dac0d986 30 *
embeddedartists 0:6b68dac0d986 31 * int main() {
embeddedartists 0:6b68dac0d986 32 * printf("Please insert a SD/MMC card\n");
embeddedartists 0:6b68dac0d986 33 * while(!mcifs.cardInserted()) {
embeddedartists 0:6b68dac0d986 34 * wait(0.5);
embeddedartists 0:6b68dac0d986 35 * }
embeddedartists 0:6b68dac0d986 36 *
embeddedartists 0:6b68dac0d986 37 * printf("Found SD/MMC card, writing to /mci/myfile.txt ...\n");
embeddedartists 0:6b68dac0d986 38 *
embeddedartists 0:6b68dac0d986 39 * FILE *fp = fopen("/mci/myfile.txt", "w");
embeddedartists 0:6b68dac0d986 40 * if (fp != NULL) {
embeddedartists 0:6b68dac0d986 41 * fprintf(fp, "Hello World!\n");
embeddedartists 0:6b68dac0d986 42 * fclose(fp);
embeddedartists 0:6b68dac0d986 43 * printf("Wrote to /mci/myfile.txt\n");
embeddedartists 0:6b68dac0d986 44 * } else {
embeddedartists 0:6b68dac0d986 45 * printf("Failed to open /mci/myfile.txt\n");
embeddedartists 0:6b68dac0d986 46 * }
embeddedartists 0:6b68dac0d986 47 * }
embeddedartists 0:6b68dac0d986 48 * @endcode
embeddedartists 0:6b68dac0d986 49 */
embeddedartists 0:6b68dac0d986 50 class MCIFileSystem : public FATFileSystem {
embeddedartists 0:6b68dac0d986 51 public:
embeddedartists 0:6b68dac0d986 52
embeddedartists 0:6b68dac0d986 53 /** Create the File System for accessing an SD/MMC Card using MCI
embeddedartists 0:6b68dac0d986 54 *
embeddedartists 0:6b68dac0d986 55 * @param name The name used to access the virtual filesystem
embeddedartists 0:6b68dac0d986 56 * @param cd The pin connected to the CardDetect line
embeddedartists 0:6b68dac0d986 57 */
embeddedartists 0:6b68dac0d986 58 MCIFileSystem(const char* name, PinName cd = p38);
embeddedartists 0:6b68dac0d986 59
embeddedartists 0:6b68dac0d986 60 virtual ~MCIFileSystem();
embeddedartists 0:6b68dac0d986 61
embeddedartists 0:6b68dac0d986 62 virtual int disk_initialize();
embeddedartists 0:6b68dac0d986 63 virtual int disk_status();
embeddedartists 0:6b68dac0d986 64 virtual int disk_read(uint8_t * buffer, uint64_t block_number, uint8_t count);
embeddedartists 0:6b68dac0d986 65 virtual int disk_write(const uint8_t * buffer, uint64_t block_number, uint8_t count);
embeddedartists 0:6b68dac0d986 66 virtual int disk_sync();
embeddedartists 0:6b68dac0d986 67 virtual uint64_t disk_sectors();
embeddedartists 0:6b68dac0d986 68
embeddedartists 0:6b68dac0d986 69 void mci_MCIIRQHandler();
embeddedartists 0:6b68dac0d986 70 void mci_DMAIRQHandler();
embeddedartists 0:6b68dac0d986 71
embeddedartists 0:6b68dac0d986 72 /** Tests if a SD/MMC card is inserted or not.
embeddedartists 0:6b68dac0d986 73 *
embeddedartists 0:6b68dac0d986 74 * @returns
embeddedartists 0:6b68dac0d986 75 * True if a card has been inserted,
embeddedartists 0:6b68dac0d986 76 * False if no card is inserted or if the card detect pin is unavailable
embeddedartists 0:6b68dac0d986 77 */
embeddedartists 0:6b68dac0d986 78 bool cardInserted() const;
embeddedartists 0:6b68dac0d986 79
embeddedartists 0:6b68dac0d986 80 private:
embeddedartists 0:6b68dac0d986 81
embeddedartists 0:6b68dac0d986 82 typedef enum {
embeddedartists 0:6b68dac0d986 83 CardStatusNumBytes = 4,
embeddedartists 0:6b68dac0d986 84 } Constants;
embeddedartists 0:6b68dac0d986 85
embeddedartists 0:6b68dac0d986 86 typedef enum {
embeddedartists 0:6b68dac0d986 87 PowerOff = 0,
embeddedartists 0:6b68dac0d986 88 PowerUp = 2,
embeddedartists 0:6b68dac0d986 89 PowerOn = 3,
embeddedartists 0:6b68dac0d986 90 } power_ctrl_t;
embeddedartists 0:6b68dac0d986 91
embeddedartists 0:6b68dac0d986 92 typedef enum {
embeddedartists 0:6b68dac0d986 93 SDMMC_IDLE_ST = 0, /*!< Idle state */
embeddedartists 0:6b68dac0d986 94 SDMMC_READY_ST, /*!< Ready state */
embeddedartists 0:6b68dac0d986 95 SDMMC_IDENT_ST, /*!< Identification State */
embeddedartists 0:6b68dac0d986 96 SDMMC_STBY_ST, /*!< standby state */
embeddedartists 0:6b68dac0d986 97 SDMMC_TRAN_ST, /*!< transfer state */
embeddedartists 0:6b68dac0d986 98 SDMMC_DATA_ST, /*!< Sending-data State */
embeddedartists 0:6b68dac0d986 99 SDMMC_RCV_ST, /*!< Receive-data State */
embeddedartists 0:6b68dac0d986 100 SDMMC_PRG_ST, /*!< Programming State */
embeddedartists 0:6b68dac0d986 101 SDMMC_DIS_ST /*!< Disconnect State */
embeddedartists 0:6b68dac0d986 102 } CardState;
embeddedartists 0:6b68dac0d986 103
embeddedartists 0:6b68dac0d986 104
embeddedartists 0:6b68dac0d986 105 typedef struct {
embeddedartists 0:6b68dac0d986 106 uint8_t CmdIndex;
embeddedartists 0:6b68dac0d986 107 uint32_t Data[CardStatusNumBytes];
embeddedartists 0:6b68dac0d986 108 } response_t;
embeddedartists 0:6b68dac0d986 109
embeddedartists 0:6b68dac0d986 110 /**
embeddedartists 0:6b68dac0d986 111 * @brief SDC Clock Control Options
embeddedartists 0:6b68dac0d986 112 */
embeddedartists 0:6b68dac0d986 113 typedef enum {
embeddedartists 0:6b68dac0d986 114 SDC_CLOCK_ENABLE = 8, /*!< Enable SD Card Bus Clock */
embeddedartists 0:6b68dac0d986 115 SDC_CLOCK_POWER_SAVE = 9, /*!< Disable SD_CLK output when bus is idle */
embeddedartists 0:6b68dac0d986 116 SDC_CLOCK_DIVIDER_BYPASS = 10, /*!< Enable bypass of clock divide logic */
embeddedartists 0:6b68dac0d986 117 SDC_CLOCK_WIDEBUS_MODE = 11, /*!< Enable wide bus mode (SD_DAT[3:0] is used instead of SD_DAT[0]) */
embeddedartists 0:6b68dac0d986 118 } ClockControl;
embeddedartists 0:6b68dac0d986 119
embeddedartists 0:6b68dac0d986 120 /**
embeddedartists 0:6b68dac0d986 121 * @brief SD/MMC Card specific setup data structure
embeddedartists 0:6b68dac0d986 122 */
embeddedartists 0:6b68dac0d986 123 typedef struct {
embeddedartists 0:6b68dac0d986 124 uint32_t response[4]; /*!< Most recent response */
embeddedartists 0:6b68dac0d986 125 uint32_t cid[4]; /*!< CID of acquired card */
embeddedartists 0:6b68dac0d986 126 uint32_t csd[4]; /*!< CSD of acquired card */
embeddedartists 0:6b68dac0d986 127 uint32_t ext_csd[512 / 4]; /*!< Ext CSD */
embeddedartists 0:6b68dac0d986 128 uint32_t card_type; /*!< Card Type */
embeddedartists 0:6b68dac0d986 129 uint16_t rca; /*!< Relative address assigned to card */
embeddedartists 0:6b68dac0d986 130 uint32_t speed; /*!< Speed */
embeddedartists 0:6b68dac0d986 131 uint32_t block_len; /*!< Card sector size */
embeddedartists 0:6b68dac0d986 132 uint32_t device_size; /*!< Device Size */
embeddedartists 0:6b68dac0d986 133 uint32_t blocknr; /*!< Block Number */
embeddedartists 0:6b68dac0d986 134 uint32_t clk_rate; /*!< Clock rate */
embeddedartists 0:6b68dac0d986 135 } SDMMC_CARD_T;
embeddedartists 0:6b68dac0d986 136
embeddedartists 0:6b68dac0d986 137 typedef enum {
embeddedartists 0:6b68dac0d986 138 SDC_RET_OK = 0,
embeddedartists 0:6b68dac0d986 139 SDC_RET_CMD_FAILED = -1,
embeddedartists 0:6b68dac0d986 140 SDC_RET_BAD_PARAMETERS = -2,
embeddedartists 0:6b68dac0d986 141 SDC_RET_BUS_NOT_IDLE = -3,
embeddedartists 0:6b68dac0d986 142 SDC_RET_TIMEOUT = -4,
embeddedartists 0:6b68dac0d986 143 SDC_RET_ERR_STATE = -5,
embeddedartists 0:6b68dac0d986 144 SDC_RET_NOT_READY = -6,
embeddedartists 0:6b68dac0d986 145 SDC_RET_FAILED = -7,
embeddedartists 0:6b68dac0d986 146 } ReturnCode;
embeddedartists 0:6b68dac0d986 147
embeddedartists 0:6b68dac0d986 148 void initMCI();
embeddedartists 0:6b68dac0d986 149
embeddedartists 0:6b68dac0d986 150 int32_t mci_Acquire();
embeddedartists 0:6b68dac0d986 151 uint32_t mci_GetCardStatus() const;
embeddedartists 0:6b68dac0d986 152 CardState mci_GetCardState() const;
embeddedartists 0:6b68dac0d986 153 ReturnCode mci_ReadBlocks(void *buffer, int32_t startBlock, int32_t blockNum);
embeddedartists 0:6b68dac0d986 154 ReturnCode mci_WriteBlocks(void *buffer, int32_t startBlock, int32_t blockNum);
embeddedartists 0:6b68dac0d986 155 void mci_SetClock(uint32_t freq) const;
embeddedartists 0:6b68dac0d986 156 void mci_ClockControl(ClockControl ctrlType, bool enable) const;
embeddedartists 0:6b68dac0d986 157 void mci_PowerControl(power_ctrl_t powerMode, uint32_t flag) const;
embeddedartists 0:6b68dac0d986 158 ReturnCode mci_ExecuteCmd(uint32_t Command, uint32_t Arg, response_t* pResp) const;
embeddedartists 0:6b68dac0d986 159 ReturnCode mci_SendIfCond() const;
embeddedartists 0:6b68dac0d986 160 ReturnCode mci_SendOpCond(uint32_t *pOCR) const;
embeddedartists 0:6b68dac0d986 161 ReturnCode mci_SendAppOpCond(uint16_t rca, bool hcs, uint32_t *pOcr, bool *pCCS) const;
embeddedartists 0:6b68dac0d986 162 ReturnCode mci_GetCID(uint32_t *pCID) const;
embeddedartists 0:6b68dac0d986 163 ReturnCode mci_SetAddr(uint16_t addr) const;
embeddedartists 0:6b68dac0d986 164 ReturnCode mci_GetAddr(uint16_t *pRCA) const;
embeddedartists 0:6b68dac0d986 165 ReturnCode mci_GetCSD(uint16_t rca, uint32_t *pCSD) const;
embeddedartists 0:6b68dac0d986 166 ReturnCode mci_SelectCard(uint16_t addr) const;
embeddedartists 0:6b68dac0d986 167 ReturnCode mci_GetStatus(uint16_t rca, uint32_t *pStatus) const;
embeddedartists 0:6b68dac0d986 168 void mci_ProcessCSD();
embeddedartists 0:6b68dac0d986 169 ReturnCode mci_SetBusWidth(uint16_t rca, uint8_t width) const;
embeddedartists 0:6b68dac0d986 170 ReturnCode mci_SetTranState(uint16_t rca) const;
embeddedartists 0:6b68dac0d986 171 ReturnCode mci_SetBlockLength(uint32_t rca, uint32_t block_len) const;
embeddedartists 0:6b68dac0d986 172 ReturnCode mci_SetCardParams() const;
embeddedartists 0:6b68dac0d986 173 ReturnCode mci_StopTransmission(uint32_t rca) const;
embeddedartists 0:6b68dac0d986 174 bool mci_CheckR1Response(uint32_t resp, ReturnCode* pCheckResult) const;
embeddedartists 0:6b68dac0d986 175 void mci_WriteDelay() const;
embeddedartists 0:6b68dac0d986 176 ReturnCode mci_SendCmd(uint32_t Command, uint32_t Arg, uint32_t timeout) const;
embeddedartists 0:6b68dac0d986 177 ReturnCode mci_SendAppCmd(uint16_t rca) const;
embeddedartists 0:6b68dac0d986 178 void mci_SetDataTransfer(uint16_t BlockNum, bool DirFromCard, uint32_t Timeout) const;
embeddedartists 0:6b68dac0d986 179 void mci_GetResp(response_t* pResp) const;
embeddedartists 0:6b68dac0d986 180 uint32_t mci_GetBits(int32_t start, int32_t end, uint32_t *data) const;
embeddedartists 0:6b68dac0d986 181 void mci_SetCommand(uint32_t Cmd, uint32_t Arg) const;
embeddedartists 0:6b68dac0d986 182 void mci_ResetCommand() const;
embeddedartists 0:6b68dac0d986 183 int32_t mci_IRQHandler(uint8_t *txBuf, uint32_t *txCnt, uint8_t *rxBuf, uint32_t *rxCnt);
embeddedartists 0:6b68dac0d986 184 int32_t mci_FIFOIRQHandler(uint8_t *txBuf, uint32_t *txCnt, uint8_t *rxBuf, uint32_t *rxCnt);
embeddedartists 0:6b68dac0d986 185 void mci_ReadFIFO(uint32_t *pDst, bool bFirstHalf) const;
embeddedartists 0:6b68dac0d986 186 void mci_WriteFIFO(uint32_t *pSrc, bool bFirstHalf) const;
embeddedartists 0:6b68dac0d986 187
embeddedartists 0:6b68dac0d986 188 void mci_SetupEventWakeup(uint8_t dmaChannel);
embeddedartists 0:6b68dac0d986 189 uint32_t mci_WaitForEvent() const;
embeddedartists 0:6b68dac0d986 190
embeddedartists 0:6b68dac0d986 191 ReturnCode _readBlocks(uint32_t card_type, uint32_t startBlock, uint32_t blockNum) const;
embeddedartists 0:6b68dac0d986 192 ReturnCode _writeBlocks(uint32_t card_type, uint32_t startBlock, uint32_t blockNum) const;
embeddedartists 0:6b68dac0d986 193
embeddedartists 0:6b68dac0d986 194
embeddedartists 0:6b68dac0d986 195 uint32_t _Stat;
embeddedartists 0:6b68dac0d986 196 SDMMC_CARD_T _sdCardInfo;
embeddedartists 0:6b68dac0d986 197
embeddedartists 0:6b68dac0d986 198 DigitalIn* _cardDetect;
embeddedartists 0:6b68dac0d986 199
embeddedartists 0:6b68dac0d986 200 uint8_t _eventDmaChannel; /*!< DMA Channel used for transfer data */
embeddedartists 0:6b68dac0d986 201 volatile bool _eventReceived;
embeddedartists 0:6b68dac0d986 202 volatile bool _eventSuccess;
embeddedartists 0:6b68dac0d986 203 };
embeddedartists 0:6b68dac0d986 204
embeddedartists 0:6b68dac0d986 205 #endif
embeddedartists 0:6b68dac0d986 206