ARM: dts: fix the SD card on the Snowball
authorLinus Walleij <linus.walleij@linaro.org>
Fri, 7 Oct 2016 08:52:17 +0000 (10:52 +0200)
committerOlof Johansson <olof@lixom.net>
Mon, 17 Oct 2016 20:45:48 +0000 (13:45 -0700)
commit1b283eea6228880b765bc40fe4e555416437ce58
tree399636789d7eed513963b4e02b7dfa22cefc4f4d
parent5c85b8722c839b214857ea0627401b82aa2bcf72
ARM: dts: fix the SD card on the Snowball

This fixes a very annoying regression on the Snowball SD card
that has been around for a while. It turns out that the device
tree does not configure the direction pins properly, nor sets
up the pins for the voltage converter properly at boot. Unless
all things are correctly set up, the feedback clock will not
work, and makes the driver spew messages in the console (but
it works, very slowly):

root@Ux500:/ mount /dev/mmcblk0p2 /mnt/
[    9.953460] mmci-pl18x 80126000.sdi0_per1: error during DMA transfer!
[    9.960296] mmcblk0: error -110 sending status command, retrying
[    9.966461] mmcblk0: error -110 sending status command, retrying
[    9.972534] mmcblk0: error -110 sending status command, aborting

Fix this by rectifying the device tree to correspond to that of
the Ux500 HREF boards plus the DAT31DIR setting that is unique for
the Snowball, and things start working smoothly. Add in the SDR12
and SDR25 modes which this host can do without any problems.

I don't know if this has ever been correct, sadly. It works after
this patch.

Cc: stable@vger.kernel.org
Reported-by: Daniel Lezcano <daniel.lezcano@linaro.org>
Cc: Ulf Hansson <ulf.hansson@linaro.org>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Olof Johansson <olof@lixom.net>
arch/arm/boot/dts/ste-snowball.dts