178 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			178 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* -----------------------------------------------------------------------------
 | |
|  * Copyright (c) 2013-2015 ARM Ltd.
 | |
|  *
 | |
|  * This software is provided 'as-is', without any express or implied warranty.
 | |
|  * In no event will the authors be held liable for any damages arising from
 | |
|  * the use of this software. Permission is granted to anyone to use this
 | |
|  * software for any purpose, including commercial applications, and to alter
 | |
|  * it and redistribute it freely, subject to the following restrictions:
 | |
|  *
 | |
|  * 1. The origin of this software must not be misrepresented; you must not
 | |
|  *    claim that you wrote the original software. If you use this software in
 | |
|  *    a product, an acknowledgment in the product documentation would be
 | |
|  *    appreciated but is not required.
 | |
|  *
 | |
|  * 2. Altered source versions must be plainly marked as such, and must not be
 | |
|  *    misrepresented as being the original software.
 | |
|  *
 | |
|  * 3. This notice may not be removed or altered from any source distribution.
 | |
|  *
 | |
|  *
 | |
|  * $Date:        22. September 2015
 | |
|  * $Revision:    V2.0
 | |
|  *
 | |
|  * Project:      MCI Driver Definitions for STMicroelectronics STM32F10x
 | |
|  * -------------------------------------------------------------------------- */
 | |
| 
 | |
| #ifndef __MCI_STM32F10X_H
 | |
| #define __MCI_STM32F10X_H
 | |
| 
 | |
| #include "stm32f10x.h"
 | |
| #include "GPIO_STM32F10x.h"
 | |
| #include "DMA_STM32F10x.h"
 | |
| 
 | |
| #include "Driver_MCI.h"
 | |
| 
 | |
| #include "RTE_Components.h"
 | |
| #include "RTE_Device.h"
 | |
| 
 | |
| #include <string.h>
 | |
| 
 | |
| 
 | |
| #if (defined(RTE_Drivers_MCI0) && (RTE_SDIO == 0))
 | |
|   #error "SDIO not configured in RTE_Device.h!"
 | |
| #endif
 | |
| 
 | |
| /* SDIO DMA */
 | |
| #define SDIO_DMA_Instance               DMAx_CHANNELy(RTE_SDIO_DMA_NUMBER, RTE_SDIO_DMA_CHANNEL)
 | |
| #define SDIO_DMA_Number                 RTE_SDIO_DMA_NUMBER
 | |
| #define SDIO_DMA_Channel                RTE_SDIO_DMA_CHANNEL
 | |
| #define SDIO_DMA_Priority               RTE_SDIO_DMA_PRIORITY
 | |
| #define SDIO_DMA_Handler                DMAx_CHANNELy_EVENT(RTE_SDIO_DMA_NUMBER, RTE_SDIO_DMA_CHANNEL)
 | |
| 
 | |
| #if (RTE_SDIO_BUS_WIDTH_4)
 | |
|   #define SDIO_D0_Pin                   1
 | |
|   #define SDIO_D1_Pin                   1
 | |
|   #define SDIO_D2_Pin                   1
 | |
|   #define SDIO_D3_Pin                   1
 | |
| #endif
 | |
| #if (RTE_SDIO_BUS_WIDTH_8)
 | |
|   #define SDIO_D4_Pin                   1
 | |
|   #define SDIO_D5_Pin                   1
 | |
|   #define SDIO_D6_Pin                   1
 | |
|   #define SDIO_D7_Pin                   1
 | |
| #endif
 | |
| 
 | |
| #if (RTE_SDIO_CD_EN)
 | |
|   #define MemoryCard_CD_Pin             1
 | |
|   #define MemoryCard_CD_GPIOx           RTE_SDIO_CD_PORT
 | |
|   #define MemoryCard_CD_GPIO_Pin        RTE_SDIO_CD_PIN
 | |
|   #define MemoryCard_CD_GPIO_PuPd     ((RTE_SDIO_CD_ACTIVE == 0) ? GPIO_IN_PULL_UP : GPIO_IN_PULL_DOWN)
 | |
|   #define MemoryCard_CD_Pin_Active    ((RTE_SDIO_CD_ACTIVE == 0) ? 0  : 1)
 | |
| #endif
 | |
| 
 | |
| #if (RTE_SDIO_WP_EN)
 | |
|   #define MemoryCard_WP_Pin             1
 | |
|   #define MemoryCard_WP_GPIOx           RTE_SDIO_WP_PORT
 | |
|   #define MemoryCard_WP_GPIO_Pin        RTE_SDIO_WP_PIN
 | |
|   #define MemoryCard_WP_GPIO_PuPd     ((RTE_SDIO_WP_ACTIVE == 0) ? GPIO_IN_PULL_UP : GPIO_IN_PULL_DOWN)
 | |
|   #define MemoryCard_WP_Pin_Active    ((RTE_SDIO_WP_ACTIVE == 0) ? 0  : 1)
 | |
| #endif
 | |
| 
 | |
| 
 | |
| /* Define 4-bit data bus width */
 | |
| #if defined(SDIO_D0_Pin) && defined(SDIO_D1_Pin) && defined(SDIO_D2_Pin) && defined(SDIO_D3_Pin)
 | |
|   #define MCI_BUS_WIDTH_4   1U
 | |
| #else
 | |
|   #define MCI_BUS_WIDTH_4   0U
 | |
| #endif
 | |
| 
 | |
