summaryrefslogtreecommitdiff
path: root/board/nvidia/p2771-0000
diff options
context:
space:
mode:
authorStephen Warren <swarren@nvidia.com>2016-07-29 13:15:05 -0600
committerTom Warren <twarren@nvidia.com>2016-08-15 10:26:13 -0700
commit45d85f0872ef92779ea5b51a424845a919a41462 (patch)
treea66a35a6fc9dbcfcca5550c35b11f728bc8ecfbd /board/nvidia/p2771-0000
parentad3c144fb8db9dbf232daaba3448ee8502c59d88 (diff)
downloadu-boot-45d85f0872ef92779ea5b51a424845a919a41462.tar.gz
u-boot-45d85f0872ef92779ea5b51a424845a919a41462.tar.bz2
u-boot-45d85f0872ef92779ea5b51a424845a919a41462.zip
ARM: tegra: enable SD card on p2771-0000
Now that clock and reset drivers exist for Tegra186, we can enable the SD card controller. Now that a BPMP I2C driver exists for Tegra186, we can communicate with the PMIC to enable power to the SD card. Hook up the DT content and board code required to make the SD card work. Signed-off-by: Stephen Warren <swarren@nvidia.com> Signed-off-by: Tom Warren <twarren@nvidia.com>
Diffstat (limited to 'board/nvidia/p2771-0000')
-rw-r--r--board/nvidia/p2771-0000/p2771-0000.c26
1 files changed, 26 insertions, 0 deletions
diff --git a/board/nvidia/p2771-0000/p2771-0000.c b/board/nvidia/p2771-0000/p2771-0000.c
index 4ba8ebc0dc..0c828a2005 100644
--- a/board/nvidia/p2771-0000/p2771-0000.c
+++ b/board/nvidia/p2771-0000/p2771-0000.c
@@ -5,3 +5,29 @@
*/
#include <common.h>
+#include <i2c.h>
+#include "../p2571/max77620_init.h"
+
+int tegra_board_init(void)
+{
+ struct udevice *dev;
+ uchar val;
+ int ret;
+
+ /* Turn on MAX77620 LDO3 to 3.3V for SD card power */
+ debug("%s: Set LDO3 for VDDIO_SDMMC_AP power to 3.3V\n", __func__);
+ ret = i2c_get_chip_for_busnum(0, MAX77620_I2C_ADDR_7BIT, 1, &dev);
+ if (ret) {
+ printf("%s: Cannot find MAX77620 I2C chip\n", __func__);
+ return ret;
+ }
+ /* 0xF2 for 3.3v, enabled: bit7:6 = 11 = enable, bit5:0 = voltage */
+ val = 0xF2;
+ ret = dm_i2c_write(dev, MAX77620_CNFG1_L3_REG, &val, 1);
+ if (ret) {
+ printf("i2c_write 0 0x3c 0x27 failed: %d\n", ret);
+ return ret;
+ }
+
+ return 0;
+}