mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-11-04 14:00:19 +00:00 
			
		
		
		
	mx6: Factor out common HDMI setup code
Instead of duplicating HDMI setup code for every mx6 board, factor out the common code Signed-off-by: Pardeep Kumar Singla <b45784@freescale.com> Acked-By: Eric Nelson <eric.nelson@boundarydevices.com>
This commit is contained in:
		
							parent
							
								
									f8b1e86d47
								
							
						
					
					
						commit
						5ea7f0e328
					
				@ -468,6 +468,14 @@ int do_mx6_showclocks(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
 | 
			
		||||
	return 0;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void enable_ipu_clock(void)
 | 
			
		||||
{
 | 
			
		||||
	struct mxc_ccm_reg *mxc_ccm = (struct mxc_ccm_reg *)CCM_BASE_ADDR;
 | 
			
		||||
	int reg;
 | 
			
		||||
	reg = readl(&mxc_ccm->CCGR3);
 | 
			
		||||
	reg |= MXC_CCM_CCGR3_IPU1_IPU_DI0_OFFSET;
 | 
			
		||||
	writel(reg, &mxc_ccm->CCGR3);
 | 
			
		||||
}
 | 
			
		||||
/***************************************************/
 | 
			
		||||
 | 
			
		||||
U_BOOT_CMD(
 | 
			
		||||
 | 
			
		||||
@ -32,6 +32,8 @@
 | 
			
		||||
#include <asm/imx-common/boot_mode.h>
 | 
			
		||||
#include <asm/imx-common/dma.h>
 | 
			
		||||
#include <stdbool.h>
 | 
			
		||||
#include <asm/arch/mxc_hdmi.h>
 | 
			
		||||
#include <asm/arch/crm_regs.h>
 | 
			
		||||
 | 
			
		||||
struct scu_regs {
 | 
			
		||||
	u32	ctrl;
 | 
			
		||||
@ -228,3 +230,44 @@ const struct boot_mode soc_boot_modes[] = {
 | 
			
		||||
void s_init(void)
 | 
			
		||||
{
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#ifdef CONFIG_IMX_HDMI
 | 
			
		||||
void imx_enable_hdmi_phy(void)
 | 
			
		||||
{
 | 
			
		||||
	struct hdmi_regs *hdmi = (struct hdmi_regs *)HDMI_ARB_BASE_ADDR;
 | 
			
		||||
	u8 reg;
 | 
			
		||||
	reg = readb(&hdmi->phy_conf0);
 | 
			
		||||
	reg |= HDMI_PHY_CONF0_PDZ_MASK;
 | 
			
		||||
	writeb(reg, &hdmi->phy_conf0);
 | 
			
		||||
	udelay(3000);
 | 
			
		||||
	reg |= HDMI_PHY_CONF0_ENTMDS_MASK;
 | 
			
		||||
	writeb(reg, &hdmi->phy_conf0);
 | 
			
		||||
	udelay(3000);
 | 
			
		||||
	reg |= HDMI_PHY_CONF0_GEN2_TXPWRON_MASK;
 | 
			
		||||
	writeb(reg, &hdmi->phy_conf0);
 | 
			
		||||
	writeb(HDMI_MC_PHYRSTZ_ASSERT, &hdmi->mc_phyrstz);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void imx_setup_hdmi(void)
 | 
			
		||||
{
 | 
			
		||||
	struct mxc_ccm_reg *mxc_ccm = (struct mxc_ccm_reg *)CCM_BASE_ADDR;
 | 
			
		||||
	struct hdmi_regs *hdmi  = (struct hdmi_regs *)HDMI_ARB_BASE_ADDR;
 | 
			
		||||
	int reg;
 | 
			
		||||
 | 
			
		||||
	/* Turn on HDMI PHY clock */
 | 
			
		||||
	reg = readl(&mxc_ccm->CCGR2);
 | 
			
		||||
	reg |=  MXC_CCM_CCGR2_HDMI_TX_IAHBCLK_MASK|
 | 
			
		||||
		 MXC_CCM_CCGR2_HDMI_TX_ISFRCLK_MASK;
 | 
			
		||||
	writel(reg, &mxc_ccm->CCGR2);
 | 
			
		||||
	writeb(HDMI_MC_PHYRSTZ_DEASSERT, &hdmi->mc_phyrstz);
 | 
			
		||||
	reg = readl(&mxc_ccm->chsccdr);
 | 
			
		||||
	reg &= ~(MXC_CCM_CHSCCDR_IPU1_DI0_PRE_CLK_SEL_MASK|
 | 
			
		||||
		 MXC_CCM_CHSCCDR_IPU1_DI0_PODF_MASK|
 | 
			
		||||
		 MXC_CCM_CHSCCDR_IPU1_DI0_CLK_SEL_MASK);
 | 
			
		||||
	reg |= (CHSCCDR_PODF_DIVIDE_BY_3
 | 
			
		||||
		 << MXC_CCM_CHSCCDR_IPU1_DI0_PODF_OFFSET)
 | 
			
		||||
		 |(CHSCCDR_IPU_PRE_CLK_540M_PFD
 | 
			
		||||
		 << MXC_CCM_CHSCCDR_IPU1_DI0_PRE_CLK_SEL_OFFSET);
 | 
			
		||||
	writel(reg, &mxc_ccm->chsccdr);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
@ -65,5 +65,5 @@ void enable_ocotp_clk(unsigned char enable);
 | 
			
		||||
void enable_usboh3_clk(unsigned char enable);
 | 
			
		||||
int enable_sata_clock(void);
 | 
			
		||||
int enable_i2c_clk(unsigned char enable, unsigned i2c_num);
 | 
			
		||||
 | 
			
		||||
void enable_ipu_clock(void);
 | 
			
		||||
#endif /* __ASM_ARCH_CLOCK_H */
 | 
			
		||||
 | 
			
		||||
@ -21,6 +21,11 @@
 | 
			
		||||
#ifndef __MXC_HDMI_H__
 | 
			
		||||
#define __MXC_HDMI_H__
 | 
			
		||||
 | 
			
		||||
#ifdef CONFIG_IMX_HDMI
 | 
			
		||||
void imx_enable_hdmi_phy(void);
 | 
			
		||||
void imx_setup_hdmi(void);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Hdmi controller registers
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
@ -480,22 +480,9 @@ static int detect_hdmi(struct display_info_t const *dev)
 | 
			
		||||
	return readb(&hdmi->phy_stat0) & HDMI_PHY_HPD;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void enable_hdmi(struct display_info_t const *dev)
 | 
			
		||||
static void do_enable_hdmi(struct display_info_t const *dev)
 | 
			
		||||
{
 | 
			
		||||
	struct hdmi_regs *hdmi	= (struct hdmi_regs *)HDMI_ARB_BASE_ADDR;
 | 
			
		||||
	u8 reg;
 | 
			
		||||
	printf("%s: setup HDMI monitor\n", __func__);
 | 
			
		||||
	reg = readb(&hdmi->phy_conf0);
 | 
			
		||||
	reg |= HDMI_PHY_CONF0_PDZ_MASK;
 | 
			
		||||
	writeb(reg, &hdmi->phy_conf0);
 | 
			
		||||
 | 
			
		||||
	udelay(3000);
 | 
			
		||||
	reg |= HDMI_PHY_CONF0_ENTMDS_MASK;
 | 
			
		||||
	writeb(reg, &hdmi->phy_conf0);
 | 
			
		||||
	udelay(3000);
 | 
			
		||||
	reg |= HDMI_PHY_CONF0_GEN2_TXPWRON_MASK;
 | 
			
		||||
	writeb(reg, &hdmi->phy_conf0);
 | 
			
		||||
	writeb(HDMI_MC_PHYRSTZ_ASSERT, &hdmi->mc_phyrstz);
 | 
			
		||||
	imx_enable_hdmi_phy();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static int detect_i2c(struct display_info_t const *dev)
 | 
			
		||||
@ -528,7 +515,7 @@ static struct display_info_t const displays[] = {{
 | 
			
		||||
	.addr	= 0,
 | 
			
		||||
	.pixfmt	= IPU_PIX_FMT_RGB24,
 | 
			
		||||
	.detect	= detect_hdmi,
 | 
			
		||||
	.enable	= enable_hdmi,
 | 
			
		||||
	.enable	= do_enable_hdmi,
 | 
			
		||||
	.mode	= {
 | 
			
		||||
		.name           = "HDMI",
 | 
			
		||||
		.refresh        = 60,
 | 
			
		||||
@ -653,25 +640,15 @@ static void setup_display(void)
 | 
			
		||||
	struct mxc_ccm_reg *mxc_ccm = (struct mxc_ccm_reg *)CCM_BASE_ADDR;
 | 
			
		||||
	struct anatop_regs *anatop = (struct anatop_regs *)ANATOP_BASE_ADDR;
 | 
			
		||||
	struct iomuxc *iomux = (struct iomuxc *)IOMUXC_BASE_ADDR;
 | 
			
		||||
	struct hdmi_regs *hdmi	= (struct hdmi_regs *)HDMI_ARB_BASE_ADDR;
 | 
			
		||||
 | 
			
		||||
	int reg;
 | 
			
		||||
 | 
			
		||||
	enable_ipu_clock();
 | 
			
		||||
	imx_setup_hdmi();
 | 
			
		||||
	/* Turn on LDB0,IPU,IPU DI0 clocks */
 | 
			
		||||
	reg = __raw_readl(&mxc_ccm->CCGR3);
 | 
			
		||||
	reg |=   MXC_CCM_CCGR3_IPU1_IPU_DI0_OFFSET
 | 
			
		||||
		|MXC_CCM_CCGR3_LDB_DI0_MASK;
 | 
			
		||||
	reg |=  MXC_CCM_CCGR3_LDB_DI0_MASK;
 | 
			
		||||
	writel(reg, &mxc_ccm->CCGR3);
 | 
			
		||||
 | 
			
		||||
	/* Turn on HDMI PHY clock */
 | 
			
		||||
	reg = __raw_readl(&mxc_ccm->CCGR2);
 | 
			
		||||
	reg |=  MXC_CCM_CCGR2_HDMI_TX_IAHBCLK_MASK
 | 
			
		||||
	       |MXC_CCM_CCGR2_HDMI_TX_ISFRCLK_MASK;
 | 
			
		||||
	writel(reg, &mxc_ccm->CCGR2);
 | 
			
		||||
 | 
			
		||||
	/* clear HDMI PHY reset */
 | 
			
		||||
	writeb(HDMI_MC_PHYRSTZ_DEASSERT, &hdmi->mc_phyrstz);
 | 
			
		||||
 | 
			
		||||
	/* set PFD1_FRAC to 0x13 == 455 MHz (480*18)/0x13 */
 | 
			
		||||
	writel(ANATOP_PFD_480_PFD1_FRAC_MASK, &anatop->pfd_480_clr);
 | 
			
		||||
	writel(0x13<<ANATOP_PFD_480_PFD1_FRAC_SHIFT, &anatop->pfd_480_set);
 | 
			
		||||
@ -689,15 +666,8 @@ static void setup_display(void)
 | 
			
		||||
	writel(reg, &mxc_ccm->cscmr2);
 | 
			
		||||
 | 
			
		||||
	reg = readl(&mxc_ccm->chsccdr);
 | 
			
		||||
	reg &= ~(MXC_CCM_CHSCCDR_IPU1_DI0_PRE_CLK_SEL_MASK
 | 
			
		||||
		|MXC_CCM_CHSCCDR_IPU1_DI0_PODF_MASK
 | 
			
		||||
		|MXC_CCM_CHSCCDR_IPU1_DI0_CLK_SEL_MASK);
 | 
			
		||||
	reg |= (CHSCCDR_CLK_SEL_LDB_DI0
 | 
			
		||||
		<<MXC_CCM_CHSCCDR_IPU1_DI0_CLK_SEL_OFFSET)
 | 
			
		||||
	      |(CHSCCDR_PODF_DIVIDE_BY_3
 | 
			
		||||
		<<MXC_CCM_CHSCCDR_IPU1_DI0_PODF_OFFSET)
 | 
			
		||||
	      |(CHSCCDR_IPU_PRE_CLK_540M_PFD
 | 
			
		||||
		<<MXC_CCM_CHSCCDR_IPU1_DI0_PRE_CLK_SEL_OFFSET);
 | 
			
		||||
		<<MXC_CCM_CHSCCDR_IPU1_DI0_CLK_SEL_OFFSET);
 | 
			
		||||
	writel(reg, &mxc_ccm->chsccdr);
 | 
			
		||||
 | 
			
		||||
	reg = IOMUXC_GPR2_BGREF_RRMODE_EXTERNAL_RES
 | 
			
		||||
 | 
			
		||||
@ -211,23 +211,6 @@ int board_phy_config(struct phy_device *phydev)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if defined(CONFIG_VIDEO_IPUV3)
 | 
			
		||||
static void enable_hdmi(void)
 | 
			
		||||
{
 | 
			
		||||
	struct hdmi_regs *hdmi	= (struct hdmi_regs *)HDMI_ARB_BASE_ADDR;
 | 
			
		||||
	u8 reg;
 | 
			
		||||
	reg = readb(&hdmi->phy_conf0);
 | 
			
		||||
	reg |= HDMI_PHY_CONF0_PDZ_MASK;
 | 
			
		||||
	writeb(reg, &hdmi->phy_conf0);
 | 
			
		||||
 | 
			
		||||
	udelay(3000);
 | 
			
		||||
	reg |= HDMI_PHY_CONF0_ENTMDS_MASK;
 | 
			
		||||
	writeb(reg, &hdmi->phy_conf0);
 | 
			
		||||
	udelay(3000);
 | 
			
		||||
	reg |= HDMI_PHY_CONF0_GEN2_TXPWRON_MASK;
 | 
			
		||||
	writeb(reg, &hdmi->phy_conf0);
 | 
			
		||||
	writeb(HDMI_MC_PHYRSTZ_ASSERT, &hdmi->mc_phyrstz);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static struct fb_videomode const hdmi = {
 | 
			
		||||
	.name           = "HDMI",
 | 
			
		||||
	.refresh        = 60,
 | 
			
		||||
@ -253,7 +236,7 @@ int board_video_skip(void)
 | 
			
		||||
	if (ret)
 | 
			
		||||
		printf("HDMI cannot be configured: %d\n", ret);
 | 
			
		||||
 | 
			
		||||
	enable_hdmi();
 | 
			
		||||
	imx_enable_hdmi_phy();
 | 
			
		||||
 | 
			
		||||
	return ret;
 | 
			
		||||
}
 | 
			
		||||
@ -261,33 +244,14 @@ int board_video_skip(void)
 | 
			
		||||
static void setup_display(void)
 | 
			
		||||
{
 | 
			
		||||
	struct mxc_ccm_reg *mxc_ccm = (struct mxc_ccm_reg *)CCM_BASE_ADDR;
 | 
			
		||||
	struct hdmi_regs *hdmi	= (struct hdmi_regs *)HDMI_ARB_BASE_ADDR;
 | 
			
		||||
	int reg;
 | 
			
		||||
 | 
			
		||||
	/* Turn on IPU clock */
 | 
			
		||||
	reg = readl(&mxc_ccm->CCGR3);
 | 
			
		||||
	reg |= MXC_CCM_CCGR3_IPU1_IPU_DI0_OFFSET;
 | 
			
		||||
	writel(reg, &mxc_ccm->CCGR3);
 | 
			
		||||
 | 
			
		||||
	/* Turn on HDMI PHY clock */
 | 
			
		||||
	reg = readl(&mxc_ccm->CCGR2);
 | 
			
		||||
	reg |=  MXC_CCM_CCGR2_HDMI_TX_IAHBCLK_MASK
 | 
			
		||||
		| MXC_CCM_CCGR2_HDMI_TX_ISFRCLK_MASK;
 | 
			
		||||
	writel(reg, &mxc_ccm->CCGR2);
 | 
			
		||||
 | 
			
		||||
	/* clear HDMI PHY reset */
 | 
			
		||||
	writeb(HDMI_MC_PHYRSTZ_DEASSERT, &hdmi->mc_phyrstz);
 | 
			
		||||
	enable_ipu_clock();
 | 
			
		||||
	imx_setup_hdmi();
 | 
			
		||||
 | 
			
		||||
	reg = readl(&mxc_ccm->chsccdr);
 | 
			
		||||
	reg &= ~(MXC_CCM_CHSCCDR_IPU1_DI0_PRE_CLK_SEL_MASK
 | 
			
		||||
		| MXC_CCM_CHSCCDR_IPU1_DI0_PODF_MASK
 | 
			
		||||
		| MXC_CCM_CHSCCDR_IPU1_DI0_CLK_SEL_MASK);
 | 
			
		||||
	reg |= (CHSCCDR_CLK_SEL_LDB_DI0
 | 
			
		||||
		<< MXC_CCM_CHSCCDR_IPU1_DI0_CLK_SEL_OFFSET)
 | 
			
		||||
	      | (CHSCCDR_PODF_DIVIDE_BY_3
 | 
			
		||||
		<< MXC_CCM_CHSCCDR_IPU1_DI0_PODF_OFFSET)
 | 
			
		||||
	      | (CHSCCDR_IPU_PRE_CLK_540M_PFD
 | 
			
		||||
		<< MXC_CCM_CHSCCDR_IPU1_DI0_PRE_CLK_SEL_OFFSET);
 | 
			
		||||
		<< MXC_CCM_CHSCCDR_IPU1_DI0_CLK_SEL_OFFSET);
 | 
			
		||||
	writel(reg, &mxc_ccm->chsccdr);
 | 
			
		||||
}
 | 
			
		||||
#endif /* CONFIG_VIDEO_IPUV3 */
 | 
			
		||||
 | 
			
		||||
@ -154,6 +154,7 @@
 | 
			
		||||
#define CONFIG_IPUV3_CLK 260000000
 | 
			
		||||
#define CONFIG_CMD_HDMIDETECT
 | 
			
		||||
#define CONFIG_CONSOLE_MUX
 | 
			
		||||
#define CONFIG_IMX_HDMI
 | 
			
		||||
 | 
			
		||||
/* allow to overwrite serial and ethaddr */
 | 
			
		||||
#define CONFIG_ENV_OVERWRITE
 | 
			
		||||
 | 
			
		||||
@ -100,6 +100,7 @@
 | 
			
		||||
#define CONFIG_VIDEO_LOGO
 | 
			
		||||
#define CONFIG_VIDEO_BMP_LOGO
 | 
			
		||||
#define CONFIG_IPUV3_CLK 260000000
 | 
			
		||||
#define CONFIG_IMX_HDMI
 | 
			
		||||
 | 
			
		||||
#if defined(CONFIG_MX6DL)
 | 
			
		||||
#define CONFIG_DEFAULT_FDT_FILE		"imx6dl-wandboard.dtb"
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user