diff options
Diffstat (limited to 'board/freescale')
55 files changed, 2131 insertions, 1188 deletions
| diff --git a/board/freescale/b4860qds/b4860qds.c b/board/freescale/b4860qds/b4860qds.c index 86e44eae0..f74651c52 100644 --- a/board/freescale/b4860qds/b4860qds.c +++ b/board/freescale/b4860qds/b4860qds.c @@ -21,12 +21,14 @@  #include "../common/qixis.h"  #include "../common/vsc3316_3308.h" +#include "../common/idt8t49n222a_serdes_clk.h"  #include "b4860qds.h"  #include "b4860qds_qixis.h"  #include "b4860qds_crossbar_con.h"  #define CLK_MUX_SEL_MASK	0x4  #define ETH_PHY_CLK_OUT		0x4 +#define PLL_NUM			2  DECLARE_GLOBAL_DATA_PTR; @@ -35,8 +37,6 @@ int checkboard(void)  	char buf[64];  	u8 sw;  	struct cpu_type *cpu = gd->arch.cpu; -	ccsr_gur_t *gur = (void *)CONFIG_SYS_MPC85xx_GUTS_ADDR; -	unsigned int i;  	static const char *const freq[] = {"100", "125", "156.25", "161.13",  						"122.88", "122.88", "122.88"};  	int clock; @@ -61,19 +61,6 @@ int checkboard(void)  	/* the timestamp string contains "\n" at the end */  	printf(" on %s", qixis_read_time(buf)); -	/* Display the RCW, so that no one gets confused as to what RCW -	 * we're actually using for this boot. -	 */ -	puts("Reset Configuration Word (RCW):"); -	for (i = 0; i < ARRAY_SIZE(gur->rcwsr); i++) { -		u32 rcw = in_be32(&gur->rcwsr[i]); - -		if ((i % 4) == 0) -			printf("\n       %08x:", i * 4); -		printf(" %08x", rcw); -	} -	puts("\n"); -  	/*  	 * Display the actual SERDES reference clocks as configured by the  	 * dip switches on the board.  Note that the SWx registers could @@ -252,6 +239,106 @@ int configure_vsc3316_3308(void)  	return 0;  } +int config_serdes1_refclks(void) +{ +	ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); +	serdes_corenet_t *srds_regs = +		(void *)CONFIG_SYS_FSL_CORENET_SERDES_ADDR; +	u32 serdes1_prtcl, lane; +	unsigned int flag_sgmii_prtcl = 0; +	int ret, i; + +	serdes1_prtcl = in_be32(&gur->rcwsr[4]) & +			FSL_CORENET2_RCWSR4_SRDS1_PRTCL; +	if (!serdes1_prtcl) { +		printf("SERDES1 is not enabled\n"); +		return -1; +	} +	serdes1_prtcl >>= FSL_CORENET2_RCWSR4_SRDS1_PRTCL_SHIFT; +	debug("Using SERDES1 Protocol: 0x%x:\n", serdes1_prtcl); + +	/* Clear SRDS_RSTCTL_RST bit for both PLLs before changing refclks +	 */ +	for (i = 0; i < PLL_NUM; i++) +		clrbits_be32(&srds_regs->bank[i].rstctl, SRDS_RSTCTL_RST); +	/* Reconfigure IDT idt8t49n222a device for CPRI to work +	 * For this SerDes1's Refclk1 and refclk2 need to be set +	 * to 122.88MHz +	 */ +	switch (serdes1_prtcl) { +	case 0x2A: +	case 0x2C: +	case 0x2D: +	case 0x2E: +		debug("Configuring idt8t49n222a for CPRI SerDes clks:" +			" for srds_prctl:%x\n", serdes1_prtcl); +		ret = select_i2c_ch_pca(I2C_CH_IDT); +		if (!ret) { +			ret = set_serdes_refclk(IDT_SERDES1_ADDRESS, 1, +					SERDES_REFCLK_122_88, +					SERDES_REFCLK_122_88, 0); +			if (ret) { +				printf("IDT8T49N222A configuration failed.\n"); +				return ret; +			} else +				printf("IDT8T49N222A configured.\n"); +		} else { +			return ret; +		} +		select_i2c_ch_pca(I2C_CH_DEFAULT); + +		/* Change SerDes1's Refclk1 to 125MHz for on board +		 * SGMIIs to work +		 */ +		for (lane = 0; lane < SRDS_MAX_LANES; lane++) { +			enum srds_prtcl lane_prtcl = serdes_get_prtcl +						(0, serdes1_prtcl, lane); +			switch (lane_prtcl) { +			case SGMII_FM1_DTSEC1: +			case SGMII_FM1_DTSEC2: +			case SGMII_FM1_DTSEC3: +			case SGMII_FM1_DTSEC4: +			case SGMII_FM1_DTSEC5: +			case SGMII_FM1_DTSEC6: +				flag_sgmii_prtcl++; +				break; +			default: +				break; +			} +		} + +		if (flag_sgmii_prtcl) +			QIXIS_WRITE(brdcfg[4], QIXIS_SRDS1CLK_125); + +		/* Steps For SerDes PLLs reset and reconfiguration after +		 * changing SerDes's refclks +		 */ +		for (i = 0; i < PLL_NUM; i++) { +			debug("For PLL%d reset and reconfiguration after" +			       " changing refclks\n", i+1); +			clrbits_be32(&srds_regs->bank[i].rstctl, +					SRDS_RSTCTL_SDRST_B); +			udelay(10); +			clrbits_be32(&srds_regs->bank[i].rstctl, +				(SRDS_RSTCTL_SDEN | SRDS_RSTCTL_PLLRST_B)); +			udelay(10); +			setbits_be32(&srds_regs->bank[i].rstctl, +					SRDS_RSTCTL_RST); +			setbits_be32(&srds_regs->bank[i].rstctl, +				(SRDS_RSTCTL_SDEN | SRDS_RSTCTL_PLLRST_B +				| SRDS_RSTCTL_SDRST_B)); +		} +		break; +	default: +		printf("WARNING:IDT8T49N222A configuration not" +			" supported for:%x SerDes1 Protocol.\n", +			serdes1_prtcl); +		return -1; +	} + +	return 0; +} +  int board_early_init_r(void)  {  	const unsigned int flashbase = CONFIG_SYS_FLASH_BASE; @@ -277,6 +364,16 @@ int board_early_init_r(void)  #ifdef CONFIG_SYS_DPAA_QBMAN  	setup_portals();  #endif +	/* SerDes1 refclks need to be set again, as default clks +	 * are not suitable for CPRI and onboard SGMIIs to work +	 * simultaneously. +	 * This function will set SerDes1's Refclk1 and refclk2 +	 * as per SerDes1 protocols +	 */ +	if (config_serdes1_refclks()) +		printf("SerDes1 Refclks couldn't set properly.\n"); +	else +		printf("SerDes1 Refclks have been set.\n");  	/* Configure VSC3316 and VSC3308 crossbar switches */  	if (configure_vsc3316_3308()) diff --git a/board/freescale/b4860qds/b4860qds_crossbar_con.h b/board/freescale/b4860qds/b4860qds_crossbar_con.h index 6e64745b0..db0cf28ff 100644 --- a/board/freescale/b4860qds/b4860qds_crossbar_con.h +++ b/board/freescale/b4860qds/b4860qds_crossbar_con.h @@ -13,10 +13,10 @@  static const int8_t vsc16_tx_amc[8][2] = { {15, 3}, {0, 2}, {7, 4}, {9, 10},  				{5, 11}, {4, 5}, {2, 6}, {12, 9} }; -static const int8_t vsc16_tx_sfp[8][2] = { {15, 7}, {0, 1}, {7, 8}, {9, 0}, +static int8_t vsc16_tx_sfp[8][2] = { {15, 7}, {0, 1}, {7, 8}, {9, 0},  				{-1, -1}, {-1, -1}, {-1, -1}, {-1, -1} }; -static const int8_t vsc16_tx_4sfp_sgmii_12_56[8][2] = { {15, 7}, {0, 1}, +static int8_t vsc16_tx_4sfp_sgmii_12_56[8][2] = { {15, 7}, {0, 1},  				{7, 8}, {9, 0}, {2, 14}, {12, 15},  				{-1, -1}, {-1, -1} }; @@ -25,7 +25,7 @@ static const int8_t vsc16_tx_4sfp_sgmii_34[8][2] = { {15, 7}, {0, 1},  				{-1, -1}, {-1, -1} };  #ifdef CONFIG_PPC_B4420 -static const int8_t vsc16_tx_sgmii_lane_cd[8][2] = { {5, 14}, {4, 15}, +static int8_t vsc16_tx_sgmii_lane_cd[8][2] = { {5, 14}, {4, 15},  		{-1, -1}, {-1, -1}, {-1, -1}, {-1, -1}, {-1, -1}, {-1, -1} };  #endif @@ -35,10 +35,10 @@ static const int8_t vsc16_tx_aurora[8][2] = { {2, 13}, {12, 12}, {-1, -1},  static const int8_t vsc16_rx_amc[8][2] = { {3, 15}, {2, 1}, {4, 8}, {10, 9},  				{11, 11}, {5, 10}, {6, 3}, {9, 12} }; -static const int8_t vsc16_rx_sfp[8][2] = { {8, 15}, {0, 1}, {7, 8}, {1, 9}, +static int8_t vsc16_rx_sfp[8][2] = { {8, 15}, {0, 1}, {7, 8}, {1, 9},  				{-1, -1}, {-1, -1}, {-1, -1}, {-1, -1} }; -static const int8_t vsc16_rx_4sfp_sgmii_12_56[8][2] = { {8, 15}, {0, 1}, +static int8_t vsc16_rx_4sfp_sgmii_12_56[8][2] = { {8, 15}, {0, 1},  				{7, 8}, {1, 9}, {14, 3}, {15, 12},  				{-1, -1}, {-1, -1} }; @@ -47,7 +47,7 @@ static const int8_t vsc16_rx_4sfp_sgmii_34[8][2] = { {8, 15}, {0, 1},  				{-1, -1}, {-1, -1} };  #ifdef CONFIG_PPC_B4420 -static const int8_t vsc16_rx_sgmii_lane_cd[8][2] = { {14, 11}, {15, 10}, +static int8_t vsc16_rx_sgmii_lane_cd[8][2] = { {14, 11}, {15, 10},  		{-1, -1}, {-1, -1}, {-1, -1}, {-1, -1}, {-1, -1}, {-1, -1} };  #endif diff --git a/board/freescale/b4860qds/eth_b4860qds.c b/board/freescale/b4860qds/eth_b4860qds.c index 19ca66e3d..dc4ef80fc 100644 --- a/board/freescale/b4860qds/eth_b4860qds.c +++ b/board/freescale/b4860qds/eth_b4860qds.c @@ -201,8 +201,6 @@ int board_eth_init(bd_t *bis)  		debug("Setting phy addresses for FM1_DTSEC5: %x and"  			"FM1_DTSEC6: %x\n", CONFIG_SYS_FM1_DTSEC5_PHY_ADDR,  			CONFIG_SYS_FM1_DTSEC6_PHY_ADDR); -		/* Fixing Serdes clock by programming FPGA register */ -		QIXIS_WRITE(brdcfg[4], QIXIS_SRDS1CLK_125);  		fm_info_set_phy_address(FM1_DTSEC5,  				CONFIG_SYS_FM1_DTSEC5_PHY_ADDR);  		fm_info_set_phy_address(FM1_DTSEC6, diff --git a/board/freescale/bsc9131rdb/ddr.c b/board/freescale/bsc9131rdb/ddr.c index a4161ad64..c82fe0aab 100644 --- a/board/freescale/bsc9131rdb/ddr.c +++ b/board/freescale/bsc9131rdb/ddr.c @@ -87,7 +87,7 @@ phys_size_t fixed_sdram(void)  	}  	ddr_size = (phys_size_t) CONFIG_SYS_SDRAM_SIZE * 1024 * 1024; -	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 0); +	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 0, 0);  	if (set_ddr_laws(CONFIG_SYS_DDR_SDRAM_BASE, ddr_size,  					LAW_TRGT_IF_DDR_1) < 0) { diff --git a/board/freescale/bsc9132qds/bsc9132qds.c b/board/freescale/bsc9132qds/bsc9132qds.c index 457489416..a895e4e29 100644 --- a/board/freescale/bsc9132qds/bsc9132qds.c +++ b/board/freescale/bsc9132qds/bsc9132qds.c @@ -125,6 +125,27 @@ void board_config_serdes_mux(void)  	}  } +/* Configure DSP DDR controller */ +void dsp_ddr_configure(void) +{ +	/* +	 *There are separate DDR-controllers for DSP and PowerPC side DDR. +	 *copy the ddr controller settings from PowerPC side DDR controller +	 *to the DSP DDR controller as connected DDR memories are similar. +	 */ +	ccsr_ddr_t __iomem *pa_ddr = +			(ccsr_ddr_t __iomem *)CONFIG_SYS_MPC8xxx_DDR_ADDR; +	ccsr_ddr_t temp_ddr; +	ccsr_ddr_t __iomem *dsp_ddr = +			(ccsr_ddr_t __iomem *)CONFIG_SYS_FSL_DSP_CCSR_DDR_ADDR; + +	memcpy(&temp_ddr, pa_ddr, sizeof(ccsr_ddr_t)); +	temp_ddr.cs0_bnds = CONFIG_SYS_DDR1_CS0_BNDS; +	temp_ddr.sdram_cfg &= ~SDRAM_CFG_MEM_EN; +	memcpy(dsp_ddr, &temp_ddr, sizeof(ccsr_ddr_t)); +	dsp_ddr->sdram_cfg |= SDRAM_CFG_MEM_EN; +} +  int board_early_init_r(void)  {  #ifndef CONFIG_SYS_NO_FLASH @@ -153,6 +174,7 @@ int board_early_init_r(void)  			0, flash_esel+1, BOOKE_PAGESZ_64M, 1);  #endif  	board_config_serdes_mux(); +	dsp_ddr_configure();  	return 0;  } diff --git a/board/freescale/bsc9132qds/ddr.c b/board/freescale/bsc9132qds/ddr.c index 05bea8ad5..fdea19312 100644 --- a/board/freescale/bsc9132qds/ddr.c +++ b/board/freescale/bsc9132qds/ddr.c @@ -109,7 +109,7 @@ phys_size_t fixed_sdram(void)  					strmhz(buf, ddr_freq));  	ddr_size = (phys_size_t) CONFIG_SYS_SDRAM_SIZE * 1024 * 1024; -	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 0); +	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 0, 0);  	if (set_ddr_laws(CONFIG_SYS_DDR_SDRAM_BASE, ddr_size,  					LAW_TRGT_IF_DDR_1) < 0) { diff --git a/board/freescale/bsc9132qds/law.c b/board/freescale/bsc9132qds/law.c index fed2edf44..e10de9adc 100644 --- a/board/freescale/bsc9132qds/law.c +++ b/board/freescale/bsc9132qds/law.c @@ -16,6 +16,14 @@ struct law_entry law_table[] = {  #ifdef CONFIG_SYS_FPGA_BASE_PHYS  	SET_LAW(CONFIG_SYS_FPGA_BASE_PHYS, LAW_SIZE_128K, LAW_TRGT_IF_IFC),  #endif +	SET_LAW(CONFIG_SYS_FSL_DSP_CCSRBAR_PHYS, LAW_SIZE_1M, +		LAW_TRGT_IF_DSP_CCSR), +	SET_LAW(CONFIG_SYS_FSL_DSP_M2_RAM_ADDR, LAW_SIZE_32M, +		LAW_TRGT_IF_OCN_DSP), +	SET_LAW(CONFIG_SYS_FSL_DSP_M3_RAM_ADDR, LAW_SIZE_32K, +		LAW_TRGT_IF_CLASS_DSP), +	SET_LAW(CONFIG_SYS_FSL_DSP_DDR_ADDR, LAW_SIZE_1G, +		LAW_TRGT_IF_CLASS_DSP)  };  int num_law_entries = ARRAY_SIZE(law_table); diff --git a/board/freescale/bsc9132qds/tlb.c b/board/freescale/bsc9132qds/tlb.c index 6d8235341..02655e9ba 100644 --- a/board/freescale/bsc9132qds/tlb.c +++ b/board/freescale/bsc9132qds/tlb.c @@ -41,6 +41,11 @@ struct fsl_e_tlb_entry tlb_table[] = {  			MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G,  			0, 1, BOOKE_PAGESZ_1M, 1), +	/* CCSRBAR (DSP) */ +	SET_TLB_ENTRY(1, CONFIG_SYS_FSL_DSP_CCSRBAR, +		      CONFIG_SYS_FSL_DSP_CCSRBAR_PHYS, MAS3_SW|MAS3_SR, +		      MAS2_I|MAS2_G, 0, 2, BOOKE_PAGESZ_1M, 1), +  #ifndef CONFIG_SPL_BUILD  	SET_TLB_ENTRY(1, CONFIG_SYS_FLASH_BASE, CONFIG_SYS_FLASH_BASE_PHYS,  			MAS3_SX|MAS3_SR, MAS2_W|MAS2_G, diff --git a/board/freescale/mx6qsabrelite/Makefile b/board/freescale/c29xpcie/Makefile index 141437c12..ab8eb8f72 100644 --- a/board/freescale/mx6qsabrelite/Makefile +++ b/board/freescale/c29xpcie/Makefile @@ -1,21 +1,23 @@  # -# Copyright (C) 2007, Guennadi Liakhovetski <lg@denx.de> -# -# (C) Copyright 2011 Freescale Semiconductor, Inc. +# Copyright 2013 Freescale Semiconductor, Inc.  #  # SPDX-License-Identifier:	GPL-2.0+ -#  include $(TOPDIR)/config.mk -LIB    = $(obj)lib$(BOARD).o +LIB	= $(obj)lib$(BOARD).o -COBJS  := mx6qsabrelite.o +COBJS-y	+= $(BOARD).o +COBJS-y	+= cpld.o +COBJS-y	+= ddr.o +COBJS-y	+= law.o +COBJS-y	+= tlb.o -SRCS   := $(COBJS:.o=.c) -OBJS   := $(addprefix $(obj),$(COBJS)) +SRCS	:= $(SOBJS:.o=.S) $(COBJS-y:.o=.c) +OBJS	:= $(addprefix $(obj),$(COBJS-y)) +SOBJS	:= $(addprefix $(obj),$(SOBJS)) -$(LIB):        $(obj).depend $(OBJS) +$(LIB):	$(obj).depend $(OBJS) $(SOBJS)  	$(call cmd_link_o_target, $(OBJS))  ######################################################################### diff --git a/board/freescale/c29xpcie/README b/board/freescale/c29xpcie/README new file mode 100644 index 000000000..430f08244 --- /dev/null +++ b/board/freescale/c29xpcie/README @@ -0,0 +1,100 @@ +Overview +========= +C29XPCIE board is a series of Freescale PCIe add-in cards to perform +as public key crypto accelerator or secure key management module. +It includes C293PCIE board, C293PCIE board and C291PCIE board. +The Freescale C29x family is a high performance crypto co-processor. +It combines a single e500v2 core with necessary SEC engines. +(maximum core frequency 1000/1200 MHz). + +The C29xPCIE board features are as follows: +Memory subsystem: +	- 512Mbyte unbuffered DDR3 SDRAM discrete devices (32-bit bus) +	- 64 Mbyte NOR flash single-chip memory +	- 4 Gbyte NAND flash memory +	- 1 Mbit AT24C1024 I2C EEPROM +	- 16 Mbyte SPI memory + +Interfaces: +	- 10/100/1000 BaseT Ethernet ports: +		- eTSEC1, RGMII: one 10/100/1000 port +		- eTSEC2, RGMII: one 10/100/1000 port +	- DUART interface: +		- DUART interface: supports two UARTs up to 115200 bps for +		   console display + +Board connectors: +	- Mini-ITX power supply connector +	- JTAG/COP for debugging + +Physical Memory Map on C29xPCIE +=============================== +Address Start   Address End   Memory type +0x0_0000_0000 - 0x0_1fff_ffff   512MB DDR +0xc_0000_0000 - 0xc_8fff_ffff   256MB PCIE memory +0xf_ec00_0000 - 0xf_efff_ffff   64MB NOR flash +0xf_ffb0_0000 - 0xf_ffb7_ffff   512KB SRAM +0xf_ffc0_0000 - 0xf_ffc0_ffff   64KB PCIE IO +0xf_ffdf_0000 - 0xf_ffdf_0fff   4KB CPLD +0xf_ffe0_0000 - 0xf_ffef_ffff   1MB CCSR + +Serial Port Configuration on C29xPCIE +===================================== +Configure the serial port of the attached computer with the following values: +	-Data rate: 115200 bps +	-Number of data bits: 8 +	-Parity: None +	-Number of Stop bits: 1 +	-Flow Control: Hardware/None + +Settings of DIP-switch +====================== +  SW5[1:4]= 1111 and SW5[6]=0 for boot from 16bit NOR flash +  SW5[1:4]= 0110 and SW5[6]=0 for boot from SPI flash +Note: 1 stands for 'off', 0 stands for 'on' + +Build and program u-boot to NOR flash +================================== +1. Build u-boot.bin image example: +	export ARCH=powerpc +	export CROSS_COMPILE=/your_path/powerpc-linux-gnu- +	make C293PCIE + +2. Program u-boot.bin into NOR flash +	=> tftp $loadaddr $uboot +	=> protect off eff80000 +$filesize +	=> erase eff80000 +$filesize +	=> cp.b $loadaddr eff80000 $filesize + +3. Check SW5[1:4]= 1111 and SW5[6]=0, then power on. + +Alternate NOR bank +================== +There are four banks in C29XPCIE board, example to change bank booting: +1. Program u-boot.bin into alternate NOR bank +	=> tftp $loadaddr $uboot +	=> protect off e9f80000 +$filesize +	=> erase e9f80000 +$filesize +	=> cp.b $loadaddr e9f80000 $filesize + +2. Switch to alternate NOR bank +	=> cpld_cmd reset altbank [bank] +	- [bank] bank value select 1-4 +	- bank 1 on the flash 0x0000000~0x0ffffff +	- bank 2 on the flash 0x1000000~0x1ffffff +	- bank 3 on the flash 0x2000000~0x2ffffff +	- bank 4 on the flash 0x3000000~0x3ffffff +	or set SW5[7]= ON/OFF and SW5[7]= ON/OFF, then power on again. + +Build and program u-boot to SPI flash +================================== +1. Build u-boot-spi.bin image +	make C29xPCIE_SPIFLASH_config; make +	Need the boot_format tool to generate u-boot-spi.bin from the u-boot.bin. + +2. Program u-boot-spi.bin into SPI flash +	=> tftp $loadaddr $uboot-spi +	=> sf erase 0 100000 +	=> sf write $loadaddr 0 $filesize + +3. Check SW5[1:4]= 0110 and SW5[6]=0, then power on. diff --git a/board/freescale/c29xpcie/c29xpcie.c b/board/freescale/c29xpcie/c29xpcie.c new file mode 100644 index 000000000..48c4b308b --- /dev/null +++ b/board/freescale/c29xpcie/c29xpcie.c @@ -0,0 +1,148 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <asm/processor.h> +#include <asm/mmu.h> +#include <asm/cache.h> +#include <asm/immap_85xx.h> +#include <asm/io.h> +#include <miiphy.h> +#include <libfdt.h> +#include <fdt_support.h> +#include <fsl_mdio.h> +#include <tsec.h> +#include <mmc.h> +#include <netdev.h> +#include <pci.h> +#include <asm/fsl_ifc.h> +#include <asm/fsl_pci.h> + +#include "cpld.h" + +DECLARE_GLOBAL_DATA_PTR; + +int checkboard(void) +{ +	struct cpu_type *cpu = gd->arch.cpu; +	struct cpld_data *cpld_data = (void *)(CONFIG_SYS_CPLD_BASE); + +	printf("Board: %sPCIe, ", cpu->name); +	printf("CPLD Ver: 0x%02x\n", in_8(&cpld_data->cpldver)); + +	return 0; +} + +int board_early_init_f(void) +{ +	struct fsl_ifc *ifc = (void *)CONFIG_SYS_IFC_ADDR; + +	/* Clock configuration to access CPLD using IFC(GPCM) */ +	setbits_be32(&ifc->ifc_gcr, 1 << IFC_GCR_TBCTL_TRN_TIME_SHIFT); + +	return 0; +} + +int board_early_init_r(void) +{ +	const unsigned long flashbase = CONFIG_SYS_FLASH_BASE; +	const u8 flash_esel = find_tlb_idx((void *)flashbase, 1); + +	/* +	 * Remap Boot flash region to caching-inhibited +	 * so that flash can be erased properly. +	 */ + +	/* Flush d-cache and invalidate i-cache of any FLASH data */ +	flush_dcache(); +	invalidate_icache(); + +	/* invalidate existing TLB entry for flash */ +	disable_tlb(flash_esel); + +	set_tlb(1, flashbase, CONFIG_SYS_FLASH_BASE_PHYS, +			MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +			0, flash_esel, BOOKE_PAGESZ_64M, 1); + +	return 0; +} + +#ifdef CONFIG_PCI +void pci_init_board(void) +{ +	fsl_pcie_init_board(0); +} +#endif /* ifdef CONFIG_PCI */ + +#ifdef CONFIG_TSEC_ENET +int board_eth_init(bd_t *bis) +{ +	struct fsl_pq_mdio_info mdio_info; +	struct tsec_info_struct tsec_info[2]; +	int num = 0; + +#ifdef CONFIG_TSEC1 +	SET_STD_TSEC_INFO(tsec_info[num], 1); +	num++; +#endif +#ifdef CONFIG_TSEC2 +	SET_STD_TSEC_INFO(tsec_info[num], 2); +	num++; +#endif +	if (!num) { +		printf("No TSECs initialized\n"); +		return 0; +	} + +	/* Register 1G MDIO bus */ +	mdio_info.regs = (struct tsec_mii_mng *)CONFIG_SYS_MDIO_BASE_ADDR; +	mdio_info.name = DEFAULT_MII_NAME; + +	fsl_pq_mdio_init(bis, &mdio_info); + +	tsec_eth_init(bis, tsec_info, num); + +	return pci_eth_init(bis); +} +#endif + +#if defined(CONFIG_OF_BOARD_SETUP) +void fdt_del_sec(void *blob, int offset) +{ +	int nodeoff = 0; + +	while ((nodeoff = fdt_node_offset_by_compat_reg(blob, "fsl,sec-v6.0", +			CONFIG_SYS_CCSRBAR_PHYS + CONFIG_SYS_FSL_SEC_OFFSET +			+ offset * 0x20000)) >= 0) { +		fdt_del_node(blob, nodeoff); +		offset++; +	} +} + +void ft_board_setup(void *blob, bd_t *bd) +{ +	phys_addr_t base; +	phys_size_t size; +	struct cpu_type *cpu; + +	cpu = gd->arch.cpu; + +	ft_cpu_setup(blob, bd); + +	base = getenv_bootm_low(); +	size = getenv_bootm_size(); + +#if defined(CONFIG_PCI) +	FT_FSL_PCI_SETUP; +#endif + +	fdt_fixup_memory(blob, (u64)base, (u64)size); +	if (cpu->soc_ver == SVR_C291) +		fdt_del_sec(blob, 1); +	else if (cpu->soc_ver == SVR_C292) +		fdt_del_sec(blob, 2); +} +#endif diff --git a/board/freescale/c29xpcie/cpld.c b/board/freescale/c29xpcie/cpld.c new file mode 100644 index 000000000..5cbccff63 --- /dev/null +++ b/board/freescale/c29xpcie/cpld.c @@ -0,0 +1,131 @@ +/** + * Copyright 2013 Freescale Semiconductor + * Author: Mingkai Hu <Mingkai.hu@freescale.com> + *         Po Liu <Po.Liu@freescale.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + * + * This file provides support for the board-specific CPLD used on some Freescale + * reference boards. + * + * The following macros need to be defined: + * + * CONFIG_SYS_CPLD_BASE - The virtual address of the base of the + * CPLD register map + * + */ + +#include <common.h> +#include <command.h> +#include <asm/io.h> + +#include "cpld.h" +/** + * Set the boot bank to the alternate bank + */ +void cpld_set_altbank(u8 banksel) +{ +	struct cpld_data *cpld_data = (void *)(CONFIG_SYS_CPLD_BASE); +	u8 reg11; + +	reg11 = in_8(&cpld_data->flhcsr); + +	switch (banksel) { +	case 1: +		out_8(&cpld_data->flhcsr, (reg11 & CPLD_BANKSEL_MASK) +			| CPLD_BANKSEL_EN | CPLD_SELECT_BANK1); +		break; +	case 2: +		out_8(&cpld_data->flhcsr, (reg11 & CPLD_BANKSEL_MASK) +			| CPLD_BANKSEL_EN | CPLD_SELECT_BANK2); +		break; +	case 3: +		out_8(&cpld_data->flhcsr, (reg11 & CPLD_BANKSEL_MASK) +			| CPLD_BANKSEL_EN | CPLD_SELECT_BANK3); +		break; +	case 4: +		out_8(&cpld_data->flhcsr, (reg11 & CPLD_BANKSEL_MASK) +			| CPLD_BANKSEL_EN | CPLD_SELECT_BANK4); +		break; +	default: +		printf("Invalid value! [1-4]\n"); +		return; +	} + +	udelay(100); +	do_reset(NULL, 0, 0, NULL); +} + +/** + * Set the boot bank to the default bank + */ +void cpld_set_defbank(void) +{ +	cpld_set_altbank(4); +} + +#ifdef DEBUG +static void cpld_dump_regs(void) +{ +	struct cpld_data *cpld_data = (void *)(CONFIG_SYS_CPLD_BASE); + +	printf("chipid1		= 0x%02x\n", in_8(&cpld_data->chipid1)); +	printf("chipid2		= 0x%02x\n", in_8(&cpld_data->chipid2)); +	printf("hwver		= 0x%02x\n", in_8(&cpld_data->hwver)); +	printf("cpldver		= 0x%02x\n", in_8(&cpld_data->cpldver)); +	printf("rstcon		= 0x%02x\n", in_8(&cpld_data->rstcon)); +	printf("flhcsr		= 0x%02x\n", in_8(&cpld_data->flhcsr)); +	printf("wdcsr		= 0x%02x\n", in_8(&cpld_data->wdcsr)); +	printf("wdkick		= 0x%02x\n", in_8(&cpld_data->wdkick)); +	printf("fancsr		= 0x%02x\n", in_8(&cpld_data->fancsr)); +	printf("ledcsr		= 0x%02x\n", in_8(&cpld_data->ledcsr)); +	printf("misc		= 0x%02x\n", in_8(&cpld_data->misccsr)); +	printf("bootor		= 0x%02x\n", in_8(&cpld_data->bootor)); +	printf("bootcfg1	= 0x%02x\n", in_8(&cpld_data->bootcfg1)); +	printf("bootcfg2	= 0x%02x\n", in_8(&cpld_data->bootcfg2)); +	printf("bootcfg3	= 0x%02x\n", in_8(&cpld_data->bootcfg3)); +	printf("bootcfg4	= 0x%02x\n", in_8(&cpld_data->bootcfg4)); +	putc('\n'); +} +#endif + +int cpld_cmd(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) +{ +	int rc = 0; +	unsigned char value; + +	if (argc <= 1) +		return cmd_usage(cmdtp); + +	if (strcmp(argv[1], "reset") == 0) { +		if (!strcmp(argv[2], "altbank") && argv[3]) { +			value = (u8)simple_strtoul(argv[3], NULL, 16); +			cpld_set_altbank(value); +		} else if (!argv[2]) +			cpld_set_defbank(); +		else +			cmd_usage(cmdtp); +#ifdef DEBUG +	} else if (strcmp(argv[1], "dump") == 0) { +		cpld_dump_regs(); +#endif +	} else +		rc = cmd_usage(cmdtp); + +	return rc; +} + +U_BOOT_CMD( +	cpld_cmd, CONFIG_SYS_MAXARGS, 1, cpld_cmd, +	"Reset the board using the CPLD sequencer", +	"reset - hard reset to default bank 4\n" +	"cpld_cmd reset altbank [bank]- reset to alternate bank\n" +	"	- [bank] bank value select 1-4\n" +	"	- bank 1 on the flash 0x0000000~0x0ffffff\n" +	"	- bank 2 on the flash 0x1000000~0x1ffffff\n" +	"	- bank 3 on the flash 0x2000000~0x2ffffff\n" +	"	- bank 4 on the flash 0x3000000~0x3ffffff\n" +#ifdef DEBUG +	"cpld_cmd dump - display the CPLD registers\n" +#endif +	); diff --git a/board/freescale/c29xpcie/cpld.h b/board/freescale/c29xpcie/cpld.h new file mode 100644 index 000000000..20862a3c0 --- /dev/null +++ b/board/freescale/c29xpcie/cpld.h @@ -0,0 +1,40 @@ +/** + * Copyright 2013 Freescale Semiconductor + * Author: Mingkai Hu <Mingkai.Hu@freescale.com> + *         Po Liu <Po.Liu@freescale.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + * + * This file provides support for the ngPIXIS, a board-specific FPGA used on + * some Freescale reference boards. + */ + +/* + * CPLD register set. Feel free to add board-specific #ifdefs where necessary. + */ +struct cpld_data { +	u8 chipid1;	/* 0x0 - CPLD Chip ID1 Register */ +	u8 chipid2;	/* 0x1 - CPLD Chip ID2 Register */ +	u8 hwver;	/* 0x2 - Hardware Version Register */ +	u8 cpldver;	/* 0x3 - Software Version Register */ +	u8 res[12]; +	u8 rstcon;	/* 0x10 - Reset control register */ +	u8 flhcsr;	/* 0x11 - Flash control and status Register */ +	u8 wdcsr;	/* 0x12 - Watchdog control and status Register */ +	u8 wdkick;	/* 0x13 - Watchdog kick Register */ +	u8 fancsr;	/* 0x14 - Fan control and status Register */ +	u8 ledcsr;	/* 0x15 - LED control and status Register */ +	u8 misccsr;	/* 0x16 - Misc control and status Register */ +	u8 bootor;	/* 0x17 - Boot configure override Register */ +	u8 bootcfg1;	/* 0x18 - Boot configure 1 Register */ +	u8 bootcfg2;	/* 0x19 - Boot configure 2 Register */ +	u8 bootcfg3;	/* 0x1a - Boot configure 3 Register */ +	u8 bootcfg4;	/* 0x1b - Boot configure 4 Register */ +}; + +#define CPLD_BANKSEL_EN		0x02 +#define CPLD_BANKSEL_MASK	0x3f +#define CPLD_SELECT_BANK1	0xc0 +#define CPLD_SELECT_BANK2	0x80 +#define CPLD_SELECT_BANK3	0x40 +#define CPLD_SELECT_BANK4	0x00 diff --git a/board/freescale/c29xpcie/ddr.c b/board/freescale/c29xpcie/ddr.c new file mode 100644 index 000000000..b017cfd96 --- /dev/null +++ b/board/freescale/c29xpcie/ddr.c @@ -0,0 +1,86 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <asm/fsl_law.h> +#include <asm/fsl_ddr_sdram.h> +#include <asm/fsl_ddr_dimm_params.h> + +/* + * Micron MT41J128M16HA-15E + * */ +dimm_params_t ddr_raw_timing = { +	.n_ranks = 1, +	.rank_density = 536870912u, +	.capacity = 536870912u, +	.primary_sdram_width = 32, +	.ec_sdram_width = 8, +	.registered_dimm = 0, +	.mirrored_dimm = 0, +	.n_row_addr = 14, +	.n_col_addr = 10, +	.n_banks_per_sdram_device = 8, +	.edc_config = 2, +	.burst_lengths_bitmask = 0x0c, + +	.tCKmin_X_ps = 1650, +	.caslat_X = 0x7e << 4,	/* 5,6,7,8,9,10 */ +	.tAA_ps = 14050, +	.tWR_ps = 15000, +	.tRCD_ps = 13500, +	.tRRD_ps = 75000, +	.tRP_ps = 13500, +	.tRAS_ps = 40000, +	.tRC_ps = 49500, +	.tRFC_ps = 160000, +	.tWTR_ps = 75000, +	.tRTP_ps = 75000, +	.refresh_rate_ps = 7800000, +	.tFAW_ps = 30000, +}; + +int fsl_ddr_get_dimm_params(dimm_params_t *pdimm, +		unsigned int controller_number, +		unsigned int dimm_number) +{ +	const char dimm_model[] = "Fixed DDR on board"; + +	if ((controller_number == 0) && (dimm_number == 0)) { +		memcpy(pdimm, &ddr_raw_timing, sizeof(dimm_params_t)); +		memset(pdimm->mpart, 0, sizeof(pdimm->mpart)); +		memcpy(pdimm->mpart, dimm_model, sizeof(dimm_model) - 1); +	} + +	return 0; +} + +void fsl_ddr_board_options(memctl_options_t *popts, +				dimm_params_t *pdimm, +				unsigned int ctrl_num) +{ +	int i; +	popts->clk_adjust = 2; +	popts->cpo_override = 0x1f; +	popts->write_data_delay = 4; +	popts->half_strength_driver_enable = 1; +	popts->bstopre = 0x3cf; +	popts->quad_rank_present = 1; +	popts->rtt_override = 1; +	popts->rtt_override_value = 1; +	popts->dynamic_power = 1; +	/* Write leveling override */ +	popts->wrlvl_en = 1; +	popts->wrlvl_override = 1; +	popts->wrlvl_sample = 0xf; +	popts->wrlvl_start = 0x4; +	popts->trwt_override = 1; +	popts->trwt = 0; + +	for (i = 0; i < CONFIG_CHIP_SELECTS_PER_CTRL; i++) { +		popts->cs_local_opts[i].odt_rd_cfg = FSL_DDR_ODT_NEVER; +		popts->cs_local_opts[i].odt_wr_cfg = FSL_DDR_ODT_CS; +	} +} diff --git a/board/freescale/c29xpcie/law.c b/board/freescale/c29xpcie/law.c new file mode 100644 index 000000000..cd8fc2105 --- /dev/null +++ b/board/freescale/c29xpcie/law.c @@ -0,0 +1,19 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <asm/fsl_law.h> +#include <asm/mmu.h> + +struct law_entry law_table[] = { +	SET_LAW(CONFIG_SYS_FLASH_BASE_PHYS, LAW_SIZE_64M, LAW_TRGT_IF_IFC), +	SET_LAW(CONFIG_SYS_CPLD_BASE_PHYS, LAW_SIZE_4K, LAW_TRGT_IF_IFC), +	SET_LAW(CONFIG_SYS_NAND_BASE_PHYS, LAW_SIZE_16K, LAW_TRGT_IF_IFC), +	SET_LAW(CONFIG_SYS_PLATFORM_SRAM_BASE_PHYS, LAW_SIZE_512K, +					LAW_TRGT_IF_PLATFORM_SRAM), +}; + +int num_law_entries = ARRAY_SIZE(law_table); diff --git a/board/freescale/c29xpcie/tlb.c b/board/freescale/c29xpcie/tlb.c new file mode 100644 index 000000000..ddd1ef80b --- /dev/null +++ b/board/freescale/c29xpcie/tlb.c @@ -0,0 +1,76 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <asm/mmu.h> + +struct fsl_e_tlb_entry tlb_table[] = { +	/* TLB 0 - for temp stack in cache */ +	SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR, CONFIG_SYS_INIT_RAM_ADDR, +			MAS3_SX|MAS3_SW|MAS3_SR, 0, +			0, 0, BOOKE_PAGESZ_4K, 0), +	SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR + 4 * 1024 , +			CONFIG_SYS_INIT_RAM_ADDR + 4 * 1024, +			MAS3_SX|MAS3_SW|MAS3_SR, 0, +			0, 0, BOOKE_PAGESZ_4K, 0), +	SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR + 8 * 1024 , +			CONFIG_SYS_INIT_RAM_ADDR + 8 * 1024, +			MAS3_SX|MAS3_SW|MAS3_SR, 0, +			0, 0, BOOKE_PAGESZ_4K, 0), +	SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR + 12 * 1024 , +			CONFIG_SYS_INIT_RAM_ADDR + 12 * 1024, +			MAS3_SX|MAS3_SW|MAS3_SR, 0, +			0, 0, BOOKE_PAGESZ_4K, 0), + +	/* TLB 1 */ +	SET_TLB_ENTRY(1, CONFIG_SYS_CCSRBAR, CONFIG_SYS_CCSRBAR_PHYS, +			MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +			0, 0, BOOKE_PAGESZ_1M, 1), + +	SET_TLB_ENTRY(1, CONFIG_SYS_FLASH_BASE, CONFIG_SYS_FLASH_BASE_PHYS, +			MAS3_SX|MAS3_SR, MAS2_W|MAS2_G, +			0, 1, BOOKE_PAGESZ_64M, 1), + +#ifdef CONFIG_PCI +	SET_TLB_ENTRY(1, CONFIG_SYS_PCIE1_MEM_VIRT, CONFIG_SYS_PCIE1_MEM_PHYS, +			MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +			0, 2, BOOKE_PAGESZ_256M, 1), + +	SET_TLB_ENTRY(1, CONFIG_SYS_PCIE1_IO_VIRT, CONFIG_SYS_PCIE1_IO_PHYS, +			MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +			0, 3, BOOKE_PAGESZ_256K, 1), +#endif + +	SET_TLB_ENTRY(1, CONFIG_SYS_CPLD_BASE, CONFIG_SYS_CPLD_BASE_PHYS, +			MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +			0, 4, BOOKE_PAGESZ_4K, 1), + +	SET_TLB_ENTRY(1, CONFIG_SYS_NAND_BASE, CONFIG_SYS_NAND_BASE_PHYS, +			MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +			0, 5, BOOKE_PAGESZ_16K, 1), + +	SET_TLB_ENTRY(1, CONFIG_SYS_PLATFORM_SRAM_BASE, +			CONFIG_SYS_PLATFORM_SRAM_BASE_PHYS, +			MAS3_SX|MAS3_SW|MAS3_SR, 0, +			0, 6, BOOKE_PAGESZ_256K, 1), +	SET_TLB_ENTRY(1, CONFIG_SYS_PLATFORM_SRAM_BASE + 0x40000, +			CONFIG_SYS_PLATFORM_SRAM_BASE_PHYS + 0x40000, +			MAS3_SX|MAS3_SW|MAS3_SR, 0, +			0, 7, BOOKE_PAGESZ_256K, 1), + +#ifdef CONFIG_SYS_RAMBOOT +	SET_TLB_ENTRY(1, CONFIG_SYS_DDR_SDRAM_BASE, +			CONFIG_SYS_DDR_SDRAM_BASE, +			MAS3_SX|MAS3_SW|MAS3_SR, 0, +			0, 8, BOOKE_PAGESZ_256M, 1), +	SET_TLB_ENTRY(1, CONFIG_SYS_DDR_SDRAM_BASE + 0x10000000, +			CONFIG_SYS_DDR_SDRAM_BASE + 0x10000000, +			MAS3_SX|MAS3_SW|MAS3_SR, 0, +			0, 9, BOOKE_PAGESZ_256M, 1), +#endif +}; + +int num_tlb_entries = ARRAY_SIZE(tlb_table); diff --git a/board/freescale/common/Makefile b/board/freescale/common/Makefile index d451f6ff0..f9550c48c 100644 --- a/board/freescale/common/Makefile +++ b/board/freescale/common/Makefile @@ -45,15 +45,14 @@ COBJS-$(CONFIG_MPC8555CDS)	+= cds_pci_ft.o  COBJS-$(CONFIG_MPC8536DS)	+= ics307_clk.o  COBJS-$(CONFIG_MPC8572DS)	+= ics307_clk.o -ifndef CONFIG_SPL_BUILD  COBJS-$(CONFIG_P1022DS)		+= ics307_clk.o -endif  COBJS-$(CONFIG_P2020DS)		+= ics307_clk.o  COBJS-$(CONFIG_P3041DS)		+= ics307_clk.o  COBJS-$(CONFIG_P4080DS)		+= ics307_clk.o  COBJS-$(CONFIG_P5020DS)		+= ics307_clk.o  COBJS-$(CONFIG_P5040DS)		+= ics307_clk.o  COBJS-$(CONFIG_VSC_CROSSBAR)    += vsc3316_3308.o +COBJS-$(CONFIG_IDT8T49N222A)	+= idt8t49n222a_serdes_clk.o  # deal with common files for P-series corenet based devices  SUBLIB-$(CONFIG_P2041RDB)	+= p_corenet/libp_corenet.o diff --git a/board/freescale/common/idt8t49n222a_serdes_clk.c b/board/freescale/common/idt8t49n222a_serdes_clk.c new file mode 100644 index 000000000..d34716227 --- /dev/null +++ b/board/freescale/common/idt8t49n222a_serdes_clk.c @@ -0,0 +1,207 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * Author: Shaveta Leekha <shaveta@freescale.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include "idt8t49n222a_serdes_clk.h" + +#define DEVICE_ID_REG		0x00 + +static int check_pll_status(u8 idt_addr) +{ +	u8 val = 0; +	int ret; + +	ret = i2c_read(idt_addr, 0x17, 1, &val, 1); +	if (ret < 0) { +		printf("IDT:0x%x could not read status register from device.\n", +			idt_addr); +		return ret; +	} + +	if (val & 0x04) { +		debug("idt8t49n222a PLL is LOCKED: %x\n", val); +	} else { +		printf("idt8t49n222a PLL is not LOCKED: %x\n", val); +		return -1; +	} + +	return 0; +} + +int set_serdes_refclk(u8 idt_addr, u8 serdes_num, +			enum serdes_refclk refclk1, +			enum serdes_refclk refclk2, u8 feedback) +{ +	u8 dev_id = 0; +	int i, ret; + +	debug("IDT:Configuring idt8t49n222a device at I2C address: 0x%2x\n", +		idt_addr); + +	ret = i2c_read(idt_addr, DEVICE_ID_REG, 1, &dev_id, 1); +	if (ret < 0) { +		debug("IDT:0x%x could not read DEV_ID from device.\n", +			idt_addr); +		return ret; +	} + +	if ((dev_id != 0x00) && (dev_id != 0x24) && (dev_id != 0x2a)) { +		debug("IDT: device at address 0x%x is not idt8t49n222a.\n", +			idt_addr); +	} + +	if (serdes_num != 1 && serdes_num != 2) { +		debug("serdes_num should be 1 for SerDes1 and" +			" 2 for SerDes2.\n"); +		return -1; +	} + +	if ((refclk1 == SERDES_REFCLK_122_88 && refclk2 != SERDES_REFCLK_122_88) +		|| (refclk1 != SERDES_REFCLK_122_88 +			&& refclk2 == SERDES_REFCLK_122_88)) { +		debug("Only one refclk at 122.88MHz is not supported." +			" Please set both refclk1 & refclk2 to 122.88MHz" +			" or both not to 122.88MHz.\n"); +		return -1; +	} + +	if (refclk1 != SERDES_REFCLK_100 && refclk1 != SERDES_REFCLK_122_88 +					&& refclk1 != SERDES_REFCLK_125 +					&& refclk1 != SERDES_REFCLK_156_25) { +		debug("refclk1 should be 100MHZ, 122.88MHz, 125MHz" +			" or 156.25MHz.\n"); +		return -1; +	} + +	if (refclk2 != SERDES_REFCLK_100 && refclk2 != SERDES_REFCLK_122_88 +					&& refclk2 != SERDES_REFCLK_125 +					&& refclk2 != SERDES_REFCLK_156_25) { +		debug("refclk2 should be 100MHZ, 122.88MHz, 125MHz" +			" or 156.25MHz.\n"); +		return -1; +	} + +	if (feedback != 0 && feedback != 1) { +		debug("valid values for feedback are 0(default) or 1.\n"); +		return -1; +	} + +	/* Configuring IDT for output refclks as +	 * Refclk1 = 122.88MHz  Refclk2 = 122.88MHz +	 */ +	if (refclk1 == SERDES_REFCLK_122_88 && +			refclk2 == SERDES_REFCLK_122_88) { +		printf("Setting refclk1:122.88 and refclk2:122.88\n"); +		for (i = 0; i < NUM_IDT_REGS; i++) +			i2c_reg_write(idt_addr, idt_conf_122_88[i][0], +						idt_conf_122_88[i][1]); + +		if (feedback) { +			for (i = 0; i < NUM_IDT_REGS_FEEDBACK; i++) +				i2c_reg_write(idt_addr, +					idt_conf_122_88_feedback[i][0], +					idt_conf_122_88_feedback[i][1]); +		} +	} + +	if (refclk1 != SERDES_REFCLK_122_88 && +			refclk2 != SERDES_REFCLK_122_88) { +		for (i = 0; i < NUM_IDT_REGS; i++) +			i2c_reg_write(idt_addr, idt_conf_not_122_88[i][0], +						idt_conf_not_122_88[i][1]); +	} + +	/* Configuring IDT for output refclks as +	 * Refclk1 = 100MHz  Refclk2 = 125MHz +	 */ +	if (refclk1 == SERDES_REFCLK_100 && refclk2 == SERDES_REFCLK_125) { +		printf("Setting refclk1:100 and refclk2:125\n"); +		i2c_reg_write(idt_addr, 0x11, 0x10); +	} + +	/* Configuring IDT for output refclks as +	 * Refclk1 = 125MHz  Refclk2 = 125MHz +	 */ +	if (refclk1 == SERDES_REFCLK_125 && refclk2 == SERDES_REFCLK_125) { +		printf("Setting refclk1:125 and refclk2:125\n"); +		i2c_reg_write(idt_addr, 0x10, 0x10); +		i2c_reg_write(idt_addr, 0x11, 0x10); +	} + +	/* Configuring IDT for output refclks as +	 * Refclk1 = 125MHz  Refclk2 = 100MHz +	 */ +	if (refclk1 == SERDES_REFCLK_125 && refclk2 == SERDES_REFCLK_100) { +		printf("Setting refclk1:125 and refclk2:100\n"); +		i2c_reg_write(idt_addr, 0x10, 0x10); +	} + +	/* Configuring IDT for output refclks as +	 * Refclk1 = 156.25MHz  Refclk2 = 156.25MHz +	 */ +	if (refclk1 == SERDES_REFCLK_156_25 && +			refclk2 == SERDES_REFCLK_156_25) { +		printf("Setting refclk1:156.25 and refclk2:156.25\n"); +		for (i = 0; i < NUM_IDT_REGS_156_25; i++) +			i2c_reg_write(idt_addr, idt_conf_156_25[i][0], +						idt_conf_156_25[i][1]); +	} + +	/* Configuring IDT for output refclks as +	 * Refclk1 = 100MHz  Refclk2 = 156.25MHz +	 */ +	if (refclk1 == SERDES_REFCLK_100 && +			refclk2 == SERDES_REFCLK_156_25) { +		printf("Setting refclk1:100 and refclk2:156.25\n"); +		for (i = 0; i < NUM_IDT_REGS_156_25; i++) +			i2c_reg_write(idt_addr, idt_conf_100_156_25[i][0], +						idt_conf_100_156_25[i][1]); +	} + +	/* Configuring IDT for output refclks as +	 * Refclk1 = 125MHz  Refclk2 = 156.25MHz +	 */ +	if (refclk1 == SERDES_REFCLK_125 && +			refclk2 == SERDES_REFCLK_156_25) { +		printf("Setting refclk1:125 and refclk2:156.25\n"); +		for (i = 0; i < NUM_IDT_REGS_156_25; i++) +			i2c_reg_write(idt_addr, idt_conf_125_156_25[i][0], +						idt_conf_125_156_25[i][1]); +	} + +	/* Configuring IDT for output refclks as +	 * Refclk1 = 156.25MHz  Refclk2 = 100MHz +	 */ +	if (refclk1 == SERDES_REFCLK_156_25 && +			refclk2 == SERDES_REFCLK_100) { +		printf("Setting refclk1:156.25 and refclk2:100\n"); +		for (i = 0; i < NUM_IDT_REGS_156_25; i++) +			i2c_reg_write(idt_addr, idt_conf_156_25_100[i][0], +						idt_conf_156_25_100[i][1]); +	} + +	/* Configuring IDT for output refclks as +	 * Refclk1 = 156.25MHz  Refclk2 = 125MHz +	 */ +	if (refclk1 == SERDES_REFCLK_156_25 && +			refclk2 == SERDES_REFCLK_125) { +		printf("Setting refclk1:156.25 and refclk2:125\n"); +		for (i = 0; i < NUM_IDT_REGS_156_25; i++) +			i2c_reg_write(idt_addr, idt_conf_156_25_125[i][0], +						idt_conf_156_25_125[i][1]); +	} + +	/* waiting for maximum of 1 second if PLL doesn'r get locked +	 * initially. then check the status again. +	 */ +	if (check_pll_status(idt_addr)) { +		mdelay(1000); +		if (check_pll_status(idt_addr)) +			return -1; +	} + +	return 0; +} diff --git a/board/freescale/common/idt8t49n222a_serdes_clk.h b/board/freescale/common/idt8t49n222a_serdes_clk.h new file mode 100644 index 000000000..787bdd9ca --- /dev/null +++ b/board/freescale/common/idt8t49n222a_serdes_clk.h @@ -0,0 +1,107 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * Author: Shaveta Leekha <shaveta@freescale.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef __IDT8T49N222A_SERDES_CLK_H_ +#define __IDT8T49N222A_SERDES_CLK_H_	1 + +#include <common.h> +#include <i2c.h> +#include "qixis.h" +#include "../b4860qds/b4860qds_qixis.h" +#include <errno.h> + +#define NUM_IDT_REGS		23 +#define NUM_IDT_REGS_FEEDBACK	12 +#define NUM_IDT_REGS_156_25	11 + +/* CLK */ +enum serdes_refclk { +	SERDES_REFCLK_100,	/* refclk 100Mhz */ +	SERDES_REFCLK_122_88,	/* refclk 122.88Mhz */ +	SERDES_REFCLK_125,	/* refclk 125Mhz */ +	SERDES_REFCLK_156_25,	/* refclk 156.25Mhz */ +	SERDES_REFCLK_NONE = -1, +}; + +/* configuration values for IDT registers for Output Refclks: + * Refclk1 = 122.88MHz Refclk2 = 122.88MHz + */ +static const u8 idt_conf_122_88[23][2] = { {0x00, 0x3C}, {0x01, 0x00}, +		{0x02, 0x9F}, {0x03, 0x00}, {0x04, 0x0B}, {0x05, 0x00}, +		{0x06, 0x00}, {0x07, 0x00}, {0x08, 0x7D}, {0x09, 0x00}, +		{0x0A, 0x08}, {0x0B, 0x00}, {0x0C, 0xDC}, {0x0D, 0x00}, +		{0x0E, 0x00}, {0x0F, 0x00}, {0x10, 0x12}, {0x11, 0x12}, +		{0x12, 0xB9}, {0x13, 0xBC}, {0x14, 0x40}, {0x15, 0x08}, +		{0x16, 0xA0} }; + + +/* configuration values for IDT registers for Output Refclks: + * Refclk1 not equal to 122.88MHz Refclk2 not equal to 122.88MHz + */ +static const u8 idt_conf_not_122_88[23][2] = { {0x00, 0x00}, {0x01, 0x00}, +		{0x02, 0x00}, {0x03, 0x00}, {0x04, 0x0A}, {0x05, 0x00}, +		{0x06, 0x00}, {0x07, 0x00}, {0x08, 0x7D}, {0x09, 0x00}, +		{0x0A, 0x08}, {0x0B, 0x00}, {0x0C, 0xDC}, {0x0D, 0x00}, +		{0x0E, 0x00}, {0x0F, 0x00}, {0x10, 0x14}, {0x11, 0x14}, +		{0x12, 0x35}, {0x13, 0xBC}, {0x14, 0x40}, {0x15, 0x08}, +		{0x16, 0xA0} }; + +/* Reconfiguration values for some of IDT registers for + * Output Refclks: + * Refclk1 = 122.88MHz Refclk2 = 122.88MHz + * and with feedback as 1 + */ +static const u8 idt_conf_122_88_feedback[12][2] = { {0x00, 0x50}, {0x02, 0xD7}, +		{0x04, 0x89}, {0x06, 0xC3}, {0x08, 0xC0}, {0x0A, 0x07}, +		{0x0C, 0x80}, {0x10, 0x10}, {0x11, 0x10}, {0x12, 0x1B}, +		{0x14, 0x00}, {0x15, 0xE8} }; + +/* configuration values for IDT registers for Output Refclks: + * Refclk1 : 156.25MHz Refclk2 : 156.25MHz + */ +static const u8 idt_conf_156_25[11][2] = { {0x04, 0x19}, {0x06, 0x03}, +		{0x08, 0xC0}, {0x0A, 0x07}, {0x0C, 0xA1}, {0x0E, 0x20}, +		{0x10, 0x10}, {0x11, 0x10}, {0x12, 0xB5}, {0x13, 0x3C}, +		{0x15, 0xE8} }; + +/* configuration values for IDT registers for Output Refclks: + * Refclk1 : 100MHz Refclk2 : 156.25MHz + */ +static const u8 idt_conf_100_156_25[11][2] = { {0x04, 0x19}, {0x06, 0x03}, +		{0x08, 0xC0}, {0x0A, 0x07}, {0x0C, 0xA1}, {0x0E, 0x20}, +		{0x10, 0x19}, {0x11, 0x10}, {0x12, 0xB5}, {0x13, 0x3C}, +		{0x15, 0xE8} }; + +/* configuration values for IDT registers for Output Refclks: + * Refclk1 : 125MHz Refclk2 : 156.25MHz + */ +static const u8 idt_conf_125_156_25[11][2] = { {0x04, 0x19}, {0x06, 0x03}, +		{0x08, 0xC0}, {0x0A, 0x07}, {0x0C, 0xA1}, {0x0E, 0x20}, +		{0x10, 0x14}, {0x11, 0x10}, {0x12, 0xB5}, {0x13, 0x3C}, +		{0x15, 0xE8} }; + +/* configuration values for IDT registers for Output Refclks: + * Refclk1 : 156.25MHz Refclk2 : 100MHz + */ +static const u8 idt_conf_156_25_100[11][2] = { {0x04, 0x19}, {0x06, 0x03}, +		{0x08, 0xC0}, {0x0A, 0x07}, {0x0C, 0xA1}, {0x0E, 0x20}, +		{0x10, 0x10}, {0x11, 0x19}, {0x12, 0xB5}, {0x13, 0x3C}, +		{0x15, 0xE8} }; + +/* configuration values for IDT registers for Output Refclks: + * Refclk1 : 156.25MHz Refclk2 : 125MHz + */ +static const u8 idt_conf_156_25_125[11][2] = { {0x04, 0x19}, {0x06, 0x03}, +		{0x08, 0xC0}, {0x0A, 0x07}, {0x0C, 0xA1}, {0x0E, 0x20}, +		{0x10, 0x10}, {0x11, 0x14}, {0x12, 0xB5}, {0x13, 0x3C}, +		{0x15, 0xE8} }; + +int set_serdes_refclk(u8 idt_addr, u8 serdes_num, +			enum serdes_refclk refclk1, +			enum serdes_refclk refclk2, u8 feedback); + +#endif	/*__IDT8T49N222A_SERDES_CLK_H_ */ diff --git a/board/freescale/common/qixis.c b/board/freescale/common/qixis.c index 40ce6b082..a49e3006d 100644 --- a/board/freescale/common/qixis.c +++ b/board/freescale/common/qixis.c @@ -107,6 +107,26 @@ const char *byte_to_binary_mask(u8 val, u8 mask, char *buf)  	return buf;  } +#ifdef QIXIS_RST_FORCE_MEM +void board_assert_mem_reset(void) +{ +	u8 rst; + +	rst = QIXIS_READ(rst_frc[0]); +	if (!(rst & QIXIS_RST_FORCE_MEM)) +		QIXIS_WRITE(rst_frc[0], rst | QIXIS_RST_FORCE_MEM); +} + +void board_deassert_mem_reset(void) +{ +	u8 rst; + +	rst = QIXIS_READ(rst_frc[0]); +	if (rst & QIXIS_RST_FORCE_MEM) +		QIXIS_WRITE(rst_frc[0], rst & ~QIXIS_RST_FORCE_MEM); +} +#endif +  void qixis_reset(void)  {  	QIXIS_WRITE(rst_ctl, QIXIS_RST_CTL_RESET); diff --git a/board/freescale/common/vsc3316_3308.c b/board/freescale/common/vsc3316_3308.c index 8a3dc33b6..97a25e838 100644 --- a/board/freescale/common/vsc3316_3308.c +++ b/board/freescale/common/vsc3316_3308.c @@ -31,7 +31,7 @@ int vsc_if_enable(unsigned int vsc_addr)  	return i2c_write(vsc_addr, INTERFACE_MODE_REG, 1, &data, 1);  } -int vsc3316_config(unsigned int vsc_addr, const int8_t con_arr[][2], +int vsc3316_config(unsigned int vsc_addr, int8_t con_arr[][2],  		unsigned int num_con)  {  	unsigned int i; diff --git a/board/freescale/common/vsc3316_3308.h b/board/freescale/common/vsc3316_3308.h index 4003fcdb2..2a4918777 100644 --- a/board/freescale/common/vsc3316_3308.h +++ b/board/freescale/common/vsc3316_3308.h @@ -12,7 +12,7 @@  #include <errno.h>  int vsc_if_enable(unsigned int vsc_addr); -int vsc3316_config(unsigned int vsc_addr, const int8_t con_arr[][2], +int vsc3316_config(unsigned int vsc_addr, int8_t con_arr[][2],  		unsigned int num_con);  int vsc3308_config(unsigned int vsc_addr, const int8_t con_arr[][2],  		unsigned int num_con); diff --git a/board/freescale/corenet_ds/corenet_ds.c b/board/freescale/corenet_ds/corenet_ds.c index fffb0c817..60e2100af 100644 --- a/board/freescale/corenet_ds/corenet_ds.c +++ b/board/freescale/corenet_ds/corenet_ds.c @@ -27,8 +27,10 @@ int checkboard (void)  {  	u8 sw;  	struct cpu_type *cpu = gd->arch.cpu; -	ccsr_gur_t *gur = (void *)CONFIG_SYS_MPC85xx_GUTS_ADDR; +#if defined(CONFIG_P3041DS) || defined(CONFIG_P5020DS) || \ +	defined(CONFIG_P5040DS)  	unsigned int i; +#endif  	static const char * const freq[] = {"100", "125", "156.25", "212.5" };  	printf("Board: %sDS, ", cpu->name); @@ -47,19 +49,6 @@ int checkboard (void)  	else  		printf("invalid setting of SW%u\n", PIXIS_LBMAP_SWITCH); -	/* Display the RCW, so that no one gets confused as to what RCW -	 * we're actually using for this boot. -	 */ -	puts("Reset Configuration Word (RCW):"); -	for (i = 0; i < ARRAY_SIZE(gur->rcwsr); i++) { -		u32 rcw = in_be32(&gur->rcwsr[i]); - -		if ((i % 4) == 0) -			printf("\n       %08x:", i * 4); -		printf(" %08x", rcw); -	} -	puts("\n"); -  	/* Display the actual SERDES reference clocks as configured by the  	 * dip switches on the board.  Note that the SWx registers could  	 * technically be set to force the reference clocks to match the diff --git a/board/freescale/corenet_ds/ddr.c b/board/freescale/corenet_ds/ddr.c index da284cde9..517e87ff4 100644 --- a/board/freescale/corenet_ds/ddr.c +++ b/board/freescale/corenet_ds/ddr.c @@ -56,14 +56,14 @@ phys_size_t fixed_sdram(void)  	ddr_size = (phys_size_t) CONFIG_SYS_SDRAM_SIZE * 1024 * 1024;  	ddr_cfg_regs.ddr_cdr1 = DDR_CDR1_DHC_EN; -	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 0); +	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 0, 0);  #if (CONFIG_NUM_DDR_CONTROLLERS == 2)  	memcpy(&ddr_cfg_regs,  		fixed_ddr_parm_1[i].ddr_settings,  		sizeof(ddr_cfg_regs));  	ddr_cfg_regs.ddr_cdr1 = DDR_CDR1_DHC_EN; -	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 1); +	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 1, 0);  #endif  	/* diff --git a/board/freescale/mpc8540ads/mpc8540ads.c b/board/freescale/mpc8540ads/mpc8540ads.c index 7a84cd295..2fb403742 100644 --- a/board/freescale/mpc8540ads/mpc8540ads.c +++ b/board/freescale/mpc8540ads/mpc8540ads.c @@ -68,7 +68,7 @@ local_bus_init(void)  	get_sys_info(&sysinfo);  	clkdiv = lbc->lcrr & LCRR_CLKDIV; -	lbc_hz = sysinfo.freqSystemBus / 1000000 / clkdiv; +	lbc_hz = sysinfo.freq_systembus / 1000000 / clkdiv;  	if (lbc_hz < 66) {  		lbc->lcrr = CONFIG_SYS_LBC_LCRR | LCRR_DBYP;	/* DLL Bypass */ diff --git a/board/freescale/mpc8541cds/mpc8541cds.c b/board/freescale/mpc8541cds/mpc8541cds.c index 3d2dabd11..1e21a664c 100644 --- a/board/freescale/mpc8541cds/mpc8541cds.c +++ b/board/freescale/mpc8541cds/mpc8541cds.c @@ -250,7 +250,7 @@ local_bus_init(void)  	get_sys_info(&sysinfo);  	clkdiv = lbc->lcrr & LCRR_CLKDIV; -	lbc_hz = sysinfo.freqSystemBus / 1000000 / clkdiv; +	lbc_hz = sysinfo.freq_systembus / 1000000 / clkdiv;  	if (lbc_hz < 66) {  		lbc->lcrr |= LCRR_DBYP;	/* DLL Bypass */ diff --git a/board/freescale/mpc8555cds/mpc8555cds.c b/board/freescale/mpc8555cds/mpc8555cds.c index d4e7abebd..ee9269504 100644 --- a/board/freescale/mpc8555cds/mpc8555cds.c +++ b/board/freescale/mpc8555cds/mpc8555cds.c @@ -248,7 +248,7 @@ local_bus_init(void)  	get_sys_info(&sysinfo);  	clkdiv = lbc->lcrr & LCRR_CLKDIV; -	lbc_hz = sysinfo.freqSystemBus / 1000000 / clkdiv; +	lbc_hz = sysinfo.freq_systembus / 1000000 / clkdiv;  	if (lbc_hz < 66) {  		lbc->lcrr |= LCRR_DBYP;	/* DLL Bypass */ diff --git a/board/freescale/mpc8560ads/mpc8560ads.c b/board/freescale/mpc8560ads/mpc8560ads.c index a45a5583c..162636ef8 100644 --- a/board/freescale/mpc8560ads/mpc8560ads.c +++ b/board/freescale/mpc8560ads/mpc8560ads.c @@ -273,7 +273,7 @@ local_bus_init(void)  	get_sys_info(&sysinfo);  	clkdiv = lbc->lcrr & LCRR_CLKDIV; -	lbc_hz = sysinfo.freqSystemBus / 1000000 / clkdiv; +	lbc_hz = sysinfo.freq_systembus / 1000000 / clkdiv;  	if (lbc_hz < 66) {  		lbc->lcrr = CONFIG_SYS_LBC_LCRR | LCRR_DBYP;	/* DLL Bypass */ diff --git a/board/freescale/mx6qsabrelite/README b/board/freescale/mx6qsabrelite/README deleted file mode 100644 index 12a9c856c..000000000 --- a/board/freescale/mx6qsabrelite/README +++ /dev/null @@ -1,72 +0,0 @@ -U-Boot for the Freescale i.MX6q SabreLite board - -This file contains information for the port of U-Boot to the Freescale -i.MX6q SabreLite board. - -1. Boot source, boot from SD card ---------------------------------- - -The recent mainline U-Boot for the Freescale i.MX6q SabreLite board supports -boot from SD card only. However, by default, the SabreLite -boards boot from the SPI NOR flash. These boards need to be reflashed with -a small SD card loader to support boot from SD card. This small SD card loader -will be flashed into the SPI NOR. The board will still boot from SPI NOR, but -the loader will in turn request the BootROM to load the U-Boot from SD card. - -The SD card loader is available from - -https://wiki.linaro.org/Boards/MX6QSabreLite - -under a open-source 3-clause BSD license. - -To update the SPI-NOR on the SabreLite board without the Freescale -manufacturing tool use the following procedure: - -1. Write this SD card loader onto a large SD card using: - - sudo dd if=iMX6DQ_SPI_to_uSDHC3.bin of=/dev/sXx - -Note: Replace sXx with the device representing the SD card in your system. - -Note: This writes SD card loader at address 0 - -2. Put this SD card into the slot for the large SD card (SD3 on the bottom of -the board). Make sure SW1 switch is at position "00", so that it can boot -from the fuses. - -3. Power-up the SabreLite, press 'space' to enter command mode in the U-Boot -(the default one the board is shipped with, starting from the SPI NOR) and -enter the following commands: - - MX6Q SABRELITE U-Boot > mmc dev 0 - MX6Q SABRELITE U-Boot > mmc read 0x10800000 0 200 - MX6Q SABRELITE U-Boot > sf probe - MX6Q SABRELITE U-Boot > sf erase 0 0x40000 - MX6Q SABRELITE U-Boot > sf write 0x10800000 0 0x40000 - -4. done. - -In case you somehow do not succeed with this procedure you will have to use -the Freescale manufacturing tool in order to reflash the SPI-NOR. - -Note: The board now boots from full size SD3 on the bottom of the board. NOT -      the micro SD4/BOOT slot on the top of the board. I.e. you have to use -      full size SD cards. - -This information is taken from - -https://wiki.linaro.org/Boards/MX6QSabreLite - -2. Build --------- - -To build U-Boot for the SabreLite board: - - make mx6qsabrelite_config - make - -To copy the resulting u-boot.imx to the SD card: - - sudo dd if=u-boot.imx of=/dev/sXx bs=512 seek=2&&sudo sync - -Note: Replace sXx with the device representing the SD card in your system. diff --git a/board/freescale/mx6qsabrelite/mx6qsabrelite.c b/board/freescale/mx6qsabrelite/mx6qsabrelite.c deleted file mode 100644 index 78451e6d0..000000000 --- a/board/freescale/mx6qsabrelite/mx6qsabrelite.c +++ /dev/null @@ -1,832 +0,0 @@ -/* - * Copyright (C) 2010-2011 Freescale Semiconductor, Inc. - * - * SPDX-License-Identifier:	GPL-2.0+  - */ - -#include <common.h> -#include <asm/io.h> -#include <asm/arch/clock.h> -#include <asm/arch/imx-regs.h> -#include <asm/arch/iomux.h> -#include <asm/arch/mx6q_pins.h> -#include <asm/errno.h> -#include <asm/gpio.h> -#include <asm/imx-common/iomux-v3.h> -#include <asm/imx-common/mxc_i2c.h> -#include <asm/imx-common/boot_mode.h> -#include <mmc.h> -#include <fsl_esdhc.h> -#include <malloc.h> -#include <micrel.h> -#include <miiphy.h> -#include <netdev.h> -#include <linux/fb.h> -#include <ipu_pixfmt.h> -#include <asm/arch/crm_regs.h> -#include <asm/arch/mxc_hdmi.h> -#include <i2c.h> - -DECLARE_GLOBAL_DATA_PTR; - -#define UART_PAD_CTRL  (PAD_CTL_PUS_100K_UP |			\ -	PAD_CTL_SPEED_MED | PAD_CTL_DSE_40ohm |			\ -	PAD_CTL_SRE_FAST  | PAD_CTL_HYS) - -#define USDHC_PAD_CTRL (PAD_CTL_PUS_47K_UP |			\ -	PAD_CTL_SPEED_LOW | PAD_CTL_DSE_80ohm |			\ -	PAD_CTL_SRE_FAST  | PAD_CTL_HYS) - -#define ENET_PAD_CTRL  (PAD_CTL_PUS_100K_UP |			\ -	PAD_CTL_SPEED_MED | PAD_CTL_DSE_40ohm | PAD_CTL_HYS) - -#define SPI_PAD_CTRL (PAD_CTL_HYS | PAD_CTL_SPEED_MED |		\ -	PAD_CTL_DSE_40ohm     | PAD_CTL_SRE_FAST) - -#define BUTTON_PAD_CTRL (PAD_CTL_PUS_100K_UP |			\ -	PAD_CTL_SPEED_MED | PAD_CTL_DSE_40ohm | PAD_CTL_HYS) - -#define I2C_PAD_CTRL	(PAD_CTL_PUS_100K_UP |			\ -	PAD_CTL_SPEED_MED | PAD_CTL_DSE_40ohm | PAD_CTL_HYS |	\ -	PAD_CTL_ODE | PAD_CTL_SRE_FAST) - -int dram_init(void) -{ -	gd->ram_size = get_ram_size((void *)PHYS_SDRAM, PHYS_SDRAM_SIZE); - -	return 0; -} - -iomux_v3_cfg_t const uart1_pads[] = { -	MX6_PAD_SD3_DAT6__UART1_RXD | MUX_PAD_CTRL(UART_PAD_CTRL), -	MX6_PAD_SD3_DAT7__UART1_TXD | MUX_PAD_CTRL(UART_PAD_CTRL), -}; - -iomux_v3_cfg_t const uart2_pads[] = { -	MX6_PAD_EIM_D26__UART2_TXD | MUX_PAD_CTRL(UART_PAD_CTRL), -	MX6_PAD_EIM_D27__UART2_RXD | MUX_PAD_CTRL(UART_PAD_CTRL), -}; - -#define PC MUX_PAD_CTRL(I2C_PAD_CTRL) - -/* I2C1, SGTL5000 */ -struct i2c_pads_info i2c_pad_info0 = { -	.scl = { -		.i2c_mode = MX6_PAD_EIM_D21__I2C1_SCL | PC, -		.gpio_mode = MX6_PAD_EIM_D21__GPIO_3_21 | PC, -		.gp = IMX_GPIO_NR(3, 21) -	}, -	.sda = { -		.i2c_mode = MX6_PAD_EIM_D28__I2C1_SDA | PC, -		.gpio_mode = MX6_PAD_EIM_D28__GPIO_3_28 | PC, -		.gp = IMX_GPIO_NR(3, 28) -	} -}; - -/* I2C2 Camera, MIPI */ -struct i2c_pads_info i2c_pad_info1 = { -	.scl = { -		.i2c_mode = MX6_PAD_KEY_COL3__I2C2_SCL | PC, -		.gpio_mode = MX6_PAD_KEY_COL3__GPIO_4_12 | PC, -		.gp = IMX_GPIO_NR(4, 12) -	}, -	.sda = { -		.i2c_mode = MX6_PAD_KEY_ROW3__I2C2_SDA | PC, -		.gpio_mode = MX6_PAD_KEY_ROW3__GPIO_4_13 | PC, -		.gp = IMX_GPIO_NR(4, 13) -	} -}; - -/* I2C3, J15 - RGB connector */ -struct i2c_pads_info i2c_pad_info2 = { -	.scl = { -		.i2c_mode = MX6_PAD_GPIO_5__I2C3_SCL | PC, -		.gpio_mode = MX6_PAD_GPIO_5__GPIO_1_5 | PC, -		.gp = IMX_GPIO_NR(1, 5) -	}, -	.sda = { -		.i2c_mode = MX6_PAD_GPIO_16__I2C3_SDA | PC, -		.gpio_mode = MX6_PAD_GPIO_16__GPIO_7_11 | PC, -		.gp = IMX_GPIO_NR(7, 11) -	} -}; - -iomux_v3_cfg_t const usdhc3_pads[] = { -	MX6_PAD_SD3_CLK__USDHC3_CLK   | MUX_PAD_CTRL(USDHC_PAD_CTRL), -	MX6_PAD_SD3_CMD__USDHC3_CMD   | MUX_PAD_CTRL(USDHC_PAD_CTRL), -	MX6_PAD_SD3_DAT0__USDHC3_DAT0 | MUX_PAD_CTRL(USDHC_PAD_CTRL), -	MX6_PAD_SD3_DAT1__USDHC3_DAT1 | MUX_PAD_CTRL(USDHC_PAD_CTRL), -	MX6_PAD_SD3_DAT2__USDHC3_DAT2 | MUX_PAD_CTRL(USDHC_PAD_CTRL), -	MX6_PAD_SD3_DAT3__USDHC3_DAT3 | MUX_PAD_CTRL(USDHC_PAD_CTRL), -	MX6_PAD_SD3_DAT5__GPIO_7_0    | MUX_PAD_CTRL(NO_PAD_CTRL), /* CD */ -}; - -iomux_v3_cfg_t const usdhc4_pads[] = { -	MX6_PAD_SD4_CLK__USDHC4_CLK   | MUX_PAD_CTRL(USDHC_PAD_CTRL), -	MX6_PAD_SD4_CMD__USDHC4_CMD   | MUX_PAD_CTRL(USDHC_PAD_CTRL), -	MX6_PAD_SD4_DAT0__USDHC4_DAT0 | MUX_PAD_CTRL(USDHC_PAD_CTRL), -	MX6_PAD_SD4_DAT1__USDHC4_DAT1 | MUX_PAD_CTRL(USDHC_PAD_CTRL), -	MX6_PAD_SD4_DAT2__USDHC4_DAT2 | MUX_PAD_CTRL(USDHC_PAD_CTRL), -	MX6_PAD_SD4_DAT3__USDHC4_DAT3 | MUX_PAD_CTRL(USDHC_PAD_CTRL), -	MX6_PAD_NANDF_D6__GPIO_2_6    | MUX_PAD_CTRL(NO_PAD_CTRL), /* CD */ -}; - -iomux_v3_cfg_t const enet_pads1[] = { -	MX6_PAD_ENET_MDIO__ENET_MDIO		| MUX_PAD_CTRL(ENET_PAD_CTRL), -	MX6_PAD_ENET_MDC__ENET_MDC		| MUX_PAD_CTRL(ENET_PAD_CTRL), -	MX6_PAD_RGMII_TXC__ENET_RGMII_TXC	| MUX_PAD_CTRL(ENET_PAD_CTRL), -	MX6_PAD_RGMII_TD0__ENET_RGMII_TD0	| MUX_PAD_CTRL(ENET_PAD_CTRL), -	MX6_PAD_RGMII_TD1__ENET_RGMII_TD1	| MUX_PAD_CTRL(ENET_PAD_CTRL), -	MX6_PAD_RGMII_TD2__ENET_RGMII_TD2	| MUX_PAD_CTRL(ENET_PAD_CTRL), -	MX6_PAD_RGMII_TD3__ENET_RGMII_TD3	| MUX_PAD_CTRL(ENET_PAD_CTRL), -	MX6_PAD_RGMII_TX_CTL__RGMII_TX_CTL	| MUX_PAD_CTRL(ENET_PAD_CTRL), -	MX6_PAD_ENET_REF_CLK__ENET_TX_CLK	| MUX_PAD_CTRL(ENET_PAD_CTRL), -	/* pin 35 - 1 (PHY_AD2) on reset */ -	MX6_PAD_RGMII_RXC__GPIO_6_30		| MUX_PAD_CTRL(NO_PAD_CTRL), -	/* pin 32 - 1 - (MODE0) all */ -	MX6_PAD_RGMII_RD0__GPIO_6_25		| MUX_PAD_CTRL(NO_PAD_CTRL), -	/* pin 31 - 1 - (MODE1) all */ -	MX6_PAD_RGMII_RD1__GPIO_6_27		| MUX_PAD_CTRL(NO_PAD_CTRL), -	/* pin 28 - 1 - (MODE2) all */ -	MX6_PAD_RGMII_RD2__GPIO_6_28		| MUX_PAD_CTRL(NO_PAD_CTRL), -	/* pin 27 - 1 - (MODE3) all */ -	MX6_PAD_RGMII_RD3__GPIO_6_29		| MUX_PAD_CTRL(NO_PAD_CTRL), -	/* pin 33 - 1 - (CLK125_EN) 125Mhz clockout enabled */ -	MX6_PAD_RGMII_RX_CTL__GPIO_6_24	| MUX_PAD_CTRL(NO_PAD_CTRL), -	/* pin 42 PHY nRST */ -	MX6_PAD_EIM_D23__GPIO_3_23		| MUX_PAD_CTRL(NO_PAD_CTRL), -}; - -iomux_v3_cfg_t const enet_pads2[] = { -	MX6_PAD_RGMII_RXC__ENET_RGMII_RXC	| MUX_PAD_CTRL(ENET_PAD_CTRL), -	MX6_PAD_RGMII_RD0__ENET_RGMII_RD0	| MUX_PAD_CTRL(ENET_PAD_CTRL), -	MX6_PAD_RGMII_RD1__ENET_RGMII_RD1	| MUX_PAD_CTRL(ENET_PAD_CTRL), -	MX6_PAD_RGMII_RD2__ENET_RGMII_RD2	| MUX_PAD_CTRL(ENET_PAD_CTRL), -	MX6_PAD_RGMII_RD3__ENET_RGMII_RD3	| MUX_PAD_CTRL(ENET_PAD_CTRL), -	MX6_PAD_RGMII_RX_CTL__RGMII_RX_CTL	| MUX_PAD_CTRL(ENET_PAD_CTRL), -}; - -/* Button assignments for J14 */ -static iomux_v3_cfg_t const button_pads[] = { -	/* Menu */ -	MX6_PAD_NANDF_D1__GPIO_2_1	| MUX_PAD_CTRL(BUTTON_PAD_CTRL), -	/* Back */ -	MX6_PAD_NANDF_D2__GPIO_2_2	| MUX_PAD_CTRL(BUTTON_PAD_CTRL), -	/* Labelled Search (mapped to Power under Android) */ -	MX6_PAD_NANDF_D3__GPIO_2_3	| MUX_PAD_CTRL(BUTTON_PAD_CTRL), -	/* Home */ -	MX6_PAD_NANDF_D4__GPIO_2_4	| MUX_PAD_CTRL(BUTTON_PAD_CTRL), -	/* Volume Down */ -	MX6_PAD_GPIO_19__GPIO_4_5	| MUX_PAD_CTRL(BUTTON_PAD_CTRL), -	/* Volume Up */ -	MX6_PAD_GPIO_18__GPIO_7_13	| MUX_PAD_CTRL(BUTTON_PAD_CTRL), -}; - -static void setup_iomux_enet(void) -{ -	gpio_direction_output(IMX_GPIO_NR(3, 23), 0); -	gpio_direction_output(IMX_GPIO_NR(6, 30), 1); -	gpio_direction_output(IMX_GPIO_NR(6, 25), 1); -	gpio_direction_output(IMX_GPIO_NR(6, 27), 1); -	gpio_direction_output(IMX_GPIO_NR(6, 28), 1); -	gpio_direction_output(IMX_GPIO_NR(6, 29), 1); -	imx_iomux_v3_setup_multiple_pads(enet_pads1, ARRAY_SIZE(enet_pads1)); -	gpio_direction_output(IMX_GPIO_NR(6, 24), 1); - -	/* Need delay 10ms according to KSZ9021 spec */ -	udelay(1000 * 10); -	gpio_set_value(IMX_GPIO_NR(3, 23), 1); - -	imx_iomux_v3_setup_multiple_pads(enet_pads2, ARRAY_SIZE(enet_pads2)); -} - -iomux_v3_cfg_t const usb_pads[] = { -	MX6_PAD_GPIO_17__GPIO_7_12 | MUX_PAD_CTRL(NO_PAD_CTRL), -}; - -static void setup_iomux_uart(void) -{ -	imx_iomux_v3_setup_multiple_pads(uart1_pads, ARRAY_SIZE(uart1_pads)); -	imx_iomux_v3_setup_multiple_pads(uart2_pads, ARRAY_SIZE(uart2_pads)); -} - -#ifdef CONFIG_USB_EHCI_MX6 -int board_ehci_hcd_init(int port) -{ -	imx_iomux_v3_setup_multiple_pads(usb_pads, ARRAY_SIZE(usb_pads)); - -	/* Reset USB hub */ -	gpio_direction_output(IMX_GPIO_NR(7, 12), 0); -	mdelay(2); -	gpio_set_value(IMX_GPIO_NR(7, 12), 1); - -	return 0; -} -#endif - -#ifdef CONFIG_FSL_ESDHC -struct fsl_esdhc_cfg usdhc_cfg[2] = { -	{USDHC3_BASE_ADDR}, -	{USDHC4_BASE_ADDR}, -}; - -int board_mmc_getcd(struct mmc *mmc) -{ -	struct fsl_esdhc_cfg *cfg = (struct fsl_esdhc_cfg *)mmc->priv; -	int ret; - -	if (cfg->esdhc_base == USDHC3_BASE_ADDR) { -		gpio_direction_input(IMX_GPIO_NR(7, 0)); -		ret = !gpio_get_value(IMX_GPIO_NR(7, 0)); -	} else { -		gpio_direction_input(IMX_GPIO_NR(2, 6)); -		ret = !gpio_get_value(IMX_GPIO_NR(2, 6)); -	} - -	return ret; -} - -int board_mmc_init(bd_t *bis) -{ -	s32 status = 0; -	u32 index = 0; - -	usdhc_cfg[0].sdhc_clk = mxc_get_clock(MXC_ESDHC3_CLK); -	usdhc_cfg[1].sdhc_clk = mxc_get_clock(MXC_ESDHC4_CLK); - -	usdhc_cfg[0].max_bus_width = 4; -	usdhc_cfg[1].max_bus_width = 4; - -	for (index = 0; index < CONFIG_SYS_FSL_USDHC_NUM; ++index) { -		switch (index) { -		case 0: -			imx_iomux_v3_setup_multiple_pads( -				usdhc3_pads, ARRAY_SIZE(usdhc3_pads)); -			break; -		case 1: -			imx_iomux_v3_setup_multiple_pads( -				usdhc4_pads, ARRAY_SIZE(usdhc4_pads)); -		       break; -	       default: -			printf("Warning: you configured more USDHC controllers" -			       "(%d) then supported by the board (%d)\n", -			       index + 1, CONFIG_SYS_FSL_USDHC_NUM); -			return status; -		} - -		status |= fsl_esdhc_initialize(bis, &usdhc_cfg[index]); -	} - -	return status; -} -#endif - -#ifdef CONFIG_MXC_SPI -iomux_v3_cfg_t const ecspi1_pads[] = { -	/* SS1 */ -	MX6_PAD_EIM_D19__GPIO_3_19   | MUX_PAD_CTRL(SPI_PAD_CTRL), -	MX6_PAD_EIM_D17__ECSPI1_MISO | MUX_PAD_CTRL(SPI_PAD_CTRL), -	MX6_PAD_EIM_D18__ECSPI1_MOSI | MUX_PAD_CTRL(SPI_PAD_CTRL), -	MX6_PAD_EIM_D16__ECSPI1_SCLK | MUX_PAD_CTRL(SPI_PAD_CTRL), -}; - -void setup_spi(void) -{ -	imx_iomux_v3_setup_multiple_pads(ecspi1_pads, -					 ARRAY_SIZE(ecspi1_pads)); -} -#endif - -int board_phy_config(struct phy_device *phydev) -{ -	/* min rx data delay */ -	ksz9021_phy_extended_write(phydev, -			MII_KSZ9021_EXT_RGMII_RX_DATA_SKEW, 0x0); -	/* min tx data delay */ -	ksz9021_phy_extended_write(phydev, -			MII_KSZ9021_EXT_RGMII_TX_DATA_SKEW, 0x0); -	/* max rx/tx clock delay, min rx/tx control */ -	ksz9021_phy_extended_write(phydev, -			MII_KSZ9021_EXT_RGMII_CLOCK_SKEW, 0xf0f0); -	if (phydev->drv->config) -		phydev->drv->config(phydev); - -	return 0; -} - -int board_eth_init(bd_t *bis) -{ -	uint32_t base = IMX_FEC_BASE; -	struct mii_dev *bus = NULL; -	struct phy_device *phydev = NULL; -	int ret; - -	setup_iomux_enet(); - -#ifdef CONFIG_FEC_MXC -	bus = fec_get_miibus(base, -1); -	if (!bus) -		return 0; -	/* scan phy 4,5,6,7 */ -	phydev = phy_find_by_mask(bus, (0xf << 4), PHY_INTERFACE_MODE_RGMII); -	if (!phydev) { -		free(bus); -		return 0; -	} -	printf("using phy at %d\n", phydev->addr); -	ret  = fec_probe(bis, -1, base, bus, phydev); -	if (ret) { -		printf("FEC MXC: %s:failed\n", __func__); -		free(phydev); -		free(bus); -	} -#endif -	return 0; -} - -static void setup_buttons(void) -{ -	imx_iomux_v3_setup_multiple_pads(button_pads, -					 ARRAY_SIZE(button_pads)); -} - -#ifdef CONFIG_CMD_SATA - -int setup_sata(void) -{ -	struct iomuxc_base_regs *const iomuxc_regs -		= (struct iomuxc_base_regs *) IOMUXC_BASE_ADDR; -	int ret = enable_sata_clock(); -	if (ret) -		return ret; - -	clrsetbits_le32(&iomuxc_regs->gpr[13], -			IOMUXC_GPR13_SATA_MASK, -			IOMUXC_GPR13_SATA_PHY_8_RXEQ_3P0DB -			|IOMUXC_GPR13_SATA_PHY_7_SATA2M -			|IOMUXC_GPR13_SATA_SPEED_3G -			|(3<<IOMUXC_GPR13_SATA_PHY_6_SHIFT) -			|IOMUXC_GPR13_SATA_SATA_PHY_5_SS_DISABLED -			|IOMUXC_GPR13_SATA_SATA_PHY_4_ATTEN_9_16 -			|IOMUXC_GPR13_SATA_PHY_3_TXBOOST_0P00_DB -			|IOMUXC_GPR13_SATA_PHY_2_TX_1P104V -			|IOMUXC_GPR13_SATA_PHY_1_SLOW); - -	return 0; -} -#endif - -#if defined(CONFIG_VIDEO_IPUV3) - -static iomux_v3_cfg_t const backlight_pads[] = { -	/* Backlight on RGB connector: J15 */ -	MX6_PAD_SD1_DAT3__GPIO_1_21 | MUX_PAD_CTRL(NO_PAD_CTRL), -#define RGB_BACKLIGHT_GP IMX_GPIO_NR(1, 21) - -	/* Backlight on LVDS connector: J6 */ -	MX6_PAD_SD1_CMD__GPIO_1_18 | MUX_PAD_CTRL(NO_PAD_CTRL), -#define LVDS_BACKLIGHT_GP IMX_GPIO_NR(1, 18) -}; - -static iomux_v3_cfg_t const rgb_pads[] = { -	MX6_PAD_DI0_DISP_CLK__IPU1_DI0_DISP_CLK, -	MX6_PAD_DI0_PIN15__IPU1_DI0_PIN15, -	MX6_PAD_DI0_PIN2__IPU1_DI0_PIN2, -	MX6_PAD_DI0_PIN3__IPU1_DI0_PIN3, -	MX6_PAD_DI0_PIN4__GPIO_4_20, -	MX6_PAD_DISP0_DAT0__IPU1_DISP0_DAT_0, -	MX6_PAD_DISP0_DAT1__IPU1_DISP0_DAT_1, -	MX6_PAD_DISP0_DAT2__IPU1_DISP0_DAT_2, -	MX6_PAD_DISP0_DAT3__IPU1_DISP0_DAT_3, -	MX6_PAD_DISP0_DAT4__IPU1_DISP0_DAT_4, -	MX6_PAD_DISP0_DAT5__IPU1_DISP0_DAT_5, -	MX6_PAD_DISP0_DAT6__IPU1_DISP0_DAT_6, -	MX6_PAD_DISP0_DAT7__IPU1_DISP0_DAT_7, -	MX6_PAD_DISP0_DAT8__IPU1_DISP0_DAT_8, -	MX6_PAD_DISP0_DAT9__IPU1_DISP0_DAT_9, -	MX6_PAD_DISP0_DAT10__IPU1_DISP0_DAT_10, -	MX6_PAD_DISP0_DAT11__IPU1_DISP0_DAT_11, -	MX6_PAD_DISP0_DAT12__IPU1_DISP0_DAT_12, -	MX6_PAD_DISP0_DAT13__IPU1_DISP0_DAT_13, -	MX6_PAD_DISP0_DAT14__IPU1_DISP0_DAT_14, -	MX6_PAD_DISP0_DAT15__IPU1_DISP0_DAT_15, -	MX6_PAD_DISP0_DAT16__IPU1_DISP0_DAT_16, -	MX6_PAD_DISP0_DAT17__IPU1_DISP0_DAT_17, -	MX6_PAD_DISP0_DAT18__IPU1_DISP0_DAT_18, -	MX6_PAD_DISP0_DAT19__IPU1_DISP0_DAT_19, -	MX6_PAD_DISP0_DAT20__IPU1_DISP0_DAT_20, -	MX6_PAD_DISP0_DAT21__IPU1_DISP0_DAT_21, -	MX6_PAD_DISP0_DAT22__IPU1_DISP0_DAT_22, -	MX6_PAD_DISP0_DAT23__IPU1_DISP0_DAT_23, -}; - -struct display_info_t { -	int	bus; -	int	addr; -	int	pixfmt; -	int	(*detect)(struct display_info_t const *dev); -	void	(*enable)(struct display_info_t const *dev); -	struct	fb_videomode mode; -}; - - -static int detect_hdmi(struct display_info_t const *dev) -{ -	struct hdmi_regs *hdmi	= (struct hdmi_regs *)HDMI_ARB_BASE_ADDR; -	return readb(&hdmi->phy_stat0) & HDMI_PHY_HPD; -} - -static void 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); -} - -static int detect_i2c(struct display_info_t const *dev) -{ -	return ((0 == i2c_set_bus_num(dev->bus)) -		&& -		(0 == i2c_probe(dev->addr))); -} - -static void enable_lvds(struct display_info_t const *dev) -{ -	struct iomuxc *iomux = (struct iomuxc *) -				IOMUXC_BASE_ADDR; -	u32 reg = readl(&iomux->gpr[2]); -	reg |= IOMUXC_GPR2_DATA_WIDTH_CH0_24BIT; -	writel(reg, &iomux->gpr[2]); -	gpio_direction_output(LVDS_BACKLIGHT_GP, 1); -} - -static void enable_rgb(struct display_info_t const *dev) -{ -	imx_iomux_v3_setup_multiple_pads( -		rgb_pads, -		 ARRAY_SIZE(rgb_pads)); -	gpio_direction_output(RGB_BACKLIGHT_GP, 1); -} - -static struct display_info_t const displays[] = {{ -	.bus	= -1, -	.addr	= 0, -	.pixfmt	= IPU_PIX_FMT_RGB24, -	.detect	= detect_hdmi, -	.enable	= enable_hdmi, -	.mode	= { -		.name           = "HDMI", -		.refresh        = 60, -		.xres           = 1024, -		.yres           = 768, -		.pixclock       = 15385, -		.left_margin    = 220, -		.right_margin   = 40, -		.upper_margin   = 21, -		.lower_margin   = 7, -		.hsync_len      = 60, -		.vsync_len      = 10, -		.sync           = FB_SYNC_EXT, -		.vmode          = FB_VMODE_NONINTERLACED -} }, { -	.bus	= 2, -	.addr	= 0x4, -	.pixfmt	= IPU_PIX_FMT_LVDS666, -	.detect	= detect_i2c, -	.enable	= enable_lvds, -	.mode	= { -		.name           = "Hannstar-XGA", -		.refresh        = 60, -		.xres           = 1024, -		.yres           = 768, -		.pixclock       = 15385, -		.left_margin    = 220, -		.right_margin   = 40, -		.upper_margin   = 21, -		.lower_margin   = 7, -		.hsync_len      = 60, -		.vsync_len      = 10, -		.sync           = FB_SYNC_EXT, -		.vmode          = FB_VMODE_NONINTERLACED -} }, { -	.bus	= 2, -	.addr	= 0x38, -	.pixfmt	= IPU_PIX_FMT_LVDS666, -	.detect	= detect_i2c, -	.enable	= enable_lvds, -	.mode	= { -		.name           = "wsvga-lvds", -		.refresh        = 60, -		.xres           = 1024, -		.yres           = 600, -		.pixclock       = 15385, -		.left_margin    = 220, -		.right_margin   = 40, -		.upper_margin   = 21, -		.lower_margin   = 7, -		.hsync_len      = 60, -		.vsync_len      = 10, -		.sync           = FB_SYNC_EXT, -		.vmode          = FB_VMODE_NONINTERLACED -} }, { -	.bus	= 2, -	.addr	= 0x48, -	.pixfmt	= IPU_PIX_FMT_RGB666, -	.detect	= detect_i2c, -	.enable	= enable_rgb, -	.mode	= { -		.name           = "wvga-rgb", -		.refresh        = 57, -		.xres           = 800, -		.yres           = 480, -		.pixclock       = 37037, -		.left_margin    = 40, -		.right_margin   = 60, -		.upper_margin   = 10, -		.lower_margin   = 10, -		.hsync_len      = 20, -		.vsync_len      = 10, -		.sync           = 0, -		.vmode          = FB_VMODE_NONINTERLACED -} } }; - -int board_video_skip(void) -{ -	int i; -	int ret; -	char const *panel = getenv("panel"); -	if (!panel) { -		for (i = 0; i < ARRAY_SIZE(displays); i++) { -			struct display_info_t const *dev = displays+i; -			if (dev->detect(dev)) { -				panel = dev->mode.name; -				printf("auto-detected panel %s\n", panel); -				break; -			} -		} -		if (!panel) { -			panel = displays[0].mode.name; -			printf("No panel detected: default to %s\n", panel); -		} -	} else { -		for (i = 0; i < ARRAY_SIZE(displays); i++) { -			if (!strcmp(panel, displays[i].mode.name)) -				break; -		} -	} -	if (i < ARRAY_SIZE(displays)) { -		ret = ipuv3_fb_init(&displays[i].mode, 0, -				    displays[i].pixfmt); -		if (!ret) { -			displays[i].enable(displays+i); -			printf("Display: %s (%ux%u)\n", -			       displays[i].mode.name, -			       displays[i].mode.xres, -			       displays[i].mode.yres); -		} else -			printf("LCD %s cannot be configured: %d\n", -			       displays[i].mode.name, ret); -	} else { -		printf("unsupported panel %s\n", panel); -		ret = -EINVAL; -	} -	return (0 != ret); -} - -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; - -	/* 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; -	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); - -	/* set LDB0, LDB1 clk select to 011/011 */ -	reg = readl(&mxc_ccm->cs2cdr); -	reg &= ~(MXC_CCM_CS2CDR_LDB_DI0_CLK_SEL_MASK -		 |MXC_CCM_CS2CDR_LDB_DI1_CLK_SEL_MASK); -	reg |= (3<<MXC_CCM_CS2CDR_LDB_DI0_CLK_SEL_OFFSET) -	      |(3<<MXC_CCM_CS2CDR_LDB_DI1_CLK_SEL_OFFSET); -	writel(reg, &mxc_ccm->cs2cdr); - -	reg = readl(&mxc_ccm->cscmr2); -	reg |= MXC_CCM_CSCMR2_LDB_DI0_IPU_DIV; -	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); -	writel(reg, &mxc_ccm->chsccdr); - -	reg = IOMUXC_GPR2_BGREF_RRMODE_EXTERNAL_RES -	     |IOMUXC_GPR2_DI1_VS_POLARITY_ACTIVE_HIGH -	     |IOMUXC_GPR2_DI0_VS_POLARITY_ACTIVE_LOW -	     |IOMUXC_GPR2_BIT_MAPPING_CH1_SPWG -	     |IOMUXC_GPR2_DATA_WIDTH_CH1_18BIT -	     |IOMUXC_GPR2_BIT_MAPPING_CH0_SPWG -	     |IOMUXC_GPR2_DATA_WIDTH_CH0_18BIT -	     |IOMUXC_GPR2_LVDS_CH1_MODE_DISABLED -	     |IOMUXC_GPR2_LVDS_CH0_MODE_ENABLED_DI0; -	writel(reg, &iomux->gpr[2]); - -	reg = readl(&iomux->gpr[3]); -	reg = (reg & ~IOMUXC_GPR3_LVDS0_MUX_CTL_MASK) -	    | (IOMUXC_GPR3_MUX_SRC_IPU1_DI0 -	       <<IOMUXC_GPR3_LVDS0_MUX_CTL_OFFSET); -	writel(reg, &iomux->gpr[3]); - -	/* backlights off until needed */ -	imx_iomux_v3_setup_multiple_pads(backlight_pads, -					 ARRAY_SIZE(backlight_pads)); -	gpio_direction_input(LVDS_BACKLIGHT_GP); -	gpio_direction_input(RGB_BACKLIGHT_GP); -} -#endif - -int board_early_init_f(void) -{ -	setup_iomux_uart(); -	setup_buttons(); - -#if defined(CONFIG_VIDEO_IPUV3) -	setup_display(); -#endif -	return 0; -} - -/* - * Do not overwrite the console - * Use always serial for U-Boot console - */ -int overwrite_console(void) -{ -	return 1; -} - -int board_init(void) -{ -	/* address of boot parameters */ -	gd->bd->bi_boot_params = PHYS_SDRAM + 0x100; - -#ifdef CONFIG_MXC_SPI -	setup_spi(); -#endif -	setup_i2c(0, CONFIG_SYS_I2C_SPEED, 0x7f, &i2c_pad_info0); -	setup_i2c(1, CONFIG_SYS_I2C_SPEED, 0x7f, &i2c_pad_info1); -	setup_i2c(2, CONFIG_SYS_I2C_SPEED, 0x7f, &i2c_pad_info2); - -#ifdef CONFIG_CMD_SATA -	setup_sata(); -#endif - -	return 0; -} - -int checkboard(void) -{ -	puts("Board: MX6Q-Sabre Lite\n"); - -	return 0; -} - -struct button_key { -	char const	*name; -	unsigned	gpnum; -	char		ident; -}; - -static struct button_key const buttons[] = { -	{"back",	IMX_GPIO_NR(2, 2),	'B'}, -	{"home",	IMX_GPIO_NR(2, 4),	'H'}, -	{"menu",	IMX_GPIO_NR(2, 1),	'M'}, -	{"search",	IMX_GPIO_NR(2, 3),	'S'}, -	{"volup",	IMX_GPIO_NR(7, 13),	'V'}, -	{"voldown",	IMX_GPIO_NR(4, 5),	'v'}, -}; - -/* - * generate a null-terminated string containing the buttons pressed - * returns number of keys pressed - */ -static int read_keys(char *buf) -{ -	int i, numpressed = 0; -	for (i = 0; i < ARRAY_SIZE(buttons); i++) { -		if (!gpio_get_value(buttons[i].gpnum)) -			buf[numpressed++] = buttons[i].ident; -	} -	buf[numpressed] = '\0'; -	return numpressed; -} - -static int do_kbd(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) -{ -	char envvalue[ARRAY_SIZE(buttons)+1]; -	int numpressed = read_keys(envvalue); -	setenv("keybd", envvalue); -	return numpressed == 0; -} - -U_BOOT_CMD( -	kbd, 1, 1, do_kbd, -	"Tests for keypresses, sets 'keybd' environment variable", -	"Returns 0 (true) to shell if key is pressed." -); - -#ifdef CONFIG_PREBOOT -static char const kbd_magic_prefix[] = "key_magic"; -static char const kbd_command_prefix[] = "key_cmd"; - -static void preboot_keys(void) -{ -	int numpressed; -	char keypress[ARRAY_SIZE(buttons)+1]; -	numpressed = read_keys(keypress); -	if (numpressed) { -		char *kbd_magic_keys = getenv("magic_keys"); -		char *suffix; -		/* -		 * loop over all magic keys -		 */ -		for (suffix = kbd_magic_keys; *suffix; ++suffix) { -			char *keys; -			char magic[sizeof(kbd_magic_prefix) + 1]; -			sprintf(magic, "%s%c", kbd_magic_prefix, *suffix); -			keys = getenv(magic); -			if (keys) { -				if (!strcmp(keys, keypress)) -					break; -			} -		} -		if (*suffix) { -			char cmd_name[sizeof(kbd_command_prefix) + 1]; -			char *cmd; -			sprintf(cmd_name, "%s%c", kbd_command_prefix, *suffix); -			cmd = getenv(cmd_name); -			if (cmd) { -				setenv("preboot", cmd); -				return; -			} -		} -	} -} -#endif - -#ifdef CONFIG_CMD_BMODE -static const struct boot_mode board_boot_modes[] = { -	/* 4 bit bus width */ -	{"mmc0",	MAKE_CFGVAL(0x40, 0x30, 0x00, 0x00)}, -	{"mmc1",	MAKE_CFGVAL(0x40, 0x38, 0x00, 0x00)}, -	{NULL,		0}, -}; -#endif - -int misc_init_r(void) -{ -#ifdef CONFIG_PREBOOT -	preboot_keys(); -#endif - -#ifdef CONFIG_CMD_BMODE -	add_board_boot_modes(board_boot_modes); -#endif -	return 0; -} diff --git a/board/freescale/mx6sabresd/mx6sabresd.c b/board/freescale/mx6sabresd/mx6sabresd.c index 936f029b4..5db516d5f 100644 --- a/board/freescale/mx6sabresd/mx6sabresd.c +++ b/board/freescale/mx6sabresd/mx6sabresd.c @@ -18,7 +18,12 @@  #include <fsl_esdhc.h>  #include <miiphy.h>  #include <netdev.h> - +#include <asm/arch/mxc_hdmi.h> +#include <asm/arch/crm_regs.h> +#include <linux/fb.h> +#include <ipu_pixfmt.h> +#include <asm/io.h> +#include <asm/arch/sys_proto.h>  DECLARE_GLOBAL_DATA_PTR;  #define UART_PAD_CTRL  (PAD_CTL_PUS_100K_UP |			\ @@ -228,6 +233,60 @@ int board_phy_config(struct phy_device *phydev)  	return 0;  } +#if defined(CONFIG_VIDEO_IPUV3) +static struct fb_videomode const hdmi = { +	.name           = "HDMI", +	.refresh        = 60, +	.xres           = 1024, +	.yres           = 768, +	.pixclock       = 15385, +	.left_margin    = 220, +	.right_margin   = 40, +	.upper_margin   = 21, +	.lower_margin   = 7, +	.hsync_len      = 60, +	.vsync_len      = 10, +	.sync           = FB_SYNC_EXT, +	.vmode          = FB_VMODE_NONINTERLACED +}; + +int board_video_skip(void) +{ +	int ret; + +	ret = ipuv3_fb_init(&hdmi, 0, IPU_PIX_FMT_RGB24); + +	if (ret) +		printf("HDMI cannot be configured: %d\n", ret); + +	imx_enable_hdmi_phy(); +	return ret; +} + +static void setup_display(void) +{ +	struct mxc_ccm_reg *mxc_ccm = (struct mxc_ccm_reg *)CCM_BASE_ADDR; +	int reg; + +	enable_ipu_clock(); +	imx_setup_hdmi(); + +	reg = readl(&mxc_ccm->chsccdr); +	reg |= (CHSCCDR_CLK_SEL_LDB_DI0 +		<< MXC_CCM_CHSCCDR_IPU1_DI0_CLK_SEL_OFFSET); +	writel(reg, &mxc_ccm->chsccdr); +} +#endif /* CONFIG_VIDEO_IPUV3 */ + +/* + * Do not overwrite the console + * Use always serial for U-Boot console + */ +int overwrite_console(void) +{ +	return 1; +} +  int board_eth_init(bd_t *bis)  {  	int ret; @@ -244,6 +303,9 @@ int board_eth_init(bd_t *bis)  int board_early_init_f(void)  {  	setup_iomux_uart(); +#if defined(CONFIG_VIDEO_IPUV3) +	setup_display(); +#endif  	return 0;  } diff --git a/board/freescale/p1010rdb/ddr.c b/board/freescale/p1010rdb/ddr.c index aa8badab4..681f052e4 100644 --- a/board/freescale/p1010rdb/ddr.c +++ b/board/freescale/p1010rdb/ddr.c @@ -139,7 +139,7 @@ phys_size_t fixed_sdram(void)  	}  	ddr_size = (phys_size_t) CONFIG_SYS_SDRAM_SIZE * 1024 * 1024; -	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 0); +	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 0, 0);  	if (set_ddr_laws(CONFIG_SYS_DDR_SDRAM_BASE, ddr_size,  					LAW_TRGT_IF_DDR_1) < 0) { diff --git a/board/freescale/p1010rdb/spl_minimal.c b/board/freescale/p1010rdb/spl_minimal.c index 73289f365..d0e712eb3 100644 --- a/board/freescale/p1010rdb/spl_minimal.c +++ b/board/freescale/p1010rdb/spl_minimal.c @@ -26,7 +26,7 @@ void sdram_init(void)  	ddr_ratio = in_be32(&gur->porpllsr) & MPC85xx_PORPLLSR_DDR_RATIO;  	ddr_ratio = ddr_ratio >> MPC85xx_PORPLLSR_DDR_RATIO_SHIFT; -	ddr_freq_mhz = (CONFIG_SYS_CLK_FREQ * ddr_ratio) / 0x1000000; +	ddr_freq_mhz = (CONFIG_SYS_CLK_FREQ * ddr_ratio) / 1000000;  	/* mask off E bit */  	u32 svr = SVR_SOC_VER(mfspr(SPRN_SVR)); diff --git a/board/freescale/p1022ds/Makefile b/board/freescale/p1022ds/Makefile index cfc05f712..3bc4f4325 100644 --- a/board/freescale/p1022ds/Makefile +++ b/board/freescale/p1022ds/Makefile @@ -21,6 +21,9 @@ ifdef MINIMAL  COBJS-y        += spl_minimal.o tlb.o law.o  else +ifdef CONFIG_SPL_BUILD +COBJS-y += spl.o +endif  COBJS-y	+= $(BOARD).o  COBJS-y	+= ddr.o  COBJS-y	+= law.o diff --git a/board/freescale/p1022ds/spl.c b/board/freescale/p1022ds/spl.c new file mode 100644 index 000000000..b9dbf81b3 --- /dev/null +++ b/board/freescale/p1022ds/spl.c @@ -0,0 +1,121 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <ns16550.h> +#include <malloc.h> +#include <mmc.h> +#include <nand.h> +#include <i2c.h> +#include "../common/ngpixis.h" +#include <fsl_esdhc.h> +#include <spi_flash.h> + +DECLARE_GLOBAL_DATA_PTR; + +static const u32 sysclk_tbl[] = { +	66666000, 7499900, 83332500, 8999900, +	99999000, 11111000, 12499800, 13333200 +}; + +ulong get_effective_memsize(void) +{ +	return CONFIG_SYS_L2_SIZE; +} + +void board_init_f(ulong bootflag) +{ +	int px_spd; +	u32 plat_ratio, sys_clk, bus_clk; +	ccsr_gur_t *gur = (void *)CONFIG_SYS_MPC85xx_GUTS_ADDR; + +	console_init_f(); + +	/* Set pmuxcr to allow both i2c1 and i2c2 */ +	setbits_be32(&gur->pmuxcr, in_be32(&gur->pmuxcr) | 0x1000); +	setbits_be32(&gur->pmuxcr, +		     in_be32(&gur->pmuxcr) | MPC85xx_PMUXCR_SD_DATA); + +#ifdef CONFIG_SPL_SPI_BOOT +	/* Enable the SPI */ +	clrsetbits_8(&pixis->brdcfg0, PIXIS_ELBC_SPI_MASK, PIXIS_SPI); +#endif + +	/* Read back the register to synchronize the write. */ +	in_be32(&gur->pmuxcr); + +	/* initialize selected port with appropriate baud rate */ +	px_spd = in_8((unsigned char *)(PIXIS_BASE + PIXIS_SPD)); +	sys_clk = sysclk_tbl[px_spd & PIXIS_SPD_SYSCLK_MASK]; +	plat_ratio = in_be32(&gur->porpllsr) & MPC85xx_PORPLLSR_PLAT_RATIO; +	bus_clk = sys_clk * plat_ratio / 2; + +	NS16550_init((NS16550_t)CONFIG_SYS_NS16550_COM1, +		     bus_clk / 16 / CONFIG_BAUDRATE); +#ifdef CONFIG_SPL_MMC_BOOT +	puts("\nSD boot...\n"); +#elif defined(CONFIG_SPL_SPI_BOOT) +	puts("\nSPI Flash boot...\n"); +#endif + +	/* copy code to RAM and jump to it - this should not return */ +	/* NOTE - code has to be copied out of NAND buffer before +	 * other blocks can be read. +	 */ +	relocate_code(CONFIG_SPL_RELOC_STACK, 0, CONFIG_SPL_RELOC_TEXT_BASE); +} + +void board_init_r(gd_t *gd, ulong dest_addr) +{ +	/* Pointer is writable since we allocated a register for it */ +	gd = (gd_t *)CONFIG_SPL_GD_ADDR; +	bd_t *bd; + +	memset(gd, 0, sizeof(gd_t)); +	bd = (bd_t *)(CONFIG_SPL_GD_ADDR + sizeof(gd_t)); +	memset(bd, 0, sizeof(bd_t)); +	gd->bd = bd; +	bd->bi_memstart = CONFIG_SYS_INIT_L2_ADDR; +	bd->bi_memsize = CONFIG_SYS_L2_SIZE; + +	probecpu(); +	get_clocks(); +	mem_malloc_init(CONFIG_SPL_RELOC_MALLOC_ADDR, +			CONFIG_SPL_RELOC_MALLOC_SIZE); +#ifndef CONFIG_SPL_NAND_BOOT +	env_init(); +#endif +#ifdef CONFIG_SPL_MMC_BOOT +	mmc_initialize(bd); +#endif +	/* relocate environment function pointers etc. */ +#ifdef CONFIG_SPL_NAND_BOOT +	nand_spl_load_image(CONFIG_ENV_OFFSET, CONFIG_ENV_SIZE, +			    (uchar *)CONFIG_ENV_ADDR); + +	gd->env_addr  = (ulong)(CONFIG_ENV_ADDR); +	gd->env_valid = 1; +#else +	env_relocate(); +#endif + +	i2c_init(CONFIG_SYS_FSL_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); + +	gd->ram_size = initdram(0); +#ifdef CONFIG_SPL_NAND_BOOT +	puts("Tertiary program loader running in sram..."); +#else +	puts("Second program loader running in sram...\n"); +#endif + +#ifdef CONFIG_SPL_MMC_BOOT +	mmc_boot(); +#elif defined(CONFIG_SPL_SPI_BOOT) +	spi_boot(); +#elif defined(CONFIG_SPL_NAND_BOOT) +	nand_boot(); +#endif +} diff --git a/board/freescale/p1022ds/spl_minimal.c b/board/freescale/p1022ds/spl_minimal.c index d150d95a2..8b3439684 100644 --- a/board/freescale/p1022ds/spl_minimal.c +++ b/board/freescale/p1022ds/spl_minimal.c @@ -12,51 +12,6 @@  #include <asm/fsl_ddr_sdram.h> -/* - * Fixed sdram init -- doesn't use serial presence detect. - */ -void sdram_init(void) -{ -	volatile ccsr_ddr_t *ddr = (ccsr_ddr_t *)CONFIG_SYS_MPC8xxx_DDR_ADDR; - -	__raw_writel(CONFIG_SYS_DDR_CS0_BNDS, &ddr->cs0_bnds); -	__raw_writel(CONFIG_SYS_DDR_CS0_CONFIG, &ddr->cs0_config); -#if CONFIG_CHIP_SELECTS_PER_CTRL > 1 -	__raw_writel(CONFIG_SYS_DDR_CS1_BNDS, &ddr->cs1_bnds); -	__raw_writel(CONFIG_SYS_DDR_CS1_CONFIG, &ddr->cs1_config); -#endif -	__raw_writel(CONFIG_SYS_DDR_TIMING_3, &ddr->timing_cfg_3); -	__raw_writel(CONFIG_SYS_DDR_TIMING_0, &ddr->timing_cfg_0); -	__raw_writel(CONFIG_SYS_DDR_TIMING_1, &ddr->timing_cfg_1); -	__raw_writel(CONFIG_SYS_DDR_TIMING_2, &ddr->timing_cfg_2); - -	__raw_writel(CONFIG_SYS_DDR_CONTROL_2, &ddr->sdram_cfg_2); -	__raw_writel(CONFIG_SYS_DDR_MODE_1, &ddr->sdram_mode); -	__raw_writel(CONFIG_SYS_DDR_MODE_2, &ddr->sdram_mode_2); - -	__raw_writel(CONFIG_SYS_DDR_INTERVAL, &ddr->sdram_interval); -	__raw_writel(CONFIG_SYS_DDR_DATA_INIT, &ddr->sdram_data_init); -	__raw_writel(CONFIG_SYS_DDR_CLK_CTRL, &ddr->sdram_clk_cntl); - -	__raw_writel(CONFIG_SYS_DDR_TIMING_4, &ddr->timing_cfg_4); -	__raw_writel(CONFIG_SYS_DDR_TIMING_5, &ddr->timing_cfg_5); -	__raw_writel(CONFIG_SYS_DDR_ZQ_CONTROL, &ddr->ddr_zq_cntl); -	__raw_writel(CONFIG_SYS_DDR_WRLVL_CONTROL, &ddr->ddr_wrlvl_cntl); - -	/* Set, but do not enable the memory */ -	__raw_writel(CONFIG_SYS_DDR_CONTROL & ~SDRAM_CFG_MEM_EN, -			&ddr->sdram_cfg); - -	in_be32(&ddr->sdram_cfg); -	udelay(500); - -	/* Let the controller go */ -	out_be32(&ddr->sdram_cfg, in_be32(&ddr->sdram_cfg) | SDRAM_CFG_MEM_EN); -	in_be32(&ddr->sdram_cfg); - -	set_next_law(0, CONFIG_SYS_SDRAM_SIZE_LAW, LAW_TRGT_IF_DDR_1); -} -  const static u32 sysclk_tbl[] = {  	66666000, 7499900, 83332500, 8999900,  	99999000, 11111000, 12499800, 13333200 @@ -68,6 +23,10 @@ void board_init_f(ulong bootflag)  	u32 plat_ratio, sys_clk, bus_clk;  	ccsr_gur_t *gur = (void *)CONFIG_SYS_MPC85xx_GUTS_ADDR; +#if defined(CONFIG_SYS_NAND_BR_PRELIM) && defined(CONFIG_SYS_NAND_OR_PRELIM) +	set_lbc_br(0, CONFIG_SYS_NAND_BR_PRELIM); +	set_lbc_or(0, CONFIG_SYS_NAND_OR_PRELIM); +#endif  	/* for FPGA */  	set_lbc_br(2, CONFIG_SYS_BR2_PRELIM);  	set_lbc_or(2, CONFIG_SYS_OR2_PRELIM); @@ -83,9 +42,6 @@ void board_init_f(ulong bootflag)  	puts("\nNAND boot... "); -	/* Initialize the DDR3 */ -	sdram_init(); -  	/* copy code to RAM and jump to it - this should not return */  	/* NOTE - code has to be copied out of NAND buffer before  	 * other blocks can be read. @@ -96,6 +52,7 @@ void board_init_f(ulong bootflag)  void board_init_r(gd_t *gd, ulong dest_addr)  { +	puts("\nSecond program loader running in sram...");  	nand_boot();  } diff --git a/board/freescale/p1022ds/tlb.c b/board/freescale/p1022ds/tlb.c index 2eef6adbf..e7ae2e25b 100644 --- a/board/freescale/p1022ds/tlb.c +++ b/board/freescale/p1022ds/tlb.c @@ -71,25 +71,32 @@ struct fsl_e_tlb_entry tlb_table[] = {  		      MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G,  		      0, 7, BOOKE_PAGESZ_4K, 1), -#if defined(CONFIG_SYS_RAMBOOT) || defined(CONFIG_SPL) +#if defined(CONFIG_SYS_RAMBOOT) || \ +	(defined(CONFIG_SPL) && !defined(CONFIG_SPL_COMMON_INIT_DDR))  	/* **** - eSDHC/eSPI/NAND boot */  	SET_TLB_ENTRY(1, CONFIG_SYS_DDR_SDRAM_BASE, CONFIG_SYS_DDR_SDRAM_BASE, -			MAS3_SX|MAS3_SW|MAS3_SR, 0, -			0, 8, BOOKE_PAGESZ_1G, 1), +		      MAS3_SX|MAS3_SW|MAS3_SR, 0, +		      0, 8, BOOKE_PAGESZ_1G, 1),  	/* **** - eSDHC/eSPI/NAND boot - second 1GB of memory */  	SET_TLB_ENTRY(1, CONFIG_SYS_DDR_SDRAM_BASE + 0x40000000, -			CONFIG_SYS_DDR_SDRAM_BASE + 0x40000000, -			MAS3_SX|MAS3_SW|MAS3_SR, 0, -			0, 9, BOOKE_PAGESZ_1G, 1), +		      CONFIG_SYS_DDR_SDRAM_BASE + 0x40000000, +		      MAS3_SX|MAS3_SW|MAS3_SR, 0, +		      0, 9, BOOKE_PAGESZ_1G, 1),  #endif  #ifdef CONFIG_SYS_NAND_BASE  	/* *I*G - NAND */  	SET_TLB_ENTRY(1, CONFIG_SYS_NAND_BASE, CONFIG_SYS_NAND_BASE_PHYS, -			MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, -			0, 10, BOOKE_PAGESZ_16K, 1), +		      MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		      0, 10, BOOKE_PAGESZ_16K, 1),  #endif +#ifdef CONFIG_SYS_INIT_L2_ADDR +	/* *I*G - L2SRAM */ +	SET_TLB_ENTRY(1, CONFIG_SYS_INIT_L2_ADDR, CONFIG_SYS_INIT_L2_ADDR_PHYS, +		      MAS3_SX|MAS3_SW|MAS3_SR, MAS2_G, +		      0, 11, BOOKE_PAGESZ_256K, 1) +#endif  };  int num_tlb_entries = ARRAY_SIZE(tlb_table); diff --git a/board/freescale/p1_p2_rdb/ddr.c b/board/freescale/p1_p2_rdb/ddr.c index 0038077fc..5bee22e63 100644 --- a/board/freescale/p1_p2_rdb/ddr.c +++ b/board/freescale/p1_p2_rdb/ddr.c @@ -220,7 +220,7 @@ phys_size_t fixed_sdram (void)  		ddr_cfg_regs.cs[0].bnds = 0x0000001F;  	} -	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 0); +	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 0, 0);  	set_ddr_laws(0, ddr_size, LAW_TRGT_IF_DDR_1);  	return ddr_size; diff --git a/board/freescale/p1_p2_rdb_pc/README b/board/freescale/p1_p2_rdb_pc/README index 44377317d..f4cc43fbf 100644 --- a/board/freescale/p1_p2_rdb_pc/README +++ b/board/freescale/p1_p2_rdb_pc/README @@ -3,6 +3,7 @@ Overview  P1_P2_RDB_PC represents a set of boards including      P1020MSBG-PC      P1020RDB-PC +    P1020RDB-PD      P1020UTM-PC      P1021RDB-PC      P1024RDB diff --git a/board/freescale/p1_p2_rdb_pc/ddr.c b/board/freescale/p1_p2_rdb_pc/ddr.c index 9355536b3..c0b72e035 100644 --- a/board/freescale/p1_p2_rdb_pc/ddr.c +++ b/board/freescale/p1_p2_rdb_pc/ddr.c @@ -80,7 +80,7 @@ dimm_params_t ddr_raw_timing = {  	.refresh_rate_ps = 7800000,  	.tFAW_ps = 30000,  }; -#elif defined(CONFIG_P1020MBG) +#elif (defined(CONFIG_P1020MBG) || defined(CONFIG_P1020RDB_PD))  /* Micron MT41J512M8_187E */  dimm_params_t ddr_raw_timing = {  	.n_ranks = 2, @@ -111,7 +111,7 @@ dimm_params_t ddr_raw_timing = {  	.refresh_rate_ps = 7800000,  	.tFAW_ps = 37500,  }; -#elif defined(CONFIG_P1020RDB) +#elif defined(CONFIG_P1020RDB_PC)  /*   * Samsung K4B2G0846C-HCF8   * The following timing are for "downshift" @@ -247,11 +247,11 @@ phys_size_t fixed_sdram(void)  	get_sys_info(&sysinfo);  	printf("Configuring DDR for %s MT/s data rate\n", -			strmhz(buf, sysinfo.freqDDRBus)); +			strmhz(buf, sysinfo.freq_ddrbus));  	ddr_size = CONFIG_SYS_SDRAM_SIZE * 1024 * 1024; -	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 0); +	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 0, 0);  	if (set_ddr_laws(CONFIG_SYS_DDR_SDRAM_BASE,  				ddr_size, LAW_TRGT_IF_DDR_1) < 0) { diff --git a/board/freescale/p1_p2_rdb_pc/tlb.c b/board/freescale/p1_p2_rdb_pc/tlb.c index 93896dc71..d4561c764 100644 --- a/board/freescale/p1_p2_rdb_pc/tlb.c +++ b/board/freescale/p1_p2_rdb_pc/tlb.c @@ -94,7 +94,7 @@ struct fsl_e_tlb_entry tlb_table[] = {  			MAS3_SX|MAS3_SW|MAS3_SR, 0,  			0, 8, BOOKE_PAGESZ_1G, 1), -#ifdef CONFIG_P1020MBG +#if defined(CONFIG_P1020MBG) || defined(CONFIG_P1020RDB_PD)  	/* 2G DDR on P1020MBG, map the second 1G */  	SET_TLB_ENTRY(1, CONFIG_SYS_DDR_SDRAM_BASE + 0x40000000,  			CONFIG_SYS_DDR_SDRAM_BASE + 0x40000000, diff --git a/board/freescale/p1_twr/Makefile b/board/freescale/p1_twr/Makefile new file mode 100644 index 000000000..915b9bc89 --- /dev/null +++ b/board/freescale/p1_twr/Makefile @@ -0,0 +1,35 @@ +# +# Copyright 2013 Freescale Semiconductor, Inc. +# +# SPDX-License-Identifier:	GPL-2.0+ + +include $(TOPDIR)/config.mk + +LIB    = $(obj)lib$(BOARD).o + +COBJS-y        += $(BOARD).o +COBJS-y        += ddr.o +COBJS-y        += law.o +COBJS-y        += tlb.o + +SRCS   := $(SOBJS:.o=.S) $(COBJS-y:.o=.c) +OBJS   := $(addprefix $(obj),$(COBJS-y)) +SOBJS  := $(addprefix $(obj),$(SOBJS)) + +$(LIB):	$(obj).depend $(OBJS) $(SOBJS) +	$(call cmd_link_o_target, $(OBJS)) + +clean: +	rm -f $(OBJS) $(SOBJS) + +distclean:	clean +	rm -f $(LIB) core *.bak .depend + +######################################################################### + +# defines $(obj).depend target +include $(SRCTREE)/rules.mk + +sinclude $(obj).depend + +######################################################################### diff --git a/board/freescale/p1_twr/ddr.c b/board/freescale/p1_twr/ddr.c new file mode 100644 index 000000000..67f69d79b --- /dev/null +++ b/board/freescale/p1_twr/ddr.c @@ -0,0 +1,69 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <asm/mmu.h> +#include <asm/immap_85xx.h> +#include <asm/processor.h> +#include <asm/fsl_ddr_sdram.h> +#include <asm/fsl_ddr_dimm_params.h> +#include <asm/io.h> +#include <asm/fsl_law.h> + +/* Fixed sdram init -- doesn't use serial presence detect. */ +phys_size_t fixed_sdram(void) +{ +	sys_info_t sysinfo; +	char buf[32]; +	size_t ddr_size; +	fsl_ddr_cfg_regs_t ddr_cfg_regs = { +		.cs[0].bnds = CONFIG_SYS_DDR_CS0_BNDS, +		.cs[0].config = CONFIG_SYS_DDR_CS0_CONFIG, +		.cs[0].config_2 = CONFIG_SYS_DDR_CS0_CONFIG_2, +#if CONFIG_CHIP_SELECTS_PER_CTRL > 1 +		.cs[1].bnds = CONFIG_SYS_DDR_CS1_BNDS, +		.cs[1].config = CONFIG_SYS_DDR_CS1_CONFIG, +		.cs[1].config_2 = CONFIG_SYS_DDR_CS1_CONFIG_2, +#endif +		.timing_cfg_3 = CONFIG_SYS_DDR_TIMING_3, +		.timing_cfg_0 = CONFIG_SYS_DDR_TIMING_0, +		.timing_cfg_1 = CONFIG_SYS_DDR_TIMING_1, +		.timing_cfg_2 = CONFIG_SYS_DDR_TIMING_2, +		.ddr_sdram_cfg = CONFIG_SYS_DDR_CONTROL, +		.ddr_sdram_cfg_2 = CONFIG_SYS_DDR_CONTROL_2, +		.ddr_sdram_mode = CONFIG_SYS_DDR_MODE_1, +		.ddr_sdram_mode_2 = CONFIG_SYS_DDR_MODE_2, +		.ddr_sdram_md_cntl = CONFIG_SYS_DDR_MODE_CONTROL, +		.ddr_sdram_interval = CONFIG_SYS_DDR_INTERVAL, +		.ddr_data_init = CONFIG_SYS_DDR_DATA_INIT, +		.ddr_sdram_clk_cntl = CONFIG_SYS_DDR_CLK_CTRL, +		.ddr_init_addr = CONFIG_SYS_DDR_INIT_ADDR, +		.ddr_init_ext_addr = CONFIG_SYS_DDR_INIT_EXT_ADDR, +		.timing_cfg_4 = CONFIG_SYS_DDR_TIMING_4, +		.timing_cfg_5 = CONFIG_SYS_DDR_TIMING_5, +		.ddr_zq_cntl = CONFIG_SYS_DDR_ZQ_CONTROL, +		.ddr_wrlvl_cntl = CONFIG_SYS_DDR_WRLVL_CONTROL, +		.ddr_sr_cntr = CONFIG_SYS_DDR_SR_CNTR, +		.ddr_sdram_rcw_1 = CONFIG_SYS_DDR_RCW_1, +		.ddr_sdram_rcw_2 = CONFIG_SYS_DDR_RCW_2 +	}; + +	get_sys_info(&sysinfo); +	printf("Configuring DDR for %s MT/s data rate\n", +			strmhz(buf, sysinfo.freq_ddrbus)); + +	ddr_size = CONFIG_SYS_SDRAM_SIZE * 1024 * 1024; + +	fsl_ddr_set_memctl_regs(&ddr_cfg_regs, 0, 0); + +	if (set_ddr_laws(CONFIG_SYS_DDR_SDRAM_BASE, +				ddr_size, LAW_TRGT_IF_DDR_1) < 0) { +		printf("ERROR setting Local Access Windows for DDR\n"); +		return 0; +	}; + +	return ddr_size; +} diff --git a/board/freescale/p1_twr/law.c b/board/freescale/p1_twr/law.c new file mode 100644 index 000000000..e79d8a4c1 --- /dev/null +++ b/board/freescale/p1_twr/law.c @@ -0,0 +1,16 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:     GPL-2.0+ + */ + +#include <common.h> +#include <asm/fsl_law.h> +#include <asm/mmu.h> + +struct law_entry law_table[] = { +	SET_LAW(CONFIG_SYS_FLASH_BASE_PHYS, LAW_SIZE_64M, LAW_TRGT_IF_LBC), +	SET_LAW(CONFIG_SYS_SSD_BASE_PHYS, LAW_SIZE_1M, LAW_TRGT_IF_LBC) +}; + +int num_law_entries = ARRAY_SIZE(law_table); diff --git a/board/freescale/p1_twr/p1_twr.c b/board/freescale/p1_twr/p1_twr.c new file mode 100644 index 000000000..ea8db6fc0 --- /dev/null +++ b/board/freescale/p1_twr/p1_twr.c @@ -0,0 +1,281 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <command.h> +#include <hwconfig.h> +#include <pci.h> +#include <i2c.h> +#include <asm/processor.h> +#include <asm/mmu.h> +#include <asm/cache.h> +#include <asm/immap_85xx.h> +#include <asm/fsl_pci.h> +#include <asm/fsl_ddr_sdram.h> +#include <asm/io.h> +#include <asm/fsl_law.h> +#include <asm/fsl_lbc.h> +#include <asm/mp.h> +#include <miiphy.h> +#include <libfdt.h> +#include <fdt_support.h> +#include <fsl_mdio.h> +#include <tsec.h> +#include <ioports.h> +#include <asm/fsl_serdes.h> +#include <netdev.h> + +#define SYSCLK_64	64000000 +#define SYSCLK_66	66666666 + +unsigned long get_board_sys_clk(ulong dummy) +{ +	ccsr_gur_t *gur = (void __iomem *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); +	par_io_t *par_io = (par_io_t *) &(gur->qe_par_io); +	unsigned int cpdat_val = 0; + +	/* Set-up up pin muxing based on board switch settings */ +	cpdat_val = par_io[1].cpdat; + +	/* Check switch setting for SYSCLK select (PB3)  */ +	if (cpdat_val & 0x10000000) +		return SYSCLK_64; +	else +		return SYSCLK_66; + +	return 0; +} + +#ifdef CONFIG_QE + +#define PCA_IOPORT_I2C_ADDR		0x23 +#define PCA_IOPORT_OUTPUT_CMD		0x2 +#define PCA_IOPORT_CFG_CMD		0x6 + +const qe_iop_conf_t qe_iop_conf_tab[] = { + +#ifdef CONFIG_TWR_P1025 +	/* GPIO */ +	{1,  0, 1, 0, 0}, +	{1,  18, 1, 0, 0}, + +	/* GPIO for switch options */ +	{1,  2, 2, 0, 0}, /* PROFIBUS_MODE_SEL */ +	{1,  3, 2, 0, 0}, /* SYS_CLK_SELECT */ +	{1,  29, 2, 0, 0}, /* LOCALBUS_QE_MUXSEL */ +	{1,  30, 2, 0, 0}, /* ETH_TDM_SEL */ + +	/* QE_MUX_MDC */ +	{1,  19, 1, 0, 1}, /* QE_MUX_MDC */ + +	/* QE_MUX_MDIO */ +	{1,  20, 3, 0, 1}, /* QE_MUX_MDIO */ + +	/* UCC_1_MII */ +	{0, 23, 2, 0, 2}, /* CLK12 */ +	{0, 24, 2, 0, 1}, /* CLK9 */ +	{0,  7, 1, 0, 2}, /* ENET1_TXD0_SER1_TXD0 */ +	{0,  9, 1, 0, 2}, /* ENET1_TXD1_SER1_TXD1 */ +	{0, 11, 1, 0, 2}, /* ENET1_TXD2_SER1_TXD2 */ +	{0, 12, 1, 0, 2}, /* ENET1_TXD3_SER1_TXD3 */ +	{0,  6, 2, 0, 2}, /* ENET1_RXD0_SER1_RXD0 */ +	{0, 10, 2, 0, 2}, /* ENET1_RXD1_SER1_RXD1 */ +	{0, 14, 2, 0, 2}, /* ENET1_RXD2_SER1_RXD2 */ +	{0, 15, 2, 0, 2}, /* ENET1_RXD3_SER1_RXD3 */ +	{0,  5, 1, 0, 2}, /* ENET1_TX_EN_SER1_RTS_B */ +	{0, 13, 1, 0, 2}, /* ENET1_TX_ER */ +	{0,  4, 2, 0, 2}, /* ENET1_RX_DV_SER1_CTS_B */ +	{0,  8, 2, 0, 2}, /* ENET1_RX_ER_SER1_CD_B */ +	{0, 17, 2, 0, 2}, /* ENET1_CRS */ +	{0, 16, 2, 0, 2}, /* ENET1_COL */ + +	/* UCC_5_RMII */ +	{1, 11, 2, 0, 1}, /* CLK13 */ +	{1, 7,  1, 0, 2}, /* ENET5_TXD0_SER5_TXD0 */ +	{1, 10, 1, 0, 2}, /* ENET5_TXD1_SER5_TXD1 */ +	{1, 6, 2, 0, 2}, /* ENET5_RXD0_SER5_RXD0 */ +	{1, 9, 2, 0, 2}, /* ENET5_RXD1_SER5_RXD1 */ +	{1, 5, 1, 0, 2}, /* ENET5_TX_EN_SER5_RTS_B */ +	{1, 4, 2, 0, 2}, /* ENET5_RX_DV_SER5_CTS_B */ +	{1, 8, 2, 0, 2}, /* ENET5_RX_ER_SER5_CD_B */ + +	/* TDMA - clock option is configured in OS based on board setting */ +	{1, 23, 2, 0, 2}, /* TDMA_TXD */ +	{1, 25, 2, 0, 2}, /* TDMA_RXD */ +	{1, 26, 1, 0, 2}, /* TDMA_SYNC */ +#endif + +	{0,  0, 0, 0, QE_IOP_TAB_END} /* END of table */ +}; +#endif + +int board_early_init_f(void) +{ +	ccsr_gur_t *gur = (void __iomem *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); + +	setbits_be32(&gur->pmuxcr, +			(MPC85xx_PMUXCR_SDHC_CD | MPC85xx_PMUXCR_SDHC_WP)); + +	/* SDHC_DAT[4:7] not exposed to pins (use as SPI) */ +	clrbits_be32(&gur->pmuxcr, MPC85xx_PMUXCR_SD_DATA); + +	return 0; +} + +int checkboard(void) +{ +	ccsr_gur_t *gur = (void __iomem *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); +	u8 boot_status; + +	printf("Board: %s\n", CONFIG_BOARDNAME); + +	boot_status = ((gur->porbmsr) >> MPC85xx_PORBMSR_ROMLOC_SHIFT) & 0xf; +	puts("rom_loc: "); +	if (boot_status == PORBMSR_ROMLOC_NOR) +		puts("nor flash"); +	else if (boot_status == PORBMSR_ROMLOC_SDHC) +		puts("sd"); +	else +		puts("unknown"); +	puts("\n"); + +	return 0; +} + +#ifdef CONFIG_PCI +void pci_init_board(void) +{ +	fsl_pcie_init_board(0); +} +#endif + +int board_early_init_r(void) +{ +	const unsigned int flashbase = CONFIG_SYS_FLASH_BASE; +	const u8 flash_esel = find_tlb_idx((void *)flashbase, 1); + +	/* +	 * Remap Boot flash region to caching-inhibited +	 * so that flash can be erased properly. +	 */ + +	/* Flush d-cache and invalidate i-cache of any FLASH data */ +	flush_dcache(); +	invalidate_icache(); + +	/* invalidate existing TLB entry for flash */ +	disable_tlb(flash_esel); + +	set_tlb(1, flashbase, CONFIG_SYS_FLASH_BASE_PHYS, /* tlb, epn, rpn */ +		MAS3_SW|MAS3_SR, MAS2_I|MAS2_G,           /* perms, wimge */ +		0, flash_esel, BOOKE_PAGESZ_64M, 1);/* ts, esel, tsize, iprot */ +	return 0; +} + +int board_eth_init(bd_t *bis) +{ +	struct fsl_pq_mdio_info mdio_info; +	struct tsec_info_struct tsec_info[4]; +	ccsr_gur_t *gur __attribute__((unused)) = +		(void __iomem *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); +	int num = 0; + +#ifdef CONFIG_TSEC1 +	SET_STD_TSEC_INFO(tsec_info[num], 1); +	num++; +#endif +#ifdef CONFIG_TSEC2 +	SET_STD_TSEC_INFO(tsec_info[num], 2); +	if (is_serdes_configured(SGMII_TSEC2)) { +		printf("eTSEC2 is in sgmii mode.\n"); +		tsec_info[num].flags |= TSEC_SGMII; +	} +	num++; +#endif +#ifdef CONFIG_TSEC3 +	SET_STD_TSEC_INFO(tsec_info[num], 3); +	num++; +#endif + +	if (!num) { +		printf("No TSECs initialized\n"); +		return 0; +	} + +	mdio_info.regs = (struct tsec_mii_mng *)CONFIG_SYS_MDIO_BASE_ADDR; +	mdio_info.name = DEFAULT_MII_NAME; + +	fsl_pq_mdio_init(bis, &mdio_info); + +	tsec_eth_init(bis, tsec_info, num); + +#if defined(CONFIG_UEC_ETH) +	/* QE0 and QE3 need to be exposed for UCC1 +	 * and UCC5 Eth mode (in PMUXCR register). +	 * Currently QE/LBC muxed pins assumed to be +	 * LBC for U-Boot and PMUXCR updated by OS if required */ + +	uec_standard_init(bis); +#endif + +	return pci_eth_init(bis); +} + +#if defined(CONFIG_QE) +static void fdt_board_fixup_qe_pins(void *blob) +{ +	int node; + +	if (!hwconfig("qe")) { +		/* For QE and eLBC pins multiplexing, +		 * When don't use QE function, remove +		 * qe node from dt blob. +		 */ +		node = fdt_path_offset(blob, "/qe"); +		if (node >= 0) +			fdt_del_node(blob, node); +	} else { +		/* For TWR Peripheral Modules - TWR-SER2 +		 * board only can support Signal Port MII, +		 * so delete one UEC node when use MII port. +		 */ +		if (hwconfig("mii")) +			node = fdt_path_offset(blob, "/qe/ucc@2400"); +		else +			node = fdt_path_offset(blob, "/qe/ucc@2000"); +		if (node >= 0) +			fdt_del_node(blob, node); +	} + +	return; +} +#endif + +#ifdef CONFIG_OF_BOARD_SETUP +void ft_board_setup(void *blob, bd_t *bd) +{ +	phys_addr_t base; +	phys_size_t size; + +	ft_cpu_setup(blob, bd); + +	base = getenv_bootm_low(); +	size = getenv_bootm_size(); + +	fdt_fixup_memory(blob, (u64)base, (u64)size); + +	FT_FSL_PCI_SETUP; + +#ifdef CONFIG_QE +	do_fixup_by_compat(blob, "fsl,qe", "status", "okay", +			sizeof("okay"), 0); +#endif +#if defined(CONFIG_TWR_P1025) +	fdt_board_fixup_qe_pins(blob); +#endif +	fdt_fixup_dr_usb(blob, bd); +} +#endif diff --git a/board/freescale/p1_twr/tlb.c b/board/freescale/p1_twr/tlb.c new file mode 100644 index 000000000..308335c97 --- /dev/null +++ b/board/freescale/p1_twr/tlb.c @@ -0,0 +1,76 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <asm/mmu.h> + +struct fsl_e_tlb_entry tlb_table[] = { +	/* TLB 0 - for temp stack in cache */ +	SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR, +			CONFIG_SYS_INIT_RAM_ADDR_PHYS, +			MAS3_SX|MAS3_SW|MAS3_SR, 0, +			0, 0, BOOKE_PAGESZ_4K, 0), +	SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR + 4 * 1024 , +			CONFIG_SYS_INIT_RAM_ADDR_PHYS + 4 * 1024, +			MAS3_SX|MAS3_SW|MAS3_SR, 0, +			0, 0, BOOKE_PAGESZ_4K, 0), +	SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR + 8 * 1024 , +			CONFIG_SYS_INIT_RAM_ADDR_PHYS + 8 * 1024, +			MAS3_SX|MAS3_SW|MAS3_SR, 0, +			0, 0, BOOKE_PAGESZ_4K, 0), +	SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR + 12 * 1024 , +			CONFIG_SYS_INIT_RAM_ADDR_PHYS + 12 * 1024, +			MAS3_SX|MAS3_SW|MAS3_SR, 0, +			0, 0, BOOKE_PAGESZ_4K, 0), + +	/* TLB 1 */ +	/* *I*** - Covers boot page */ +	SET_TLB_ENTRY(1, 0xfffff000, 0xfffff000, +			MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I, +			0, 0, BOOKE_PAGESZ_4K, 1), + +	/* *I*G* - CCSRBAR */ +	SET_TLB_ENTRY(1, CONFIG_SYS_CCSRBAR, CONFIG_SYS_CCSRBAR_PHYS, +			MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +			0, 1, BOOKE_PAGESZ_1M, 1), + +#ifndef CONFIG_SPL_BUILD +	/* W**G* - Flash, localbus */ +	/* This will be changed to *I*G* after relocation to RAM. */ +	SET_TLB_ENTRY(1, CONFIG_SYS_FLASH_BASE, CONFIG_SYS_FLASH_BASE_PHYS, +			MAS3_SX|MAS3_SR, MAS2_W|MAS2_G, +			0, 2, BOOKE_PAGESZ_64M, 1), + +	/* W**G* - Flash, localbus */ +	/* This will be changed to *I*G* after relocation to RAM. */ +	SET_TLB_ENTRY(1, CONFIG_SYS_SSD_BASE, CONFIG_SYS_SSD_BASE_PHYS, +			MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +			0, 5, BOOKE_PAGESZ_1M, 1), + +#ifdef CONFIG_PCI +	/* *I*G* - PCI memory 1.5G */ +	SET_TLB_ENTRY(1, CONFIG_SYS_PCIE1_MEM_VIRT, CONFIG_SYS_PCIE1_MEM_PHYS, +			MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +			0, 3, BOOKE_PAGESZ_1G, 1), + +	/* *I*G* - PCI I/O effective: 192K  */ +	SET_TLB_ENTRY(1, CONFIG_SYS_PCIE1_IO_VIRT, CONFIG_SYS_PCIE1_IO_PHYS, +			MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +			0, 4, BOOKE_PAGESZ_256K, 1), +#endif + +#endif + +#ifdef CONFIG_SYS_RAMBOOT +	/* *I*G - eSDHC boot */ +	SET_TLB_ENTRY(1, CONFIG_SYS_DDR_SDRAM_BASE, CONFIG_SYS_DDR_SDRAM_BASE, +			MAS3_SX|MAS3_SW|MAS3_SR, 0, +			0, 8, BOOKE_PAGESZ_1G, 1), +#endif + +}; + +int num_tlb_entries = ARRAY_SIZE(tlb_table); diff --git a/board/freescale/p2041rdb/p2041rdb.c b/board/freescale/p2041rdb/p2041rdb.c index 08d10bc9c..60694a672 100644 --- a/board/freescale/p2041rdb/p2041rdb.c +++ b/board/freescale/p2041rdb/p2041rdb.c @@ -28,7 +28,6 @@ int checkboard(void)  {  	u8 sw;  	struct cpu_type *cpu = gd->arch.cpu; -	ccsr_gur_t *gur = (void *)CONFIG_SYS_MPC85xx_GUTS_ADDR;  	unsigned int i;  	printf("Board: %sRDB, ", cpu->name); @@ -39,20 +38,6 @@ int checkboard(void)  	printf("vBank: %d\n", sw & 0x1);  	/* -	 * Display the RCW, so that no one gets confused as to what RCW -	 * we're actually using for this boot. -	 */ -	puts("Reset Configuration Word (RCW):"); -	for (i = 0; i < ARRAY_SIZE(gur->rcwsr); i++) { -		u32 rcw = in_be32(&gur->rcwsr[i]); - -		if ((i % 4) == 0) -			printf("\n       %08x:", i * 4); -		printf(" %08x", rcw); -	} -	puts("\n"); - -	/*  	 * Display the actual SERDES reference clocks as configured by the  	 * dip switches on the board.  Note that the SWx registers could  	 * technically be set to force the reference clocks to match the diff --git a/board/freescale/t4qds/Makefile b/board/freescale/t4qds/Makefile index 85df06690..a2167b377 100644 --- a/board/freescale/t4qds/Makefile +++ b/board/freescale/t4qds/Makefile @@ -8,7 +8,8 @@ include $(TOPDIR)/config.mk  LIB	= $(obj)lib$(BOARD).o -COBJS-y	+= $(BOARD).o +COBJS-$(CONFIG_T4240QDS) += t4240qds.o +COBJS-$(CONFIG_T4240EMU) += t4240emu.o  COBJS-y	+= ddr.o  COBJS-$(CONFIG_T4240QDS)+= eth.o  COBJS-$(CONFIG_PCI)	+= pci.o diff --git a/board/freescale/t4qds/ddr.c b/board/freescale/t4qds/ddr.c index 058d62511..26ac2a54d 100644 --- a/board/freescale/t4qds/ddr.c +++ b/board/freescale/t4qds/ddr.c @@ -13,81 +13,10 @@  #include <asm/fsl_ddr_sdram.h>  #include <asm/fsl_ddr_dimm_params.h>  #include <asm/fsl_law.h> +#include "ddr.h"  DECLARE_GLOBAL_DATA_PTR; -struct board_specific_parameters { -	u32 n_ranks; -	u32 datarate_mhz_high; -	u32 rank_gb; -	u32 clk_adjust; -	u32 wrlvl_start; -	u32 wrlvl_ctl_2; -	u32 wrlvl_ctl_3; -	u32 cpo; -	u32 write_data_delay; -	u32 force_2T; -}; - -/* - * This table contains all valid speeds we want to override with board - * specific parameters. datarate_mhz_high values need to be in ascending order - * for each n_ranks group. - */ -static const struct board_specific_parameters udimm0[] = { -	/* -	 * memory controller 0 -	 *   num|  hi| rank|  clk| wrlvl |   wrlvl   |  wrlvl | cpo  |wrdata|2T -	 * ranks| mhz| GB  |adjst| start |   ctl2    |  ctl3  |      |delay | -	 */ -	{2,  1350, 4, 4,     8, 0x0809090b, 0x0c0c0d0a,   0xff,    2,  0}, -	{2,  1350, 0, 5,     7, 0x0709090b, 0x0c0c0d09,   0xff,    2,  0}, -	{2,  1666, 4, 4,     8, 0x080a0a0d, 0x0d10100b,   0xff,    2,  0}, -	{2,  1666, 0, 5,     7, 0x080a0a0c, 0x0d0d0e0a,   0xff,    2,  0}, -	{2,  1900, 0, 4,     8, 0x090a0b0e, 0x0f11120c,   0xff,    2,  0}, -	{2,  2140, 0, 4,     8, 0x090a0b0e, 0x0f11120c,   0xff,    2,  0}, -	{1,  1350, 0, 5,     8, 0x0809090b, 0x0c0c0d0a,   0xff,    2,  0}, -	{1,  1700, 0, 5,     8, 0x080a0a0c, 0x0c0d0e0a,   0xff,    2,  0}, -	{1,  1900, 0, 4,     8, 0x080a0a0c, 0x0e0e0f0a,   0xff,    2,  0}, -	{1,  2140, 0, 4,     8, 0x090a0b0c, 0x0e0f100b,   0xff,    2,  0}, -	{} -}; - -/* - * The three slots have slightly different timing. The center values are good - * for all slots. We use identical speed tables for them. In future use, if - * DIMMs require separated tables, make more entries as needed. - */ -static const struct board_specific_parameters *udimms[] = { -	udimm0, -}; - -static const struct board_specific_parameters rdimm0[] = { -	/* -	 * memory controller 0 -	 *   num|  hi| rank|  clk| wrlvl |   wrlvl   |  wrlvl | cpo  |wrdata|2T -	 * ranks| mhz| GB  |adjst| start |   ctl2    |  ctl3  |      |delay | -	 */ -	{4,  1350, 0, 5,     9, 0x08070605, 0x07080805,   0xff,    2,  0}, -	{4,  1666, 0, 5,     8, 0x08070605, 0x07080805,   0xff,    2,  0}, -	{4,  2140, 0, 5,     8, 0x08070605, 0x07081805,   0xff,    2,  0}, -	{2,  1350, 0, 5,     7, 0x0809090b, 0x0c0c0d09,   0xff,    2,  0}, -	{2,  1666, 0, 5,     8, 0x080a0a0c, 0x0c0d0e0a,   0xff,    2,  0}, -	{2,  2140, 0, 5,     8, 0x090a0b0c, 0x0e0f100b,   0xff,    2,  0}, -	{1,  1350, 0, 5,     8, 0x0809090b, 0x0c0c0d0a,   0xff,    2,  0}, -	{1,  1700, 0, 5,     8, 0x080a0a0c, 0x0c0d0e0a,   0xff,    2,  0}, -	{1,  1900, 0, 4,     8, 0x080a0a0c, 0x0e0e0f0a,   0xff,    2,  0}, -	{1,  2140, 0, 4,     8, 0x090a0b0c, 0x0e0f100b,   0xff,    2,  0}, -	{} -}; - -/* - * The three slots have slightly different timing. See comments above. - */ -static const struct board_specific_parameters *rdimms[] = { -	rdimm0, -}; -  void fsl_ddr_board_options(memctl_options_t *popts,  				dimm_params_t *pdimm,  				unsigned int ctrl_num) diff --git a/board/freescale/t4qds/ddr.h b/board/freescale/t4qds/ddr.h new file mode 100644 index 000000000..d0a0951af --- /dev/null +++ b/board/freescale/t4qds/ddr.h @@ -0,0 +1,108 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef __DDR_H__ +#define __DDR_H__ +struct board_specific_parameters { +	u32 n_ranks; +	u32 datarate_mhz_high; +	u32 rank_gb; +	u32 clk_adjust; +	u32 wrlvl_start; +	u32 wrlvl_ctl_2; +	u32 wrlvl_ctl_3; +	u32 cpo; +	u32 write_data_delay; +	u32 force_2T; +}; + +/* + * These tables contain all valid speeds we want to override with board + * specific parameters. datarate_mhz_high values need to be in ascending order + * for each n_ranks group. + */ + +#ifdef CONFIG_T4240QDS +static const struct board_specific_parameters udimm0[] = { +	/* +	 * memory controller 0 +	 *   num|  hi| rank|  clk| wrlvl |   wrlvl   |  wrlvl | cpo  |wrdata|2T +	 * ranks| mhz| GB  |adjst| start |   ctl2    |  ctl3  |      |delay | +	 */ +	{2,  1350, 4, 4,     8, 0x0809090b, 0x0c0c0d0a,   0xff,    2,  0}, +	{2,  1350, 0, 5,     7, 0x0709090b, 0x0c0c0d09,   0xff,    2,  0}, +	{2,  1666, 4, 4,     8, 0x080a0a0d, 0x0d10100b,   0xff,    2,  0}, +	{2,  1666, 0, 5,     7, 0x080a0a0c, 0x0d0d0e0a,   0xff,    2,  0}, +	{2,  1900, 0, 4,     8, 0x090a0b0e, 0x0f11120c,   0xff,    2,  0}, +	{2,  2140, 0, 4,     8, 0x090a0b0e, 0x0f11120c,   0xff,    2,  0}, +	{1,  1350, 0, 5,     8, 0x0809090b, 0x0c0c0d0a,   0xff,    2,  0}, +	{1,  1700, 0, 5,     8, 0x080a0a0c, 0x0c0d0e0a,   0xff,    2,  0}, +	{1,  1900, 0, 4,     8, 0x080a0a0c, 0x0e0e0f0a,   0xff,    2,  0}, +	{1,  2140, 0, 4,     8, 0x090a0b0c, 0x0e0f100b,   0xff,    2,  0}, +	{} +}; + +static const struct board_specific_parameters rdimm0[] = { +	/* +	 * memory controller 0 +	 *   num|  hi| rank|  clk| wrlvl |   wrlvl   |  wrlvl | cpo  |wrdata|2T +	 * ranks| mhz| GB  |adjst| start |   ctl2    |  ctl3  |      |delay | +	 */ +	{4,  1350, 0, 5,     9, 0x08070605, 0x06070806,   0xff,    2,  0}, +	{4,  1666, 0, 5,    11, 0x0a080706, 0x07090906,   0xff,    2,  0}, +	{4,  2140, 0, 5,    12, 0x0b090807, 0x080a0b07,   0xff,    2,  0}, +	{2,  1350, 0, 5,     9, 0x08070605, 0x06070806,   0xff,    2,  0}, +	{2,  1666, 0, 5,    11, 0x0a090806, 0x08090a06,   0xff,    2,  0}, +	{2,  2140, 0, 5,    12, 0x0b090807, 0x080a0b07,   0xff,    2,  0}, +	{1,  1350, 0, 5,     9, 0x08070605, 0x06070806,   0xff,    2,  0}, +	{1,  1666, 0, 5,    11, 0x0a090806, 0x08090a06,   0xff,    2,  0}, +	{1,  2140, 0, 4,    12, 0x0b090807, 0x080a0b07,   0xff,    2,  0}, +	{} +}; + +#else	/* CONFIG_T4240EMU */ +static const struct board_specific_parameters udimm0[] = { +	/* +	 * memory controller 0 +	 *   num|  hi| rank|  clk| wrlvl |   wrlvl   |  wrlvl | cpo  |wrdata|2T +	 * ranks| mhz| GB  |adjst| start |   ctl2    |  ctl3  |      |delay | +	 */ +	{2,  2140, 0, 4,     8, 0x0, 0x0,   0xff,    2,  0}, +	{1,  2140, 0, 4,     8, 0x0, 0x0,   0xff,    2,  0}, +	{} +}; + +static const struct board_specific_parameters rdimm0[] = { +	/* +	 * memory controller 0 +	 *   num|  hi| rank|  clk| wrlvl |   wrlvl   |  wrlvl | cpo  |wrdata|2T +	 * ranks| mhz| GB  |adjst| start |   ctl2    |  ctl3  |      |delay | +	 */ +	{4,  2140, 0, 5,     8, 0x0, 0x0,   0xff,    2,  0}, +	{2,  2140, 0, 5,     8, 0x0, 0x0,   0xff,    2,  0}, +	{1,  2140, 0, 4,     8, 0x0, 0x0,   0xff,    2,  0}, +	{} +}; +#endif	/* CONFIG_T4240EMU */ + +/* + * The three slots have slightly different timing. The center values are good + * for all slots. We use identical speed tables for them. In future use, if + * DIMMs require separated tables, make more entries as needed. + */ +static const struct board_specific_parameters *udimms[] = { +	udimm0, +}; + +/* + * The three slots have slightly different timing. See comments above. + */ +static const struct board_specific_parameters *rdimms[] = { +	rdimm0, +}; + + +#endif diff --git a/board/freescale/t4qds/eth.c b/board/freescale/t4qds/eth.c index c771e1795..b5f488bcb 100644 --- a/board/freescale/t4qds/eth.c +++ b/board/freescale/t4qds/eth.c @@ -172,7 +172,10 @@ static int t4240qds_mdio_init(char *realbusname, u8 muxval)  void board_ft_fman_fixup_port(void *blob, char * prop, phys_addr_t pa,  				enum fm_port port, int offset)  { -	if (fm_info_get_enet_if(port) == PHY_INTERFACE_MODE_SGMII) { +	int interface = fm_info_get_enet_if(port); + +	if (interface == PHY_INTERFACE_MODE_SGMII || +	    interface == PHY_INTERFACE_MODE_QSGMII) {  		switch (port) {  		case FM1_DTSEC1:  			if (qsgmiiphy_fix[port]) @@ -272,6 +275,7 @@ void fdt_fixup_board_enet(void *fdt)  	for (i = FM1_DTSEC1; i < NUM_FM_PORTS; i++) {  		switch (fm_info_get_enet_if(i)) {  		case PHY_INTERFACE_MODE_SGMII: +		case PHY_INTERFACE_MODE_QSGMII:  			switch (mdio_mux[i]) {  			case EMI1_SLOT1:  				fdt_status_okay_by_alias(fdt, "emi1_slot1"); @@ -393,7 +397,7 @@ static void initialize_qsgmiiphy_fix(void)  int board_eth_init(bd_t *bis)  {  #if defined(CONFIG_FMAN_ENET) -	int i, idx, lane, slot; +	int i, idx, lane, slot, interface;  	struct memac_mdio_info dtsec_mdio_info;  	struct memac_mdio_info tgec_mdio_info;  	ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); @@ -470,9 +474,9 @@ int board_eth_init(bd_t *bis)  		fm_info_set_phy_address(FM1_DTSEC6, slot_qsgmii_phyaddr[1][1]);  		if ((srds_prtcl_s2 != 56) && (srds_prtcl_s2 != 57)) {  			fm_info_set_phy_address(FM1_DTSEC9, -						slot_qsgmii_phyaddr[1][3]); -			fm_info_set_phy_address(FM1_DTSEC10,  						slot_qsgmii_phyaddr[1][2]); +			fm_info_set_phy_address(FM1_DTSEC10, +						slot_qsgmii_phyaddr[1][3]);  		}  		break;  	case 40: @@ -482,9 +486,9 @@ int board_eth_init(bd_t *bis)  		fm_info_set_phy_address(FM1_DTSEC6, slot_qsgmii_phyaddr[1][1]);  		if ((srds_prtcl_s2 != 56) && (srds_prtcl_s2 != 57)) {  			fm_info_set_phy_address(FM1_DTSEC10, -						slot_qsgmii_phyaddr[1][3]); -			fm_info_set_phy_address(FM1_DTSEC9,  						slot_qsgmii_phyaddr[1][2]); +			fm_info_set_phy_address(FM1_DTSEC9, +						slot_qsgmii_phyaddr[1][3]);  		}  		fm_info_set_phy_address(FM1_DTSEC1, slot_qsgmii_phyaddr[2][0]);  		fm_info_set_phy_address(FM1_DTSEC2, slot_qsgmii_phyaddr[2][1]); @@ -498,15 +502,31 @@ int board_eth_init(bd_t *bis)  	for (i = FM1_DTSEC1; i < FM1_DTSEC1 + CONFIG_SYS_NUM_FM1_DTSEC; i++) {  		idx = i - FM1_DTSEC1; -		switch (fm_info_get_enet_if(i)) { +		interface = fm_info_get_enet_if(i); +		switch (interface) {  		case PHY_INTERFACE_MODE_SGMII: -			lane = serdes_get_first_lane(FSL_SRDS_1, +		case PHY_INTERFACE_MODE_QSGMII: +			if (interface == PHY_INTERFACE_MODE_QSGMII) { +				if (idx <= 3) +					lane = serdes_get_first_lane(FSL_SRDS_1, +							QSGMII_FM1_A); +				else +					lane = serdes_get_first_lane(FSL_SRDS_1, +							QSGMII_FM1_B); +				if (lane < 0) +					break; +				slot = lane_to_slot_fsm1[lane]; +				debug("FM1@DTSEC%u expects QSGMII in slot %u\n", +				      idx + 1, slot); +			} else { +				lane = serdes_get_first_lane(FSL_SRDS_1,  						SGMII_FM1_DTSEC1 + idx); -			if (lane < 0) -				break; -			slot = lane_to_slot_fsm1[lane]; -			debug("FM1@DTSEC%u expects SGMII in slot %u\n", -				idx + 1, slot); +				if (lane < 0) +					break; +				slot = lane_to_slot_fsm1[lane]; +				debug("FM1@DTSEC%u expects SGMII in slot %u\n", +				      idx + 1, slot); +			}  			if (QIXIS_READ(present2) & (1 << (slot - 1)))  				fm_disable_port(i);  			switch (slot) { @@ -600,8 +620,8 @@ int board_eth_init(bd_t *bis)  		fm_info_set_phy_address(FM2_DTSEC4, slot_qsgmii_phyaddr[4][3]);  		fm_info_set_phy_address(FM2_DTSEC5, slot_qsgmii_phyaddr[3][0]);  		fm_info_set_phy_address(FM2_DTSEC6, slot_qsgmii_phyaddr[3][1]); -		fm_info_set_phy_address(FM2_DTSEC9, slot_qsgmii_phyaddr[3][3]); -		fm_info_set_phy_address(FM2_DTSEC10, slot_qsgmii_phyaddr[3][2]); +		fm_info_set_phy_address(FM2_DTSEC9, slot_qsgmii_phyaddr[3][2]); +		fm_info_set_phy_address(FM2_DTSEC10, slot_qsgmii_phyaddr[3][3]);  		break;  	case 40:  	case 46: @@ -641,15 +661,31 @@ int board_eth_init(bd_t *bis)  	for (i = FM2_DTSEC1; i < FM2_DTSEC1 + CONFIG_SYS_NUM_FM2_DTSEC; i++) {  		idx = i - FM2_DTSEC1; -		switch (fm_info_get_enet_if(i)) { +		interface = fm_info_get_enet_if(i); +		switch (interface) {  		case PHY_INTERFACE_MODE_SGMII: -			lane = serdes_get_first_lane(FSL_SRDS_2, +		case PHY_INTERFACE_MODE_QSGMII: +			if (interface == PHY_INTERFACE_MODE_QSGMII) { +				if (idx <= 3) +					lane = serdes_get_first_lane(FSL_SRDS_2, +							QSGMII_FM2_A); +				else +					lane = serdes_get_first_lane(FSL_SRDS_2, +							QSGMII_FM2_B); +				if (lane < 0) +					break; +				slot = lane_to_slot_fsm2[lane]; +				debug("FM2@DTSEC%u expects QSGMII in slot %u\n", +				      idx + 1, slot); +			} else { +				lane = serdes_get_first_lane(FSL_SRDS_2,  						SGMII_FM2_DTSEC1 + idx); -			if (lane < 0) -				break; -			slot = lane_to_slot_fsm2[lane]; -			debug("FM2@DTSEC%u expects SGMII in slot %u\n", -				idx + 1, slot); +				if (lane < 0) +					break; +				slot = lane_to_slot_fsm2[lane]; +				debug("FM2@DTSEC%u expects SGMII in slot %u\n", +				      idx + 1, slot); +			}  			if (QIXIS_READ(present2) & (1 << (slot - 1)))  				fm_disable_port(i);  			switch (slot) { diff --git a/board/freescale/t4qds/law.c b/board/freescale/t4qds/law.c index 63549df2a..367783bfe 100644 --- a/board/freescale/t4qds/law.c +++ b/board/freescale/t4qds/law.c @@ -19,7 +19,9 @@ struct law_entry law_table[] = {  #ifdef CONFIG_SYS_QMAN_MEM_PHYS  	SET_LAW(CONFIG_SYS_QMAN_MEM_PHYS, LAW_SIZE_32M, LAW_TRGT_IF_QMAN),  #endif +#ifdef QIXIS_BASE_PHYS  	SET_LAW(QIXIS_BASE_PHYS, LAW_SIZE_4K, LAW_TRGT_IF_IFC), +#endif  #ifdef CONFIG_SYS_DCSRBAR_PHYS  	/* Limit DCSR to 32M to access NPC Trace Buffer */  	SET_LAW(CONFIG_SYS_DCSRBAR_PHYS, LAW_SIZE_32M, LAW_TRGT_IF_DCSR), diff --git a/board/freescale/t4qds/t4240emu.c b/board/freescale/t4qds/t4240emu.c new file mode 100644 index 000000000..7a610367d --- /dev/null +++ b/board/freescale/t4qds/t4240emu.c @@ -0,0 +1,80 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <command.h> +#include <i2c.h> +#include <netdev.h> +#include <linux/compiler.h> +#include <asm/mmu.h> +#include <asm/processor.h> +#include <asm/cache.h> +#include <asm/immap_85xx.h> +#include <asm/fsl_law.h> +#include <asm/fsl_serdes.h> +#include <asm/fsl_portals.h> +#include <asm/fsl_liodn.h> + +DECLARE_GLOBAL_DATA_PTR; + +int checkboard(void) +{ +	struct cpu_type *cpu = gd->arch.cpu; + +	printf("Board: %sEMU\n", cpu->name); + +	return 0; +} + +int board_early_init_r(void) +{ +	const unsigned int flashbase = CONFIG_SYS_FLASH_BASE; +	const u8 flash_esel = find_tlb_idx((void *)flashbase, 1); + +	/* +	 * Remap Boot flash + PROMJET region to caching-inhibited +	 * so that flash can be erased properly. +	 */ + +	/* Flush d-cache and invalidate i-cache of any FLASH data */ +	flush_dcache(); +	invalidate_icache(); + +	/* invalidate existing TLB entry for flash */ +	disable_tlb(flash_esel); + +	set_tlb(1, flashbase, CONFIG_SYS_FLASH_BASE_PHYS, +		MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		0, flash_esel, BOOKE_PAGESZ_256M, 1); + +	set_liodns(); +#ifdef CONFIG_SYS_DPAA_QBMAN +	setup_portals(); +#endif + +	return 0; +} + +int misc_init_r(void) +{ +	return 0; +} + +void ft_board_setup(void *blob, bd_t *bd) +{ +	phys_addr_t base; +	phys_size_t size; + +	ft_cpu_setup(blob, bd); + +	base = getenv_bootm_low(); +	size = getenv_bootm_size(); + +	fdt_fixup_memory(blob, (u64)base, (u64)size); + +	fdt_fixup_liodn(blob); +	fdt_fixup_dr_usb(blob, bd); +} diff --git a/board/freescale/t4qds/t4qds.c b/board/freescale/t4qds/t4240qds.c index aa6a217f3..0c1a4fbd9 100644 --- a/board/freescale/t4qds/t4qds.c +++ b/board/freescale/t4qds/t4240qds.c @@ -26,16 +26,16 @@  DECLARE_GLOBAL_DATA_PTR; -static const int8_t vsc3316_fsm1_tx[8][2] = { {0, 0}, {1, 1}, {6, 6}, {7, 7}, +static int8_t vsc3316_fsm1_tx[8][2] = { {0, 0}, {1, 1}, {6, 6}, {7, 7},  				{8, 8}, {9, 9}, {14, 14}, {15, 15} }; -static const int8_t vsc3316_fsm2_tx[8][2] = { {2, 2}, {3, 3}, {4, 4}, {5, 5}, +static int8_t vsc3316_fsm2_tx[8][2] = { {2, 2}, {3, 3}, {4, 4}, {5, 5},  				{10, 10}, {11, 11}, {12, 12}, {13, 13} }; -static const int8_t vsc3316_fsm1_rx[8][2] = { {2, 12}, {3, 13}, {4, 5}, {5, 4}, +static int8_t vsc3316_fsm1_rx[8][2] = { {2, 12}, {3, 13}, {4, 5}, {5, 4},  				{10, 11}, {11, 10}, {12, 2}, {13, 3} }; -static const int8_t vsc3316_fsm2_rx[8][2] = { {0, 15}, {1, 14}, {6, 7}, {7, 6}, +static int8_t vsc3316_fsm2_rx[8][2] = { {0, 15}, {1, 14}, {6, 7}, {7, 6},  				{8, 9}, {9, 8}, {14, 1}, {15, 0} };  int checkboard(void) @@ -43,12 +43,11 @@ int checkboard(void)  	char buf[64];  	u8 sw;  	struct cpu_type *cpu = gd->arch.cpu; -	ccsr_gur_t *gur = (void *)CONFIG_SYS_MPC85xx_GUTS_ADDR;  	unsigned int i;  	printf("Board: %sQDS, ", cpu->name);  	printf("Sys ID: 0x%02x, Sys Ver: 0x%02x, ", -		QIXIS_READ(id), QIXIS_READ(arch)); +	       QIXIS_READ(id), QIXIS_READ(arch));  	sw = QIXIS_READ(brdcfg[0]);  	sw = (sw & QIXIS_LBMAP_MASK) >> QIXIS_LBMAP_SHIFT; @@ -63,24 +62,11 @@ int checkboard(void)  		printf("invalid setting of SW%u\n", QIXIS_LBMAP_SWITCH);  	printf("FPGA: v%d (%s), build %d", -		(int)QIXIS_READ(scver), qixis_read_tag(buf), -		(int)qixis_read_minor()); +	       (int)QIXIS_READ(scver), qixis_read_tag(buf), +	       (int)qixis_read_minor());  	/* the timestamp string contains "\n" at the end */  	printf(" on %s", qixis_read_time(buf)); -	/* Display the RCW, so that no one gets confused as to what RCW -	 * we're actually using for this boot. -	 */ -	puts("Reset Configuration Word (RCW):"); -	for (i = 0; i < ARRAY_SIZE(gur->rcwsr); i++) { -		u32 rcw = in_be32(&gur->rcwsr[i]); - -		if ((i % 4) == 0) -			printf("\n       %08x:", i * 4); -		printf(" %08x", rcw); -	} -	puts("\n"); -  	/*  	 * Display the actual SERDES reference clocks as configured by the  	 * dip switches on the board.  Note that the SWx registers could @@ -92,7 +78,7 @@ int checkboard(void)  	puts("SERDES Reference Clocks: ");  	sw = QIXIS_READ(brdcfg[2]);  	for (i = 0; i < MAX_SERDES; i++) { -		static const char *freq[] = { +		static const char * const freq[] = {  			"100", "125", "156.25", "161.1328125"};  		unsigned int clock = (sw >> (6 - 2 * i)) & 3; @@ -367,25 +353,60 @@ int config_frontside_crossbar_vsc3316(void)  	srds_prtcl_s1 = in_be32(&gur->rcwsr[4]) &  			FSL_CORENET2_RCWSR4_SRDS1_PRTCL;  	srds_prtcl_s1 >>= FSL_CORENET2_RCWSR4_SRDS1_PRTCL_SHIFT; -	if (srds_prtcl_s1) { +	switch (srds_prtcl_s1) { +	case 38: +		/* swap first lane and third lane on slot1 */ +		vsc3316_fsm1_tx[0][1] = 14; +		vsc3316_fsm1_tx[6][1] = 0; +		vsc3316_fsm1_rx[1][1] = 2; +		vsc3316_fsm1_rx[6][1] = 13; +	case 40: +	case 46: +	case 48: +		/* swap first lane and third lane on slot2 */ +		vsc3316_fsm1_tx[2][1] = 8; +		vsc3316_fsm1_tx[4][1] = 6; +		vsc3316_fsm1_rx[2][1] = 10; +		vsc3316_fsm1_rx[5][1] = 5; +	default:  		ret = vsc3316_config(VSC3316_FSM_TX_ADDR, vsc3316_fsm1_tx, 8);  		if (ret)  			return ret;  		ret = vsc3316_config(VSC3316_FSM_RX_ADDR, vsc3316_fsm1_rx, 8);  		if (ret)  			return ret; +		break;  	}  	srds_prtcl_s2 = in_be32(&gur->rcwsr[4]) &  				FSL_CORENET2_RCWSR4_SRDS2_PRTCL;  	srds_prtcl_s2 >>= FSL_CORENET2_RCWSR4_SRDS2_PRTCL_SHIFT; -	if (srds_prtcl_s2) { +	switch (srds_prtcl_s2) { +	case 38: +		/* swap first lane and third lane on slot3 */ +		vsc3316_fsm2_tx[2][1] = 11; +		vsc3316_fsm2_tx[5][1] = 4; +		vsc3316_fsm2_rx[2][1] = 9; +		vsc3316_fsm2_rx[4][1] = 7; +	case 40: +	case 46: +	case 48: +	case 50: +	case 52: +	case 54: +		/* swap first lane and third lane on slot4 */ +		vsc3316_fsm2_tx[6][1] = 3; +		vsc3316_fsm2_tx[1][1] = 12; +		vsc3316_fsm2_rx[0][1] = 1; +		vsc3316_fsm2_rx[6][1] = 15; +	default:  		ret = vsc3316_config(VSC3316_FSM_TX_ADDR, vsc3316_fsm2_tx, 8);  		if (ret)  			return ret;  		ret = vsc3316_config(VSC3316_FSM_RX_ADDR, vsc3316_fsm2_rx, 8);  		if (ret)  			return ret; +		break;  	}  	return 0; @@ -430,7 +451,7 @@ int config_backside_crossbar_mux(void)  		break;  	default:  		printf("WARNING: unsupported for SerDes3 Protocol %d\n", -				srds_prtcl_s3); +		       srds_prtcl_s3);  		return -1;  	} @@ -470,7 +491,7 @@ int config_backside_crossbar_mux(void)  		break;  	default:  		printf("WARNING: unsupported for SerDes4 Protocol %d\n", -				srds_prtcl_s4); +		       srds_prtcl_s4);  		return -1;  	} @@ -495,8 +516,8 @@ int board_early_init_r(void)  	disable_tlb(flash_esel);  	set_tlb(1, flashbase, CONFIG_SYS_FLASH_BASE_PHYS, -			MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, -			0, flash_esel, BOOKE_PAGESZ_256M, 1); +		MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		0, flash_esel, BOOKE_PAGESZ_256M, 1);  	set_liodns();  #ifdef CONFIG_SYS_DPAA_QBMAN @@ -634,9 +655,8 @@ int misc_init_r(void)  		u32 pllcr0 = srds_regs->bank[i].pllcr0;  		u32 expected = pllcr0 & SRDS_PLLCR0_RFCK_SEL_MASK;  		if (expected != actual[i]) { -			printf("Warning: SERDES%u expects reference clock" -			       " %sMHz, but actual is %sMHz\n", i + 1, -			       serdes_clock_to_string(expected), +			printf("Warning: SERDES%u expects reference clock %sMHz, but actual is %sMHz\n", +			       i + 1, serdes_clock_to_string(expected),  			       serdes_clock_to_string(actual[i]));  		}  	} @@ -795,42 +815,44 @@ void qixis_dump_switch(void)  	}  	sw[0] = dutcfg[0]; -	sw[1] = (dutcfg[1] << 0x07)		| \ -		((dutcfg[12] & 0xC0) >> 1)	| \ -		((dutcfg[11] & 0xE0) >> 3)	| \ -		((dutcfg[6] & 0x80) >> 6)	| \ +	sw[1] = (dutcfg[1] << 0x07)		| +		((dutcfg[12] & 0xC0) >> 1)	| +		((dutcfg[11] & 0xE0) >> 3)	| +		((dutcfg[6] & 0x80) >> 6)	|  		((dutcfg[1] & 0x80) >> 7); -	sw[2] = ((brdcfg[1] & 0x0f) << 4)	| \ -		((brdcfg[1] & 0x30) >> 2)	| \ -		((brdcfg[1] & 0x40) >> 5)	| \ +	sw[2] = ((brdcfg[1] & 0x0f) << 4)	| +		((brdcfg[1] & 0x30) >> 2)	| +		((brdcfg[1] & 0x40) >> 5)	|  		((brdcfg[1] & 0x80) >> 7);  	sw[3] = brdcfg[2]; -	sw[4] = ((dutcfg[2] & 0x01) << 7)	| \ -		((dutcfg[2] & 0x06) << 4)	| \ -		((~QIXIS_READ(present)) & 0x10)	| \ -		((brdcfg[3] & 0x80) >> 4)	| \ -		((brdcfg[3] & 0x01) << 2)	| \ -		((brdcfg[6] == 0x62) ? 3 :	\ -		((brdcfg[6] == 0x5a) ? 2 :	\ +	sw[4] = ((dutcfg[2] & 0x01) << 7)	| +		((dutcfg[2] & 0x06) << 4)	| +		((~QIXIS_READ(present)) & 0x10)	| +		((brdcfg[3] & 0x80) >> 4)	| +		((brdcfg[3] & 0x01) << 2)	| +		((brdcfg[6] == 0x62) ? 3 : +		((brdcfg[6] == 0x5a) ? 2 :  		((brdcfg[6] == 0x5e) ? 1 : 0))); -	sw[5] = ((brdcfg[0] & 0x0f) << 4)	| \ -		((QIXIS_READ(rst_ctl) & 0x30) >> 2) | \ +	sw[5] = ((brdcfg[0] & 0x0f) << 4)	| +		((QIXIS_READ(rst_ctl) & 0x30) >> 2) |  		((brdcfg[0] & 0x40) >> 5);  	sw[6] = (brdcfg[11] & 0x20)		|  		((brdcfg[5] & 0x02) << 3); -	sw[7] = (((~QIXIS_READ(rst_ctl)) & 0x40) << 1) | \ +	sw[7] = (((~QIXIS_READ(rst_ctl)) & 0x40) << 1) |  		((brdcfg[5] & 0x10) << 2); -	sw[8] = ((brdcfg[12] & 0x08) << 4)	| \ +	sw[8] = ((brdcfg[12] & 0x08) << 4)	|  		((brdcfg[12] & 0x03) << 5);  	puts("DIP switch (reverse-engineering)\n");  	for (i = 0; i < 9; i++) {  		printf("SW%d         = 0b%s (0x%02x)\n", -			i + 1, byte_to_binary_mask(sw[i], mask[i], buf), sw[i]); +		       i + 1, byte_to_binary_mask(sw[i], mask[i], buf), sw[i]);  	}  } -static int do_vdd_adjust(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) +static int do_vdd_adjust(cmd_tbl_t *cmdtp, +			 int flag, int argc, +			 char * const argv[])  {  	ulong override; diff --git a/board/freescale/t4qds/tlb.c b/board/freescale/t4qds/tlb.c index b27356a5f..b701e7520 100644 --- a/board/freescale/t4qds/tlb.c +++ b/board/freescale/t4qds/tlb.c @@ -120,9 +120,11 @@ struct fsl_e_tlb_entry tlb_table[] = {  			MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G,  			0, 16, BOOKE_PAGESZ_64K, 1),  #endif +#ifdef QIXIS_BASE_PHYS  	SET_TLB_ENTRY(1, QIXIS_BASE, QIXIS_BASE_PHYS,  		      MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G,  		      0, 17, BOOKE_PAGESZ_4K, 1), +#endif  #ifdef CONFIG_SRIO_PCIE_BOOT_SLAVE  	/*  	 * SRIO_PCIE_BOOT-SLAVE. 1M space from 0xffe00000 for |