blob: 17e7d76ae7aa7ebe6a5355adb8ff2f3a8b6a505e [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Tom Warren15fc9842014-01-24 12:46:18 -07002/*
3 * (C) Copyright 2013
4 * NVIDIA Corporation <www.nvidia.com>
Tom Warren15fc9842014-01-24 12:46:18 -07005 */
6
7/* AS3722-PMIC-specific early init regs */
8
9#define AS3722_I2C_ADDR 0x80
10
11#define AS3722_SD0VOLTAGE_REG 0x00 /* CPU */
12#define AS3722_SD1VOLTAGE_REG 0x01 /* CORE, already set by OTP */
13#define AS3722_SD6VOLTAGE_REG 0x06 /* GPU */
14#define AS3722_SDCONTROL_REG 0x4D
15
16#define AS3722_LDO2VOLTAGE_REG 0x12 /* VPP_FUSE */
17#define AS3722_LDO6VOLTAGE_REG 0x16 /* VDD_SDMMC */
18#define AS3722_LDCONTROL_REG 0x4E
19
Peter Chubb441f2382016-08-30 22:54:46 +000020#if defined(CONFIG_TARGET_VENICE2)
Tom Warren15fc9842014-01-24 12:46:18 -070021#define AS3722_SD0VOLTAGE_DATA (0x2800 | AS3722_SD0VOLTAGE_REG)
Peter Chubb441f2382016-08-30 22:54:46 +000022#else /* TK1 or Nyan-Big */
23#define AS3722_SD0VOLTAGE_DATA (0x3C00 | AS3722_SD0VOLTAGE_REG)
Stephen Warrena844b012014-03-25 11:39:33 -060024#endif
Tom Warren15fc9842014-01-24 12:46:18 -070025#define AS3722_SD0CONTROL_DATA (0x0100 | AS3722_SDCONTROL_REG)
26
Peter Chubb441f2382016-08-30 22:54:46 +000027#if defined(CONFIG_TARGET_JETSON_TK1) || defined(CONFIG_TARGET_CEI_TK1_SOM)
Bibek Basu9b7a41e2016-08-11 16:28:28 -060028#define AS3722_SD1VOLTAGE_DATA (0x2800 | AS3722_SD1VOLTAGE_REG)
Tom Warren15fc9842014-01-24 12:46:18 -070029#define AS3722_SD1CONTROL_DATA (0x0200 | AS3722_SDCONTROL_REG)
Bibek Basu9b7a41e2016-08-11 16:28:28 -060030#endif
Tom Warren15fc9842014-01-24 12:46:18 -070031
32#define AS3722_SD6CONTROL_DATA (0x4000 | AS3722_SDCONTROL_REG)
33#define AS3722_SD6VOLTAGE_DATA (0x2800 | AS3722_SD6VOLTAGE_REG)
34
35#define AS3722_LDO2CONTROL_DATA (0x0400 | AS3722_LDCONTROL_REG)
36#define AS3722_LDO2VOLTAGE_DATA (0x1000 | AS3722_LDO2VOLTAGE_REG)
37
38#define AS3722_LDO6CONTROL_DATA (0x4000 | AS3722_LDCONTROL_REG)
39#define AS3722_LDO6VOLTAGE_DATA (0x3F00 | AS3722_LDO6VOLTAGE_REG)
40
41#define I2C_SEND_2_BYTES 0x0A02
42
43void pmic_enable_cpu_vdd(void);