mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-27 15:50:23 +08:00
69ad018bc0
1. Add SD card driver (SPI mode) 2. Add ELM ChaN FatFs support (Please read "Readme.txt") - Warning: FatFs is really FAT! (35KB) 3. Upgrade EFM32 libraries (CMSIS and efm32lib) to version 2.0.0 4. Merge all of the C source code in "libcpu\arm\cortex-m3\" into "cpuport.c" 5. Merge all of the assembly source code in "libcpu\arm\cortex-m3\" into "context_gcc.S" (except "start_gcc.S") git-svn-id: https://rt-thread.googlecode.com/svn/trunk@1525 bbd45198-f89e-11dd-88c7-29a3b14d5316
69 lines
2.8 KiB
C
69 lines
2.8 KiB
C
/******************************************************************//**
|
|
* @file drv_sdcard.h
|
|
* @brief Memory card driver (SPI mode) of RT-Thread RTOS for using EFM32 USART module
|
|
* COPYRIGHT (C) 2011, RT-Thread Development Team
|
|
* @author onelife
|
|
* @version 0.4 beta
|
|
**********************************************************************
|
|
* @section License
|
|
* The license and distribution terms for this file may be found in the file LICENSE in this
|
|
* distribution or at http://www.rt-thread.org/license/LICENSE
|
|
**********************************************************************
|
|
* @section Change Logs
|
|
* Date Author Notes
|
|
* 2011-05-13 onelife Initial creation for using EFM32 USART module
|
|
*********************************************************************/
|
|
#ifndef __DEV_SDCARD_H__
|
|
#define __DEV_SDCARD_H__
|
|
|
|
/* Includes -------------------------------------------------------------------*/
|
|
/* Exported types -------------------------------------------------------------*/
|
|
/* Exported constants ---------------------------------------------------------*/
|
|
/* Exported macro -------------------------------------------------------------*/
|
|
#define EFM32_SDCLK_LOW (100000)
|
|
#define EFM32_SDCLK_HIGH (EFM32_HFXO_FREQUENCY/2)
|
|
|
|
#define SD_SPEED_LOW (0)
|
|
#define SD_SPEED_HIGH (1)
|
|
#define SD_WAIT_PERIOD (RT_TICK_PER_SECOND)
|
|
|
|
#define SD_SECTOR_SIZE_SHIFT (9)
|
|
#define SD_SECTOR_SIZE (1 << SD_SECTOR_SIZE_SHIFT)
|
|
#define SD_BLOCK_SIZE_CSD (16)
|
|
#define SD_BLOCK_SIZE_CID (16)
|
|
#define SD_BLOCK_SIZE_OCR (4)
|
|
#define SD_BLOCK_SIZE_SDSTAT (64)
|
|
|
|
/* Card type definitions (CardType) */
|
|
#define CT_MMC (0x01)
|
|
#define CT_SD1 (0x02)
|
|
#define CT_SD2 (0x04)
|
|
#define CT_SDC (CT_SD1|CT_SD2)
|
|
#define CT_BLOCK (0x08)
|
|
|
|
/* Definitions for MMC/SDC command */
|
|
#define CMD0 (0) /* GO_IDLE_STATE */
|
|
#define CMD1 (1) /* SEND_OP_COND */
|
|
#define ACMD41 (41|0x80) /* SEND_OP_COND (SDC) */
|
|
#define CMD8 (8) /* SEND_IF_COND */
|
|
#define CMD9 (9) /* SEND_CSD */
|
|
#define CMD10 (10) /* SEND_CID */
|
|
#define CMD12 (12) /* STOP_TRANSMISSION */
|
|
#define ACMD13 (13|0x80) /* SD_STATUS (SDC) */
|
|
#define CMD16 (16) /* SET_BLOCKLEN */
|
|
#define CMD17 (17) /* READ_SINGLE_BLOCK */
|
|
#define CMD18 (18) /* READ_MULTIPLE_BLOCK */
|
|
#define CMD23 (23) /* SET_BLOCK_COUNT */
|
|
#define ACMD23 (23|0x80) /* SET_WR_BLK_ERASE_COUNT (SDC) */
|
|
#define CMD24 (24) /* WRITE_BLOCK */
|
|
#define CMD25 (25) /* WRITE_MULTIPLE_BLOCK */
|
|
#define CMD41 (41) /* SEND_OP_COND (ACMD) */
|
|
#define CMD55 (55) /* APP_CMD */
|
|
#define CMD58 (58) /* READ_OCR */
|
|
|
|
/* Exported functions --------------------------------------------------------- */
|
|
void efm_spiSd_init(void);
|
|
void efm_spiSd_deinit(void);
|
|
|
|
#endif /* __DEV_SDCARD_H__ */
|