2005-04-17 02:20:36 +04:00
/*
2007-07-11 22:04:50 +04:00
* linux / drivers / mmc / host / mmci . h - ARM PrimeCell MMCI PL180 / 1 driver
2005-04-17 02:20:36 +04:00
*
* Copyright ( C ) 2003 Deep Blue Solutions , Ltd , All Rights Reserved .
*
* 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 .
*/
# define MMCIPOWER 0x000
# define MCI_PWR_OFF 0x00
# define MCI_PWR_UP 0x02
# define MCI_PWR_ON 0x03
2009-01-04 17:18:54 +03:00
# define MCI_DATA2DIREN (1 << 2)
# define MCI_CMDDIREN (1 << 3)
# define MCI_DATA0DIREN (1 << 4)
# define MCI_DATA31DIREN (1 << 5)
2005-04-17 02:20:36 +04:00
# define MCI_OD (1 << 6)
# define MCI_ROD (1 << 7)
2009-01-04 17:18:54 +03:00
/* The ST Micro version does not have ROD */
# define MCI_FBCLKEN (1 << 7)
# define MCI_DATA74DIREN (1 << 8)
2005-04-17 02:20:36 +04:00
# define MMCICLOCK 0x004
# define MCI_CLK_ENABLE (1 << 8)
# define MCI_CLK_PWRSAVE (1 << 9)
# define MCI_CLK_BYPASS (1 << 10)
2009-01-04 17:18:54 +03:00
# define MCI_WIDE_BUS (1 << 11)
/* HW flow control on the ST Micro version */
# define MCI_FCEN (1 << 13)
2005-04-17 02:20:36 +04:00
# define MMCIARGUMENT 0x008
# define MMCICOMMAND 0x00c
# define MCI_CPSM_RESPONSE (1 << 6)
# define MCI_CPSM_LONGRSP (1 << 7)
# define MCI_CPSM_INTERRUPT (1 << 8)
# define MCI_CPSM_PENDING (1 << 9)
# define MCI_CPSM_ENABLE (1 << 10)
2009-01-04 17:18:54 +03:00
# define MCI_SDIO_SUSP (1 << 11)
# define MCI_ENCMD_COMPL (1 << 12)
# define MCI_NIEN (1 << 13)
# define MCI_CE_ATACMD (1 << 14)
2005-04-17 02:20:36 +04:00
# define MMCIRESPCMD 0x010
# define MMCIRESPONSE0 0x014
# define MMCIRESPONSE1 0x018
# define MMCIRESPONSE2 0x01c
# define MMCIRESPONSE3 0x020
# define MMCIDATATIMER 0x024
# define MMCIDATALENGTH 0x028
# define MMCIDATACTRL 0x02c
# define MCI_DPSM_ENABLE (1 << 0)
# define MCI_DPSM_DIRECTION (1 << 1)
# define MCI_DPSM_MODE (1 << 2)
# define MCI_DPSM_DMAENABLE (1 << 3)
2009-01-04 17:18:54 +03:00
# define MCI_DPSM_BLOCKSIZE (1 << 4)
# define MCI_DPSM_RWSTART (1 << 8)
# define MCI_DPSM_RWSTOP (1 << 9)
# define MCI_DPSM_RWMOD (1 << 10)
# define MCI_DPSM_SDIOEN (1 << 11)
2005-04-17 02:20:36 +04:00
# define MMCIDATACNT 0x030
# define MMCISTATUS 0x034
# define MCI_CMDCRCFAIL (1 << 0)
# define MCI_DATACRCFAIL (1 << 1)
# define MCI_CMDTIMEOUT (1 << 2)
# define MCI_DATATIMEOUT (1 << 3)
# define MCI_TXUNDERRUN (1 << 4)
# define MCI_RXOVERRUN (1 << 5)
# define MCI_CMDRESPEND (1 << 6)
# define MCI_CMDSENT (1 << 7)
# define MCI_DATAEND (1 << 8)
# define MCI_DATABLOCKEND (1 << 10)
# define MCI_CMDACTIVE (1 << 11)
# define MCI_TXACTIVE (1 << 12)
# define MCI_RXACTIVE (1 << 13)
# define MCI_TXFIFOHALFEMPTY (1 << 14)
# define MCI_RXFIFOHALFFULL (1 << 15)
# define MCI_TXFIFOFULL (1 << 16)
# define MCI_RXFIFOFULL (1 << 17)
# define MCI_TXFIFOEMPTY (1 << 18)
# define MCI_RXFIFOEMPTY (1 << 19)
# define MCI_TXDATAAVLBL (1 << 20)
# define MCI_RXDATAAVLBL (1 << 21)
2009-01-04 17:18:54 +03:00
# define MCI_SDIOIT (1 << 22)
# define MCI_CEATAEND (1 << 23)
2005-04-17 02:20:36 +04:00
# define MMCICLEAR 0x038
# define MCI_CMDCRCFAILCLR (1 << 0)
# define MCI_DATACRCFAILCLR (1 << 1)
# define MCI_CMDTIMEOUTCLR (1 << 2)
# define MCI_DATATIMEOUTCLR (1 << 3)
# define MCI_TXUNDERRUNCLR (1 << 4)
# define MCI_RXOVERRUNCLR (1 << 5)
# define MCI_CMDRESPENDCLR (1 << 6)
# define MCI_CMDSENTCLR (1 << 7)
# define MCI_DATAENDCLR (1 << 8)
# define MCI_DATABLOCKENDCLR (1 << 10)
2009-01-04 17:18:54 +03:00
# define MCI_SDIOITC (1 << 22)
# define MCI_CEATAENDC (1 << 23)
2005-04-17 02:20:36 +04:00
# define MMCIMASK0 0x03c
# define MCI_CMDCRCFAILMASK (1 << 0)
# define MCI_DATACRCFAILMASK (1 << 1)
# define MCI_CMDTIMEOUTMASK (1 << 2)
# define MCI_DATATIMEOUTMASK (1 << 3)
# define MCI_TXUNDERRUNMASK (1 << 4)
# define MCI_RXOVERRUNMASK (1 << 5)
# define MCI_CMDRESPENDMASK (1 << 6)
# define MCI_CMDSENTMASK (1 << 7)
# define MCI_DATAENDMASK (1 << 8)
# define MCI_DATABLOCKENDMASK (1 << 10)
# define MCI_CMDACTIVEMASK (1 << 11)
# define MCI_TXACTIVEMASK (1 << 12)
# define MCI_RXACTIVEMASK (1 << 13)
# define MCI_TXFIFOHALFEMPTYMASK (1 << 14)
# define MCI_RXFIFOHALFFULLMASK (1 << 15)
# define MCI_TXFIFOFULLMASK (1 << 16)
# define MCI_RXFIFOFULLMASK (1 << 17)
# define MCI_TXFIFOEMPTYMASK (1 << 18)
# define MCI_RXFIFOEMPTYMASK (1 << 19)
# define MCI_TXDATAAVLBLMASK (1 << 20)
# define MCI_RXDATAAVLBLMASK (1 << 21)
2009-01-04 17:18:54 +03:00
# define MCI_SDIOITMASK (1 << 22)
# define MCI_CEATAENDMASK (1 << 23)
2005-04-17 02:20:36 +04:00
# define MMCIMASK1 0x040
# define MMCIFIFOCNT 0x048
# define MMCIFIFO 0x080 /* to 0x0bc */
# define MCI_IRQENABLE \
( MCI_CMDCRCFAILMASK | MCI_DATACRCFAILMASK | MCI_CMDTIMEOUTMASK | \
MCI_DATATIMEOUTMASK | MCI_TXUNDERRUNMASK | MCI_RXOVERRUNMASK | \
MCI_CMDRESPENDMASK | MCI_CMDSENTMASK | MCI_DATABLOCKENDMASK )
/*
* The size of the FIFO in bytes .
*/
# define MCI_FIFOSIZE (16*4)
# define MCI_FIFOHALFSIZE (MCI_FIFOSIZE / 2)
# define NR_SG 16
struct clk ;
struct mmci_host {
void __iomem * base ;
struct mmc_request * mrq ;
struct mmc_command * cmd ;
struct mmc_data * data ;
struct mmc_host * mmc ;
struct clk * clk ;
2009-07-09 18:16:07 +04:00
int gpio_cd ;
int gpio_wp ;
2005-04-17 02:20:36 +04:00
unsigned int data_xfered ;
spinlock_t lock ;
unsigned int mclk ;
unsigned int cclk ;
u32 pwr ;
2009-09-22 17:29:36 +04:00
struct mmci_platform_data * plat ;
2005-04-17 02:20:36 +04:00
2009-01-04 17:18:54 +03:00
u8 hw_designer ;
u8 hw_revision : 4 ;
2005-04-17 02:20:36 +04:00
struct timer_list timer ;
unsigned int oldstat ;
unsigned int sg_len ;
/* pio stuff */
struct scatterlist * sg_ptr ;
unsigned int sg_off ;
unsigned int size ;
2009-09-22 17:41:40 +04:00
struct regulator * vcc ;
2005-04-17 02:20:36 +04:00
} ;
static inline void mmci_init_sg ( struct mmci_host * host , struct mmc_data * data )
{
/*
* Ideally , we want the higher levels to pass us a scatter list .
*/
host - > sg_len = data - > sg_len ;
host - > sg_ptr = data - > sg ;
host - > sg_off = 0 ;
}
static inline int mmci_next_sg ( struct mmci_host * host )
{
host - > sg_ptr + + ;
host - > sg_off = 0 ;
return - - host - > sg_len ;
}
static inline char * mmci_kmap_atomic ( struct mmci_host * host , unsigned long * flags )
{
struct scatterlist * sg = host - > sg_ptr ;
local_irq_save ( * flags ) ;
2007-10-23 22:37:24 +04:00
return kmap_atomic ( sg_page ( sg ) , KM_BIO_SRC_IRQ ) + sg - > offset ;
2005-04-17 02:20:36 +04:00
}
2006-01-05 13:31:23 +03:00
static inline void mmci_kunmap_atomic ( struct mmci_host * host , void * buffer , unsigned long * flags )
2005-04-17 02:20:36 +04:00
{
2006-01-05 13:31:23 +03:00
kunmap_atomic ( buffer , KM_BIO_SRC_IRQ ) ;
2005-04-17 02:20:36 +04:00
local_irq_restore ( * flags ) ;
}