mirror of
https://github.com/CTCaer/hekate
synced 2024-12-22 11:21:23 +00:00
ccplex: Add regulator for T210B01
This commit is contained in:
parent
d0a73bdc72
commit
147fed39c8
3 changed files with 118 additions and 2 deletions
100
bdk/power/max77812.h
Normal file
100
bdk/power/max77812.h
Normal file
|
@ -0,0 +1,100 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2020 CTCaer
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms and conditions of the GNU General Public License,
|
||||||
|
* version 2, as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _MAX77812_H_
|
||||||
|
#define _MAX77812_H_
|
||||||
|
|
||||||
|
#define MAX77812_PHASE31_CPU_I2C_ADDR 0x31
|
||||||
|
#define MAX77812_PHASE211_CPU_I2C_ADDR 0x33
|
||||||
|
|
||||||
|
#define MAX77812_REG_RSET 0x00
|
||||||
|
#define MAX77812_REG_INT_SRC 0x01
|
||||||
|
#define MAX77812_REG_INT_SRC_M 0x02
|
||||||
|
#define MAX77812_REG_TOPSYS_INT 0x03
|
||||||
|
#define MAX77812_REG_TOPSYS_INT_M 0x04
|
||||||
|
#define MAX77812_REG_TOPSYS_STAT 0x05
|
||||||
|
#define MAX77812_REG_EN_CTRL 0x06
|
||||||
|
#define MAX77812_EN_CTRL_EN_M4 BIT(6)
|
||||||
|
#define MAX77812_REG_STUP_DLY2 0x07
|
||||||
|
#define MAX77812_REG_STUP_DLY3 0x08
|
||||||
|
#define MAX77812_REG_STUP_DLY4 0x09
|
||||||
|
#define MAX77812_REG_SHDN_DLY1 0x0A
|
||||||
|
#define MAX77812_REG_SHDN_DLY2 0x0B
|
||||||
|
#define MAX77812_REG_SHDN_DLY3 0x0C
|
||||||
|
#define MAX77812_REG_SHDN_DLY4 0x0D
|
||||||
|
#define MAX77812_REG_WDTRSTB_DEB 0x0E
|
||||||
|
#define MAX77812_REG_GPI_FUNC 0x0F
|
||||||
|
#define MAX77812_REG_GPI_DEB1 0x10
|
||||||
|
#define MAX77812_REG_GPI_DEB2 0x11
|
||||||
|
#define MAX77812_REG_GPI_PD_CTRL 0x12
|
||||||
|
#define MAX77812_REG_PROT_CFG 0x13
|
||||||
|
#define MAX77812_REG_VERSION 0x14
|
||||||
|
#define MAX77812_REG_I2C_CFG 0x15
|
||||||
|
#define MAX77812_REG_BUCK_INT 0x20
|
||||||
|
#define MAX77812_REG_BUCK_INT_M 0x21
|
||||||
|
#define MAX77812_REG_BUCK_STAT 0x22
|
||||||
|
#define MAX77812_REG_M1_VOUT 0x23
|
||||||
|
#define MAX77812_REG_M2_VOUT 0x24
|
||||||
|
#define MAX77812_REG_M3_VOUT 0x25
|
||||||
|
#define MAX77812_REG_M4_VOUT 0x26
|
||||||
|
#define MAX77812_M4_VOUT_0_80V 0x6E
|
||||||
|
#define MAX77812_REG_M1_VOUT_D 0x27
|
||||||
|
#define MAX77812_REG_M2_VOUT_D 0x28
|
||||||
|
#define MAX77812_REG_M3_VOUT_D 0x29
|
||||||
|
#define MAX77812_REG_M4_VOUT_D 0x2A
|
||||||
|
#define MAX77812_REG_M1_VOUT_S 0x2B
|
||||||
|
#define MAX77812_REG_M2_VOUT_S 0x2C
|
||||||
|
#define MAX77812_REG_M3_VOUT_S 0x2D
|
||||||
|
#define MAX77812_REG_M4_VOUT_S 0x2E
|
||||||
|
#define MAX77812_REG_M1_CFG 0x2F
|
||||||
|
#define MAX77812_REG_M2_CFG 0x30
|
||||||
|
#define MAX77812_REG_M3_CFG 0x31
|
||||||
|
#define MAX77812_REG_M4_CFG 0x32
|
||||||
|
#define MAX77812_REG_GLB_CFG1 0x33
|
||||||
|
#define MAX77812_REG_GLB_CFG2 0x34
|
||||||
|
#define MAX77812_REG_GLB_CFG3 0x35
|
||||||
|
#define MAX77812_REG_GLB_CFG4 0x36
|
||||||
|
#define MAX77812_REG_GLB_CFG5 0x37
|
||||||
|
#define MAX77812_REG_GLB_CFG6 0x38
|
||||||
|
#define MAX77812_REG_GLB_CFG7 0x39
|
||||||
|
#define MAX77812_REG_GLB_CFG8 0x3A
|
||||||
|
#define MAX77812_REG_PROT_ACCESS 0xFD
|
||||||
|
#define MAX77812_REG_MAX 0xFE
|
||||||
|
|
||||||
|
#define MAX77812_REG_EN_CTRL_MASK(n) BIT(n)
|
||||||
|
#define MAX77812_START_SLEW_RATE_MASK 0x07
|
||||||
|
#define MAX77812_SHDN_SLEW_RATE_MASK 0x70
|
||||||
|
#define MAX77812_RAMPUP_SLEW_RATE_MASK 0x07
|
||||||
|
#define MAX77812_RAMPDOWN_SLEW_RATE_MASK 0x70
|
||||||
|
#define MAX77812_SLEW_RATE_SHIFT 4
|
||||||
|
|
||||||
|
#define MAX77812_OP_ACTIVE_DISCHARGE_MASK BIT(7)
|
||||||
|
#define MAX77812_PEAK_CURRENT_LMT_MASK 0x70
|
||||||
|
#define MAX77812_SWITCH_FREQ_MASK 0x0C
|
||||||
|
#define MAX77812_FORCED_PWM_MASK BIT(1)
|
||||||
|
#define MAX77812_SLEW_RATE_CNTRL_MASK BIT(0)
|
||||||
|
#define MAX77812_START_SHD_DELAY_MASK 0x1F
|
||||||
|
#define MAX77812_VERSION_MASK 0x07
|
||||||
|
#define MAX77812_ES2_VERSION 0x04
|
||||||
|
#define MAX77812_QS_VERSION 0x05
|
||||||
|
|
||||||
|
#define MAX77812_VOUT_MASK 0xFF
|
||||||
|
#define MAX77812_VOUT_N_VOLTAGE 0xFF
|
||||||
|
#define MAX77812_VOUT_VMIN 250000
|
||||||
|
#define MAX77812_VOUT_VMAX 1525000
|
||||||
|
#define MAX77812_VOUT_STEP 5000
|
||||||
|
|
||||||
|
#endif
|
|
@ -1,5 +1,6 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2018 naehrwert
|
* Copyright (c) 2018 naehrwert
|
||||||
|
* Copyright (c) 2018-2020 CTCaer
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify it
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
* under the terms and conditions of the GNU General Public License,
|
* under the terms and conditions of the GNU General Public License,
|
||||||
|
@ -15,15 +16,18 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <soc/ccplex.h>
|
#include <soc/ccplex.h>
|
||||||
|
#include <soc/fuse.h>
|
||||||
|
#include <soc/hw_init.h>
|
||||||
#include <soc/i2c.h>
|
#include <soc/i2c.h>
|
||||||
#include <soc/clock.h>
|
#include <soc/clock.h>
|
||||||
#include <soc/pmc.h>
|
#include <soc/pmc.h>
|
||||||
#include <soc/t210.h>
|
#include <soc/t210.h>
|
||||||
#include <power/max77620.h>
|
#include <power/max77620.h>
|
||||||
#include <power/max7762x.h>
|
#include <power/max7762x.h>
|
||||||
|
#include <power/max77812.h>
|
||||||
#include <utils/util.h>
|
#include <utils/util.h>
|
||||||
|
|
||||||
void _ccplex_enable_power()
|
void _ccplex_enable_power_t210()
|
||||||
{
|
{
|
||||||
u8 tmp = i2c_recv_byte(I2C_5, MAX77620_I2C_ADDR, MAX77620_REG_AME_GPIO); // Get current pinmuxing
|
u8 tmp = i2c_recv_byte(I2C_5, MAX77620_I2C_ADDR, MAX77620_REG_AME_GPIO); // Get current pinmuxing
|
||||||
i2c_send_byte(I2C_5, MAX77620_I2C_ADDR, MAX77620_REG_AME_GPIO, tmp & ~BIT(5)); // Disable GPIO5 pinmuxing.
|
i2c_send_byte(I2C_5, MAX77620_I2C_ADDR, MAX77620_REG_AME_GPIO, tmp & ~BIT(5)); // Disable GPIO5 pinmuxing.
|
||||||
|
@ -40,12 +44,23 @@ void _ccplex_enable_power()
|
||||||
i2c_send_byte(I2C_5, MAX77621_CPU_I2C_ADDR, MAX77621_VOUT_DVS_REG, MAX77621_VOUT_ENABLE | MAX77621_VOUT_0_95V);
|
i2c_send_byte(I2C_5, MAX77621_CPU_I2C_ADDR, MAX77621_VOUT_DVS_REG, MAX77621_VOUT_ENABLE | MAX77621_VOUT_0_95V);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void _ccplex_enable_power_t210b01()
|
||||||
|
{
|
||||||
|
u8 pmic_cpu_addr = !(FUSE(FUSE_RESERVED_ODM28) & 1) ? MAX77812_PHASE31_CPU_I2C_ADDR : MAX77812_PHASE211_CPU_I2C_ADDR;
|
||||||
|
u8 tmp = i2c_recv_byte(I2C_5, pmic_cpu_addr, MAX77812_REG_EN_CTRL);
|
||||||
|
i2c_send_byte(I2C_5, pmic_cpu_addr, MAX77812_REG_EN_CTRL, tmp | MAX77812_EN_CTRL_EN_M4);
|
||||||
|
i2c_send_byte(I2C_5, pmic_cpu_addr, MAX77812_REG_M4_VOUT, MAX77812_M4_VOUT_0_80V);
|
||||||
|
}
|
||||||
|
|
||||||
void ccplex_boot_cpu0(u32 entry)
|
void ccplex_boot_cpu0(u32 entry)
|
||||||
{
|
{
|
||||||
// Set ACTIVE_CLUSER to FAST.
|
// Set ACTIVE_CLUSER to FAST.
|
||||||
FLOW_CTLR(FLOW_CTLR_BPMP_CLUSTER_CONTROL) &= 0xFFFFFFFE;
|
FLOW_CTLR(FLOW_CTLR_BPMP_CLUSTER_CONTROL) &= 0xFFFFFFFE;
|
||||||
|
|
||||||
_ccplex_enable_power();
|
if (hw_get_chip_id() == GP_HIDREV_MAJOR_T210)
|
||||||
|
_ccplex_enable_power_t210();
|
||||||
|
else
|
||||||
|
_ccplex_enable_power_t210b01();
|
||||||
|
|
||||||
if (!(CLOCK(CLK_RST_CONTROLLER_PLLX_BASE) & 0x40000000)) // PLLX_ENABLE.
|
if (!(CLOCK(CLK_RST_CONTROLLER_PLLX_BASE) & 0x40000000)) // PLLX_ENABLE.
|
||||||
{
|
{
|
||||||
|
|
|
@ -64,6 +64,7 @@
|
||||||
#define FUSE_OPT_X_COORDINATE 0x214
|
#define FUSE_OPT_X_COORDINATE 0x214
|
||||||
#define FUSE_OPT_Y_COORDINATE 0x218
|
#define FUSE_OPT_Y_COORDINATE 0x218
|
||||||
#define FUSE_GPU_IDDQ_CALIB 0x228
|
#define FUSE_GPU_IDDQ_CALIB 0x228
|
||||||
|
#define FUSE_RESERVED_ODM28 0x240
|
||||||
#define FUSE_USB_CALIB_EXT 0x350
|
#define FUSE_USB_CALIB_EXT 0x350
|
||||||
|
|
||||||
/*! Fuse commands. */
|
/*! Fuse commands. */
|
||||||
|
|
Loading…
Reference in a new issue