| /* Define 8-bit data bus width */
 | |
| #if defined(SDIO_D0_Pin) && defined(SDIO_D1_Pin) && defined(SDIO_D2_Pin) && defined(SDIO_D3_Pin) && \
 | |
|     defined(SDIO_D4_Pin) && defined(SDIO_D5_Pin) && defined(SDIO_D6_Pin) && defined(SDIO_D7_Pin)
 | |
|   #define MCI_BUS_WIDTH_8   1U
 | |
| #else
 | |
|   #define MCI_BUS_WIDTH_8   0U
 | |
| #endif
 | |
| 
 | |
| /* Define Card Detect pin existence */
 | |
| #if defined(MemoryCard_CD_Pin)
 | |
|   #define MCI_CD_PIN        1U
 | |
| #else
 | |
|   #define MCI_CD_PIN        0U
 | |
| #endif
 | |
| 
 | |
| /* Define Write Protect pin existence */
 | |
| #if defined(MemoryCard_WP_Pin)
 | |
|   #define MCI_WP_PIN        1U
 | |
| #else
 | |
|   #define MCI_WP_PIN        0U
 | |
| #endif
 | |
| 
 | |
| /* SDIO Adapter Clock definition */
 | |
| #define SDIOCLK       (uint32_t)RTE_HCLK    /* SDIO adapter clock */
 | |
| 
 | |
| #ifndef SDIO_MASK_STBITERRIE
 | |
| #define SDIO_MASK_STBITERRIE    0U
 | |
| #endif
 | |
| #ifndef SDIO_STA_STBITERR
 | |
| #define SDIO_STA_STBITERR       0U
 | |
| #endif
 | |
| #ifndef SDIO_ICR_STBITERRC
 | |
| #define SDIO_ICR_STBITERRC      0U
 | |
| #endif
 | |
| 
 | |
| /* Interrupt clear Mask */
 | |
| #define SDIO_ICR_BIT_Msk       (SDIO_ICR_CCRCFAILC | \
 | |
|                                 SDIO_ICR_DCRCFAILC | \
 | |
|                                 SDIO_ICR_CTIMEOUTC | \
 | |
|                                 SDIO_ICR_DTIMEOUTC | \
 | |
|                                 SDIO_ICR_TXUNDERRC | \
 | |
|                                 SDIO_ICR_RXOVERRC  | \
 | |
|                                 SDIO_ICR_CMDRENDC  | \
 | |
|                                 SDIO_ICR_CMDSENTC  | \
 | |
|                                 SDIO_ICR_DATAENDC  | \
 | |
|                                 SDIO_ICR_STBITERRC | \
 | |
|                                 SDIO_ICR_DBCKENDC  | \
 | |
|                                 SDIO_ICR_SDIOITC)
 | |
| 
 | |
| /* Error interrupt mask */
 | |
| #define SDIO_STA_ERR_BIT_Msk   (SDIO_STA_CCRCFAIL | \
 | |
|                                 SDIO_STA_DCRCFAIL | \
 | |
|                                 SDIO_STA_CTIMEOUT | \
 | |
|                                 SDIO_STA_DTIMEOUT | \
 | |
|                                 SDIO_STA_STBITERR)
 | |
| 
 | |
| /* Driver flag definitions */
 | |
| #define MCI_INIT      ((uint8_t)0x01)   /* MCI initialized           */
 | |
| #define MCI_POWER     ((uint8_t)0x02)   /* MCI powered on            */
 | |
| #define MCI_SETUP     ((uint8_t)0x04)   /* MCI configured            */
 | |
| #define MCI_RESP_LONG ((uint8_t)0x08)   /* Long response expected    */
 | |
| #define MCI_RESP_CRC  ((uint8_t)0x10)   /* Check response CRC error  */
 | |
| #define MCI_DATA_XFER ((uint8_t)0x20)   /* Transfer data             */
 | |
| #define MCI_DATA_READ ((uint8_t)0x40)   /* Read transfer             */
 | |
| #define MCI_READ_WAIT ((uint8_t)0x80)   /* Read wait operation start */
 | |
| 
 | |
| #define MCI_RESPONSE_EXPECTED_Msk (ARM_MCI_RESPONSE_SHORT      | \
 | |
|                                    ARM_MCI_RESPONSE_SHORT_BUSY | \
 | |
|                                    ARM_MCI_RESPONSE_LONG)
 | |
| 
 | |
| /* MCI Transfer Information Definition */
 | |
| typedef struct _MCI_XFER {
 | |
|   uint8_t *buf;                         /* Data buffer                        */
 | |
|   uint32_t cnt;                         /* Data bytes to transfer             */
 | |
| } MCI_XFER;
 | |
| 
 | |
| /* MCI Driver State Definition */
 | |
| typedef struct _MCI_INFO {
 | |
|   ARM_MCI_SignalEvent_t cb_event;       /* Driver event callback function     */
 | |
|   ARM_MCI_STATUS        status;         /* Driver status                      */
 | |
|   uint32_t             *response;       /* Pointer to response buffer         */
 | |
|   MCI_XFER              xfer;           /* Data transfer description          */
 | |
|   uint8_t volatile      flags;          /* Driver state flags                 */
 | |
|   uint32_t              dctrl;          /* Data control register value        */
 | |
|   uint32_t              dlen;           /* Data length register value         */
 | |
| } MCI_INFO;
 | |
| 
 | |
| #endif /* __MCI_STM32F10X_H */
 |