mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-12-04 02:20:25 +00:00
aba11d4476
Enabling a PLL while IDDQ is high. The Linux kernel checks for this condition and warns about it verbosely, so while this seems to work fine, fix it up according to the programming guidelines provided in the Tegra K1 TRM (v02p), Section 5.3.8.1 ("PLLC and PLLC4 Startup Sequence"). Reported-by: Nicolas Chauvet <kwizart@gmail.com> Signed-off-by: Thierry Reding <treding@nvidia.com> Signed-off-by: Tom Warren <twarren@nvidia.com>
45 lines
1,009 B
C
45 lines
1,009 B
C
/*
|
|
* (C) Copyright 2010-2013
|
|
* NVIDIA Corporation <www.nvidia.com>
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0+
|
|
*/
|
|
|
|
/* Tegra124 clock control definitions */
|
|
|
|
#ifndef _TEGRA124_CLOCK_H_
|
|
#define _TEGRA124_CLOCK_H_
|
|
|
|
#include <asm/arch-tegra/clock.h>
|
|
|
|
/* CLK_RST_CONTROLLER_OSC_CTRL_0 */
|
|
#define OSC_FREQ_SHIFT 28
|
|
#define OSC_FREQ_MASK (0xF << OSC_FREQ_SHIFT)
|
|
|
|
/* CLK_RST_CONTROLLER_PLLC_MISC_0 */
|
|
#define PLLC_IDDQ (1 << 26)
|
|
|
|
/* CLK_RST_CONTROLLER_CLK_SOURCE_SOR0_0 */
|
|
#define SOR0_CLK_SEL0 (1 << 14)
|
|
#define SOR0_CLK_SEL1 (1 << 15)
|
|
|
|
int tegra_plle_enable(void);
|
|
|
|
void clock_sor_enable_edp_clock(void);
|
|
|
|
/**
|
|
* clock_set_display_rate() - Set the display clock rate
|
|
*
|
|
* @frequency: the requested PLLD frequency
|
|
*
|
|
* Return the PLLD frequenc (which may not quite what was requested), or 0
|
|
* on failure
|
|
*/
|
|
u32 clock_set_display_rate(u32 frequency);
|
|
|
|
/**
|
|
* clock_set_up_plldp() - Set up the EDP clock ready for use
|
|
*/
|
|
void clock_set_up_plldp(void);
|
|
|
|
#endif /* _TEGRA124_CLOCK_H_ */
|