summaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorSascha Hauer <s.hauer@pengutronix.de>2010-10-22 12:21:25 +0200
committerSascha Hauer <s.hauer@pengutronix.de>2010-10-22 19:32:01 +0200
commit13c09da676d10054853fefbef49a1bb0c050dae8 (patch)
treebecc0b2286e9e6a91657e214541649d869715db7 /drivers
parentd8eccfd51debb0b3751e0512d3c61751705caf01 (diff)
downloadbarebox-13c09da676d10054853fefbef49a1bb0c050dae8.tar.gz
barebox-13c09da676d10054853fefbef49a1bb0c050dae8.tar.xz
mci: align data for commands
Some mci controllers cannot transfer data with their DMA engines if the data is not sufficiently aligned. Normally this is a driver problem, but hey, we have no problem aligning the data and keep the burden from the drivers. Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de> Cc: Juergen Beisert <jbe@pengutronix.de> Acked-by: Juergen Beisert <jbe@pengurtronix.de>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/mci/mci-core.c12
1 files changed, 6 insertions, 6 deletions
diff --git a/drivers/mci/mci-core.c b/drivers/mci/mci-core.c
index f82e6572a9..7bebe90033 100644
--- a/drivers/mci/mci-core.c
+++ b/drivers/mci/mci-core.c
@@ -349,7 +349,7 @@ static int mci_switch(struct device_d *mci_dev, unsigned set, unsigned index,
static int mmc_change_freq(struct device_d *mci_dev)
{
struct mci *mci = GET_MCI_DATA(mci_dev);
- char ext_csd[512];
+ char *ext_csd = sector_buf;
char cardtype;
int err;
@@ -441,8 +441,8 @@ static int sd_change_freq(struct device_d *mci_dev)
struct mci *mci = GET_MCI_DATA(mci_dev);
struct mci_cmd cmd;
struct mci_data data;
- uint32_t switch_status[16];
- uint scr[2];
+ uint32_t *switch_status = sector_buf;
+ uint32_t *scr = sector_buf;
int timeout;
int err;
@@ -463,7 +463,7 @@ static int sd_change_freq(struct device_d *mci_dev)
retry_scr:
pr_debug("Trying to read the SCR (try %d of %d)\n", 4 - timeout, 3);
- data.dest = (char *)&scr;
+ data.dest = (char *)scr;
data.blocksize = 8;
data.blocks = 1;
data.flags = MMC_DATA_READ;
@@ -504,7 +504,7 @@ retry_scr:
timeout = 4;
while (timeout--) {
err = sd_switch(mci_dev, SD_SWITCH_CHECK, 0, 1,
- (uint8_t*)&switch_status);
+ (uint8_t*)switch_status);
if (err) {
pr_debug("Checking SD transfer switch frequency feature failed: %d\n", err);
return err;
@@ -522,7 +522,7 @@ retry_scr:
if (!(__be32_to_cpu(switch_status[3]) & SD_HIGHSPEED_SUPPORTED))
return 0;
- err = sd_switch(mci_dev, SD_SWITCH_SWITCH, 0, 1, (uint8_t*)&switch_status);
+ err = sd_switch(mci_dev, SD_SWITCH_SWITCH, 0, 1, (uint8_t*)switch_status);
if (err) {
pr_debug("Switching SD transfer frequency failed: %d\n", err);
return err;