2005-04-16 18:20:36 -04:00
|
|
|
/*
|
|
|
|
* linux/include/linux/mmc/host.h
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* Host driver specific definitions.
|
|
|
|
*/
|
|
|
|
#ifndef LINUX_MMC_HOST_H
|
|
|
|
#define LINUX_MMC_HOST_H
|
|
|
|
|
|
|
|
#include <linux/mmc/mmc.h>
|
|
|
|
|
|
|
|
struct mmc_ios {
|
|
|
|
unsigned int clock; /* clock rate */
|
|
|
|
unsigned short vdd;
|
|
|
|
|
|
|
|
#define MMC_VDD_150 0
|
|
|
|
#define MMC_VDD_155 1
|
|
|
|
#define MMC_VDD_160 2
|
|
|
|
#define MMC_VDD_165 3
|
|
|
|
#define MMC_VDD_170 4
|
|
|
|
#define MMC_VDD_180 5
|
|
|
|
#define MMC_VDD_190 6
|
|
|
|
#define MMC_VDD_200 7
|
|
|
|
#define MMC_VDD_210 8
|
|
|
|
#define MMC_VDD_220 9
|
|
|
|
#define MMC_VDD_230 10
|
|
|
|
#define MMC_VDD_240 11
|
|
|
|
#define MMC_VDD_250 12
|
|
|
|
#define MMC_VDD_260 13
|
|
|
|
#define MMC_VDD_270 14
|
|
|
|
#define MMC_VDD_280 15
|
|
|
|
#define MMC_VDD_290 16
|
|
|
|
#define MMC_VDD_300 17
|
|
|
|
#define MMC_VDD_310 18
|
|
|
|
#define MMC_VDD_320 19
|
|
|
|
#define MMC_VDD_330 20
|
|
|
|
#define MMC_VDD_340 21
|
|
|
|
#define MMC_VDD_350 22
|
|
|
|
#define MMC_VDD_360 23
|
|
|
|
|
|
|
|
unsigned char bus_mode; /* command output mode */
|
|
|
|
|
|
|
|
#define MMC_BUSMODE_OPENDRAIN 1
|
|
|
|
#define MMC_BUSMODE_PUSHPULL 2
|
|
|
|
|
2005-09-03 11:45:02 -04:00
|
|
|
unsigned char chip_select; /* SPI chip select */
|
|
|
|
|
|
|
|
#define MMC_CS_DONTCARE 0
|
|
|
|
#define MMC_CS_HIGH 1
|
|
|
|
#define MMC_CS_LOW 2
|
|
|
|
|
2005-04-16 18:20:36 -04:00
|
|
|
unsigned char power_mode; /* power supply mode */
|
|
|
|
|
|
|
|
#define MMC_POWER_OFF 0
|
|
|
|
#define MMC_POWER_UP 1
|
|
|
|
#define MMC_POWER_ON 2
|
2005-09-06 18:18:55 -04:00
|
|
|
|
|
|
|
unsigned char bus_width; /* data bus width */
|
|
|
|
|
|
|
|
#define MMC_BUS_WIDTH_1 0
|
|
|
|
#define MMC_BUS_WIDTH_4 2
|
2005-04-16 18:20:36 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
struct mmc_host_ops {
|
|
|
|
void (*request)(struct mmc_host *host, struct mmc_request *req);
|
|
|
|
void (*set_ios)(struct mmc_host *host, struct mmc_ios *ios);
|
2005-09-06 18:18:52 -04:00
|
|
|
int (*get_ro)(struct mmc_host *host);
|
2005-04-16 18:20:36 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
struct mmc_card;
|
|
|
|
struct device;
|
|
|
|
|
|
|
|
struct mmc_host {
|
2006-09-12 11:00:10 -04:00
|
|
|
struct device *parent;
|
|
|
|
struct device class_dev;
|
2005-08-19 04:42:52 -04:00
|
|
|
int index;
|
2006-09-03 09:43:33 -04:00
|
|
|
const struct mmc_host_ops *ops;
|
2005-04-16 18:20:36 -04:00
|
|
|
unsigned int f_min;
|
|
|
|
unsigned int f_max;
|
|
|
|
u32 ocr_avail;
|
|
|
|
|
2005-09-06 18:18:55 -04:00
|
|
|
unsigned long caps; /* Host capabilities */
|
|
|
|
|
|
|
|
#define MMC_CAP_4_BIT_DATA (1 << 0) /* Can the host do 4 bit transfers */
|
2006-08-30 10:14:56 -04:00
|
|
|
#define MMC_CAP_MULTIWRITE (1 << 1) /* Can accurately report bytes sent to card on error */
|
2006-09-24 05:44:09 -04:00
|
|
|
#define MMC_CAP_BYTEBLOCK (1 << 2) /* Can do non-log2 block sizes */
|
2005-09-06 18:18:55 -04:00
|
|
|
|
2005-04-16 18:20:36 -04:00
|
|
|
/* host specific block data */
|
|
|
|
unsigned int max_seg_size; /* see blk_queue_max_segment_size */
|
|
|
|
unsigned short max_hw_segs; /* see blk_queue_max_hw_segments */
|
|
|
|
unsigned short max_phys_segs; /* see blk_queue_max_phys_segments */
|
|
|
|
unsigned short max_sectors; /* see blk_queue_max_sectors */
|
|
|
|
unsigned short unused;
|
|
|
|
|
|
|
|
/* private data */
|
|
|
|
struct mmc_ios ios; /* current io bus settings */
|
|
|
|
u32 ocr; /* the current OCR setting */
|
|
|
|
|
2005-09-06 18:18:50 -04:00
|
|
|
unsigned int mode; /* current card mode of host */
|
|
|
|
#define MMC_MODE_MMC 0
|
|
|
|
#define MMC_MODE_SD 1
|
|
|
|
|
2005-04-16 18:20:36 -04:00
|
|
|
struct list_head cards; /* devices attached to this host */
|
|
|
|
|
|
|
|
wait_queue_head_t wq;
|
|
|
|
spinlock_t lock; /* card_busy lock */
|
|
|
|
struct mmc_card *card_busy; /* the MMC card claiming host */
|
|
|
|
struct mmc_card *card_selected; /* the selected MMC card */
|
|
|
|
|
2006-11-22 09:57:56 -05:00
|
|
|
struct delayed_work detect;
|
2005-09-08 17:46:00 -04:00
|
|
|
|
|
|
|
unsigned long private[0] ____cacheline_aligned;
|
2005-04-16 18:20:36 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
extern struct mmc_host *mmc_alloc_host(int extra, struct device *);
|
|
|
|
extern int mmc_add_host(struct mmc_host *);
|
|
|
|
extern void mmc_remove_host(struct mmc_host *);
|
|
|
|
extern void mmc_free_host(struct mmc_host *);
|
|
|
|
|
2005-09-08 17:46:00 -04:00
|
|
|
static inline void *mmc_priv(struct mmc_host *host)
|
|
|
|
{
|
|
|
|
return (void *)host->private;
|
|
|
|
}
|
|
|
|
|
2006-09-12 11:00:10 -04:00
|
|
|
#define mmc_dev(x) ((x)->parent)
|
|
|
|
#define mmc_hostname(x) ((x)->class_dev.bus_id)
|
2005-04-16 18:20:36 -04:00
|
|
|
|
2005-04-16 18:25:37 -04:00
|
|
|
extern int mmc_suspend_host(struct mmc_host *, pm_message_t);
|
2005-04-16 18:20:36 -04:00
|
|
|
extern int mmc_resume_host(struct mmc_host *);
|
|
|
|
|
2005-09-08 12:53:01 -04:00
|
|
|
extern void mmc_detect_change(struct mmc_host *, unsigned long delay);
|
2005-04-16 18:20:36 -04:00
|
|
|
extern void mmc_request_done(struct mmc_host *, struct mmc_request *);
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|