[U-Boot] [PATCH 6/6] am335x_evm: am33xx_spl_board_init function and scale core frequency

Dan Murphy dmurphy at ti.com
Tue Jul 23 20:46:53 CEST 2013


On 07/19/2013 02:00 PM, Tom Rini wrote:
> Add a am33xx_spl_board_init (and enable the PMICs) that we may see,
> depending on the board we are running on.  In all cases, we see if we
> can rely on the efuse_sma register to tell us the maximum speed.  In the
> case of Beaglebone White, we need to make sure we are on AC power, and
> are on later than rev A1, and then we can ramp up to the PG1.0 maximum
> of 720Mhz.  In the case of Beaglebone Black, we are either on PG2.0 that
> supports 1GHz or PG2.1.  As PG2.0 may or may not have efuse_sma set, we
> cannot rely on this probe.  In the case of the GP EVM, EVM SK and IDK we
> need to rely on the efuse_sma if we are on PG2.1, and the defaults for
> PG1.0/2.0.
>
> Signed-off-by: Tom Rini <trini at ti.com>
> ---
>  arch/arm/include/asm/arch-am33xx/clocks_am33xx.h |    8 ++
>  board/ti/am335x/board.c                          |  155 ++++++++++++++++++++++
>  include/configs/am335x_evm.h                     |    4 +
>  3 files changed, 167 insertions(+)
>
> diff --git a/arch/arm/include/asm/arch-am33xx/clocks_am33xx.h b/arch/arm/include/asm/arch-am33xx/clocks_am33xx.h
> index 89b63d9..834f24f 100644
> --- a/arch/arm/include/asm/arch-am33xx/clocks_am33xx.h
> +++ b/arch/arm/include/asm/arch-am33xx/clocks_am33xx.h
> @@ -24,6 +24,14 @@
>  #define CONFIG_SYS_MPUCLK	550
>  #endif
>  
> +/* MAIN PLL Fdll supported frequencies */
> +#define MPUPLL_M_1000	1000
> +#define MPUPLL_M_800	800
> +#define MPUPLL_M_720	720
> +#define MPUPLL_M_600	600
> +#define MPUPLL_M_550	550
> +#define MPUPLL_M_300	300
> +
>  extern void pll_init(void);
>  extern void enable_emif_clocks(void);
>  extern void enable_dmm_clocks(void);
> diff --git a/board/ti/am335x/board.c b/board/ti/am335x/board.c
> index fdbe26c..6544931 100644
> --- a/board/ti/am335x/board.c
> +++ b/board/ti/am335x/board.c
> @@ -33,6 +33,8 @@
>  #include <i2c.h>
>  #include <miiphy.h>
>  #include <cpsw.h>
> +#include <power/tps65217.h>
> +#include <power/tps65910.h>
>  #include "board.h"
>  
>  DECLARE_GLOBAL_DATA_PTR;
> @@ -282,6 +284,159 @@ int spl_start_uboot(void)
>  }
>  #endif
>  
> +void am33xx_spl_board_init(void)
> +{
> +	int mpu_vdd, mpu_pll, sil_rev;
> +
> +	/* Assume PG 1.0 */
> +	mpu_pll = MPUPLL_M_720;
> +
> +	sil_rev = readl(&cdev->deviceid) >> 28;
> +	if (sil_rev == 1)
> +		/* PG 2.0, efuse may not be set. */
> +		mpu_pll = MPUPLL_M_800;
> +	else if (sil_rev >= 2) {
> +		/* Check what the efuse says our max speed is. */
> +		int efuse_arm_mpu_max_freq;
> +		efuse_arm_mpu_max_freq = readl(&cdev->efuse_sma);
> +		switch ((efuse_arm_mpu_max_freq & DEVICE_ID_MASK)) {
> +		case AM335X_ZCZ_1000:
> +			mpu_pll = MPUPLL_M_1000;
> +			break;
> +		case AM335X_ZCZ_800:
> +			mpu_pll = MPUPLL_M_800;
> +			break;
> +		case AM335X_ZCZ_720:
> +			mpu_pll = MPUPLL_M_720;
> +			break;
> +		case AM335X_ZCZ_600:
> +		case AM335X_ZCE_600:
> +			mpu_pll = MPUPLL_M_600;
> +			break;
> +		case AM335X_ZCZ_300:
> +		case AM335X_ZCE_300:
> +			mpu_pll = MPUPLL_M_300;
> +			break;
> +		}
> +	}
> +
> +	if (board_is_bone() || board_is_bone_lt()) {
> +		/* BeagleBone PMIC Code */
> +		int usb_cur_lim;
> +
> +		/*
> +		 * Only perform PMIC configurations if board rev > A1
> +		 * on Beaglebone White
> +		 */
> +		if (board_is_bone() && !strncmp(header.version, "00A1", 4))
> +			return;
> +
> +		if (i2c_probe(TPS65217_CHIP_PM))
> +			return;
> +
> +		/*
> +		 * On Beaglebone White we need to ensure we have AC power
> +		 * before increasing the frequency.
> +		 */
> +		if (board_is_bone()) {
> +			uchar pmic_status_reg;
> +			if (tps65217_reg_read(STATUS, &pmic_status_reg))
> +				return;
> +			if (!(pmic_status_reg & PWR_SRC_AC_BITMASK)) {
> +				puts("No AC power, disabling frequency switch\n");
> +				return;
> +			}
> +		}
> +
> +		/*
> +		 * Increase USB current limit to 1300mA or 1800mA and set
> +		 * the MPU voltage controller as needed.
> +		 */
> +		if (mpu_pll == MPUPLL_M_1000) {
> +			usb_cur_lim = USB_INPUT_CUR_LIMIT_1800MA;
> +			mpu_vdd = DCDC_VOLT_SEL_1325MV;
> +		} else {
> +			usb_cur_lim = USB_INPUT_CUR_LIMIT_1300MA;
> +			mpu_vdd = DCDC_VOLT_SEL_1275MV;
> +		}
> +
> +		if (tps65217_reg_write(PROT_LEVEL_NONE, POWER_PATH,
> +				       usb_cur_lim, USB_INPUT_CUR_LIMIT_MASK))
> +			printf("tps65217_reg_write failure\n");

puts("...") when we don't have format characters, thanks.

> +
> +
> +		/* Set DCDC2 (MPU) voltage */
> +		if (tps65217_voltage_update(DEFDCDC2, mpu_vdd)) {
> +			printf("tps65217_voltage_update failure\n");

Same as above


> +			return;
> +		}
> +
> +		/* Set LDO3, LDO4 output voltage to 3.3V */
> +		if (tps65217_reg_write(PROT_LEVEL_2, DEFLS1,
> +				       LDO_VOLTAGE_OUT_3_3, LDO_MASK))
> +			printf("tps65217_reg_write failure\n");

Same as above


> +
> +		if (tps65217_reg_write(PROT_LEVEL_2, DEFLS2,
> +				       LDO_VOLTAGE_OUT_3_3, LDO_MASK))
> +			printf("tps65217_reg_write failure\n");

Same as above


> +	} else {
> +		uchar buf[4];
> +
> +		/*
> +		 * The GP EVM, IDK and EVM SK use a TPS65910 PMIC.  For all
> +		 * MPU frequencies we support we use a CORE voltage of
> +		 * 1.1375V.  For MPU voltage we need to switch based on
> +		 * the frequency we are running at.
> +		 */
> +		if (i2c_probe(TPS65910_CTRL_I2C_ADDR))
> +			return;
> +
> +		/* VDD1/2 voltage selection register access by control i/f */
> +		if (i2c_read(TPS65910_CTRL_I2C_ADDR, TPS65910_DEVCTRL_REG, 1,
> +			     buf, 1))

Would it not be better to have an API in the pmic driver file that you can call to access the pmic
instead of calling the pmic explicitly?

> +			return;
> +
> +		buf[0] |= TPS65910_DEVCTRL_REG_SR_CTL_I2C_SEL_CTL_I2C;
> +
> +		if (i2c_write(TPS65910_CTRL_I2C_ADDR, TPS65910_DEVCTRL_REG, 1,
> +			      buf, 1))

Would it not be better to have an API in the pmic driver file that you can call to access the pmic
instead of calling the pmic explicitly?

> +			return;
> +
> +		/* Depending on MPU clock we need different MPU VDD */
> +
> +		/* Default to PG1.0/PG2.0 values. */
> +		mpu_vdd = TPS65910_OP_REG_SEL_1_1_3;
> +
> +		if (sil_rev >= 2) {
> +			switch (mpu_pll) {
> +			case MPUPLL_M_1000:
> +				mpu_vdd = TPS65910_OP_REG_SEL_1_3_2_5;
> +				break;
> +			case MPUPLL_M_800:
> +				mpu_vdd = TPS65910_OP_REG_SEL_1_2_6;
> +				break;
> +			case MPUPLL_M_720:
> +				mpu_vdd = TPS65910_OP_REG_SEL_1_2_0;
> +				break;
> +			case MPUPLL_M_600:
> +			case MPUPLL_M_300:
> +				mpu_vdd = TPS65910_OP_REG_SEL_1_1_3;
> +				break;
> +			}
> +		}
> +
> +		/* First update MPU voltage. */
> +		if (tps65910_voltage_update(MPU, mpu_vdd))
> +			return;
> +
> +		/* Second, update the CORE voltage. */
> +		if (tps65910_voltage_update(CORE, TPS65910_OP_REG_SEL_1_1_3))
> +			return;
> +	}
> +
> +	/* Set MPU Frequency to what we detected now that voltages are set */
> +	mpu_pll_config_val(mpu_pll);
> +}
>  #endif
>  
>  /*
> diff --git a/include/configs/am335x_evm.h b/include/configs/am335x_evm.h
> index c5a6d4b..60c87a3 100644
> --- a/include/configs/am335x_evm.h
> +++ b/include/configs/am335x_evm.h
> @@ -289,6 +289,9 @@
>  #define CONFIG_SYS_I2C_EEPROM_ADDR_LEN	2
>  #define CONFIG_SYS_I2C_MULTI_EEPROMS
>  
> +#define CONFIG_POWER_TPS65217
> +#define CONFIG_POWER_TPS65910
> +
>  #define CONFIG_OMAP_GPIO
>  
>  #define CONFIG_BAUDRATE		115200
> @@ -352,6 +355,7 @@
>  #define CONFIG_SPL_LIBCOMMON_SUPPORT
>  #define CONFIG_SPL_LIBDISK_SUPPORT
>  #define CONFIG_SPL_LIBGENERIC_SUPPORT
> +#define CONFIG_SPL_POWER_SUPPORT
>  #define CONFIG_SPL_SERIAL_SUPPORT
>  #define CONFIG_SPL_GPIO_SUPPORT
>  #define CONFIG_SPL_YMODEM_SUPPORT


-- 
------------------
Dan Murphy



More information about the U-Boot mailing list