2011-10-23 17:46:20 +08:00
|
|
|
/*
|
|
|
|
* File : mmcsd_host.h
|
|
|
|
* This file is part of RT-Thread RTOS
|
|
|
|
* COPYRIGHT (C) 2006, RT-Thread Development Team
|
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*
|
|
|
|
* Change Logs:
|
|
|
|
* Date Author Notes
|
|
|
|
* 2011-07-25 weety first version
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __HOST_H__
|
|
|
|
#define __HOST_H__
|
|
|
|
|
|
|
|
#include <rtthread.h>
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
struct rt_mmcsd_io_cfg {
|
|
|
|
rt_uint32_t clock; /* clock rate */
|
|
|
|
rt_uint16_t vdd;
|
|
|
|
|
|
|
|
/* vdd stores the bit number of the selected voltage range from below. */
|
|
|
|
|
|
|
|
rt_uint8_t bus_mode; /* command output mode */
|
|
|
|
|
|
|
|
#define MMCSD_BUSMODE_OPENDRAIN 1
|
|
|
|
#define MMCSD_BUSMODE_PUSHPULL 2
|
|
|
|
|
|
|
|
rt_uint8_t chip_select; /* SPI chip select */
|
|
|
|
|
|
|
|
#define MMCSD_CS_IGNORE 0
|
|
|
|
#define MMCSD_CS_HIGH 1
|
|
|
|
#define MMCSD_CS_LOW 2
|
|
|
|
|
|
|
|
rt_uint8_t power_mode; /* power supply mode */
|
|
|
|
|
|
|
|
#define MMCSD_POWER_OFF 0
|
|
|
|
#define MMCSD_POWER_UP 1
|
|
|
|
#define MMCSD_POWER_ON 2
|
|
|
|
|
|
|
|
rt_uint8_t bus_width; /* data bus width */
|
|
|
|
|
|
|
|
#define MMCSD_BUS_WIDTH_1 0
|
|
|
|
#define MMCSD_BUS_WIDTH_4 2
|
|
|
|
#define MMCSD_BUS_WIDTH_8 3
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
struct rt_mmcsd_host;
|
|
|
|
struct rt_mmcsd_req;
|
|
|
|
|
|
|
|
struct rt_mmcsd_host_ops {
|
|
|
|
void (*request)(struct rt_mmcsd_host *host, struct rt_mmcsd_req *req);
|
|
|
|
void (*set_iocfg)(struct rt_mmcsd_host *host, struct rt_mmcsd_io_cfg *io_cfg);
|
|
|
|
rt_int32_t (*get_card_status)(struct rt_mmcsd_host *host);
|
2012-02-29 00:40:40 +08:00
|
|
|
void (*enable_sdio_irq)(struct rt_mmcsd_host *host, rt_int32_t en);
|
2011-10-23 17:46:20 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct rt_mmcsd_host {
|
|
|
|
struct rt_mmcsd_card *card;
|
|
|
|
const struct rt_mmcsd_host_ops *ops;
|
|
|
|
rt_uint32_t freq_min;
|
|
|
|
rt_uint32_t freq_max;
|
|
|
|
struct rt_mmcsd_io_cfg io_cfg;
|
|
|
|
rt_uint32_t valid_ocr; /* current valid OCR */
|
|
|
|
#define VDD_165_195 (1 << 7) /* VDD voltage 1.65 - 1.95 */
|
|
|
|
#define VDD_20_21 (1 << 8) /* VDD voltage 2.0 ~ 2.1 */
|
|
|
|
#define VDD_21_22 (1 << 9) /* VDD voltage 2.1 ~ 2.2 */
|
|
|
|
#define VDD_22_23 (1 << 10) /* VDD voltage 2.2 ~ 2.3 */
|
|
|
|
#define VDD_23_24 (1 << 11) /* VDD voltage 2.3 ~ 2.4 */
|
|
|
|
#define VDD_24_25 (1 << 12) /* VDD voltage 2.4 ~ 2.5 */
|
|
|
|
#define VDD_25_26 (1 << 13) /* VDD voltage 2.5 ~ 2.6 */
|
|
|
|
#define VDD_26_27 (1 << 14) /* VDD voltage 2.6 ~ 2.7 */
|
|
|
|
#define VDD_27_28 (1 << 15) /* VDD voltage 2.7 ~ 2.8 */
|
|
|
|
#define VDD_28_29 (1 << 16) /* VDD voltage 2.8 ~ 2.9 */
|
|
|
|
#define VDD_29_30 (1 << 17) /* VDD voltage 2.9 ~ 3.0 */
|
|
|
|
#define VDD_30_31 (1 << 18) /* VDD voltage 3.0 ~ 3.1 */
|
|
|
|
#define VDD_31_32 (1 << 19) /* VDD voltage 3.1 ~ 3.2 */
|
|
|
|
#define VDD_32_33 (1 << 20) /* VDD voltage 3.2 ~ 3.3 */
|
|
|
|
#define VDD_33_34 (1 << 21) /* VDD voltage 3.3 ~ 3.4 */
|
|
|
|
#define VDD_34_35 (1 << 22) /* VDD voltage 3.4 ~ 3.5 */
|
|
|
|
#define VDD_35_36 (1 << 23) /* VDD voltage 3.5 ~ 3.6 */
|
|
|
|
rt_uint32_t flags; /* define device capabilities */
|
|
|
|
#define MMCSD_BUSWIDTH_4 (1 << 0)
|
|
|
|
#define MMCSD_BUSWIDTH_8 (1 << 1)
|
|
|
|
#define MMCSD_MUTBLKWRITE (1 << 2)
|
|
|
|
#define MMCSD_HOST_IS_SPI (1 << 3)
|
|
|
|
#define controller_is_spi(host) (host->flags & MMCSD_HOST_IS_SPI)
|
2012-02-29 00:40:40 +08:00
|
|
|
#define MMCSD_SUP_SDIO_IRQ (1 << 4) /* support signal pending SDIO IRQs */
|
|
|
|
#define MMCSD_SUP_HIGHSPEED (1 << 5) /* support high speed */
|
|
|
|
|
|
|
|
rt_uint32_t max_seg_size; /* maximum size of one dma segment */
|
|
|
|
rt_uint32_t max_dma_segs; /* maximum number of dma segments in one request */
|
|
|
|
rt_uint32_t max_blk_size; /* maximum block size */
|
|
|
|
rt_uint32_t max_blk_count; /* maximum block count */
|
|
|
|
|
2011-10-23 17:46:20 +08:00
|
|
|
rt_uint32_t spi_use_crc;
|
|
|
|
struct rt_semaphore bus_lock;
|
|
|
|
struct rt_semaphore sem_ack;
|
|
|
|
|
2012-02-29 00:40:40 +08:00
|
|
|
rt_uint32_t sdio_irq_num;
|
|
|
|
struct rt_semaphore *sdio_irq_sem;
|
|
|
|
struct rt_thread *sdio_irq_thread;
|
|
|
|
|
2011-10-23 17:46:20 +08:00
|
|
|
void *private_data;
|
|
|
|
};
|
|
|
|
|
|
|
|
rt_inline void mmcsd_delay_ms(rt_uint32_t ms)
|
|
|
|
{
|
|
|
|
if (ms < 1000 / RT_TICK_PER_SECOND)
|
|
|
|
{
|
|
|
|
rt_thread_delay(1);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
rt_thread_delay(ms/(1000 / RT_TICK_PER_SECOND));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|