/****************************************************************************** * Copyright (c) 2014 Texas Instruments Incorporated - http://www.ti.com * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * * are met: * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the * * distribution. * * * Neither the name of Texas Instruments Incorporated nor the names of * its contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * ***************************************************************************** * * Filename: evmtci6630k2l.gel * Description: Utility GEL for use with the TCI6630k2l EVM. This GEL has * functions that initialize the chip PLL's and the DDR3A interfaces. * * It also includes general utilities that are useful for EVM development * * More functions will be added as needed. * * Author: Texas instruments * Revision History: * v1.0 - Initial Revision: Includes functions for Core PLL Init, DDR1066,DDR1600 * v1.1 - Functions for DDR1333, Enable all PSC, Set Tetris PLL * v1.2 - Function for DFE PLL Setup * v1.3 - Modified Ethernet PHY setup function to use MDIO * * ---------------------------------------------------------------------------*/ #define GEL_VERSION 1.3 // Timeout definitions int _GEL_Global_Timeout1 = 0; #define TIMEOUT_ID 10 // Global timeout value #define GTIMEOUT 2000 //***************************************************** // Power definitions #define PSC_BASE 0x02350000 #define PSC_PTCMD *( unsigned int* )( PSC_BASE+0x120 ) #define PSC_PTSTAT *( unsigned int* )( PSC_BASE+0x128 ) #define PSC_PDCTL_BASE ( PSC_BASE+0x300 ) #define PSC_MDSTAT_BASE ( PSC_BASE+0x800 ) #define PSC_MDCTL_BASE ( PSC_BASE+0xA00 ) // Modules on power domain 0 // Always on // Modules on power domain 1 #define LPSC_DEBUG (5) #define LPSC_TETB (6) // Modules on power domain 2 #define LPSC_PA (7) #define LPSC_SGMII (8) #define LPSC_SA (9) // Modules on power domain 3 #define LPSC_PCIE_0 (10) // Modules on power domain 4 #define LPSC_PCIE_1 (11) // Modules on power domain 5 #define LPSC_DFE_PD2 (12) // Modules on power domain 6 #define LPSC_SR (13) // Modules on power domain 7 #define LPSC_MSMCRAM (14) // Modules on power domain 8 #define LPSC_GEM_0 (15) // Modules on power domain 9 #define LPSC_GEM_1 (16) // Modules on power domain 10 #define LPSC_GEM_2 (17) // Modules on power domain 11 #define LPSC_GEM_3 (18) // Modules on power domain 16 #define LPSC_DDR3_0 (23) // Modules on power domain 17 #define LPSC_TAC (25) #define LPSC_RAC_0 (26) // Modules on power domain 18 #define LPSC_DFE_PD0 (27) // Modules on power domain 19 #define LPSC_FFTCA_FFTC_0 (28) // Modules on power domain 21 #define LPSC_OSR (34) // Modules on power domain 22 #define LPSC_TCP3D_0 (35) // Modules on power domain 23 #define LPSC_TCP3D_1 (37) // Modules on power domain 24 #define LPSC_VCP_0 (39) #define LPSC_VCP_1 (40) #define LPSC_VCP_2 (41) #define LPSC_VCP_3 (42) // Modules on power domain 26 #define LPSC_BCP (47) // Modules on power domain 27 #define LPSC_DFE_PD1 (48) // Modules on power domain 28 #define LPSC_FFTCA_FFTC_1 (49) // Modules on power domain 29 #define LPSC_IQN_AIL (50) // Modules on power domain 31 #define LPSC_ARM (52) // Power domains definitions #define PD0 (0) // Power Domain-0 #define PD1 (1) // Power Domain-1 #define PD2 (2) // Power Domain-2 #define PD3 (3) // Power Domain-3 #define PD4 (4) // Power Domain-4 #define PD5 (5) // Power Domain-5 #define PD6 (6) // Power Domain-6 #define PD7 (7) // Power Domain-7 #define PD8 (8) // Power Domain-8 #define PD9 (9) // Power Domain-9 #define PD10 (10) // Power Domain-10 #define PD11 (11) // Power Domain-11 #define PD12 (12) // Power Domain-12 #define PD13 (13) // Power Domain-13 #define PD14 (14) // Power Domain-14 #define PD15 (15) // Power Domain-15 #define PD16 (16) // Power Domain-16 #define PD17 (17) // Power Domain-17 #define PD18 (18) // Power Domain-18 #define PD19 (19) // Power Domain-19 #define PD20 (20) // Power Domain-20 #define PD21 (21) // Power Domain-21 #define PD22 (22) // Power Domain-22 #define PD23 (23) // Power Domain-23 #define PD24 (24) // Power Domain-24 #define PD25 (25) // Power Domain-25 #define PD26 (26) // Power Domain-26 #define PD27 (27) // Power Domain-27 #define PD28 (28) // Power Domain-28 #define PD29 (29) // Power Domain-29 #define PD30 (30) // Power Domain-30 #define PD31 (31) // Power Domain-31 #define PSC_SYNCRESET (0x1) #define PSC_DISABLE (0x2) #define PSC_ENABLE (0x3) #define CHIP_LEVEL_REG 0x02620000 /******************* PLL registers **********************************/ /*Boot cfg registers*/ #define KICK0 *(unsigned int*)(CHIP_LEVEL_REG + 0x0038) #define KICK1 *(unsigned int*)(CHIP_LEVEL_REG + 0x003C) #define KICK0_UNLOCK (0x83E70B13) #define KICK1_UNLOCK (0x95A4F1E0) #define KICK_LOCK 0 #define TINPSEL *(unsigned int*)(CHIP_LEVEL_REG + 0x0300) #define TOUTPSEL *(unsigned int*)(CHIP_LEVEL_REG + 0x0304) #define MAINPLLCTL0 *(unsigned int*)(CHIP_LEVEL_REG + 0x0350) //0x0328) #define MAINPLLCTL1 *(unsigned int*)(CHIP_LEVEL_REG + 0x0354) //0x032C) #define MAIN_PLLD_OFFSET 0 #define MAIN_PLLD_MASK 0xFFFFFFC0 #define MAIN_PLLM_OFFSET 12 #define MAIN_PLLM_MASK 0xFFF80FFF #define MAIN_BWADJ0_OFFSET 24 #define MAIN_BWADJ0_MASK 0x00FFFFFF #define MAIN_ENSAT_OFFSET 6 #define MAIN_ENSAT_MASK 0xFFFFFFBF #define MAIN_BWADJ1_OFFSET 0 #define MAIN_BWADJ1_MASK 0xFFFFFFF0 #define OBSCLKCTL *(unsigned int*)(CHIP_LEVEL_REG + 0x0C80) /* PA PLL Registers */ #define BYPASS_BIT_SHIFT 23 #define CLKF_BIT_SHIFT 6 #define CLKD_BIT_SHIFT 0 #define DEVSTAT (*((unsigned int *) 0x02620020)) #define PAPLLCTL0 *(unsigned int*)(CHIP_LEVEL_REG + 0x0358) #define PAPLLCTL1 *(unsigned int*)(CHIP_LEVEL_REG + 0x035C) #define PASSCLKSEL_MASK (1 << 17) /* Tells the configuration of the PASSCLKSEL pin */ #define PA_PLL_BYPASS_MASK (1 << BYPASS_BIT_SHIFT) /* Tells whether the PA PLL is in BYPASS mode or not */ #define PA_PLL_CLKOD_MASK (0x00780000) /* Tells the output divider value for the PA PLL */ #define PA_PLL_CLKF_MASK (0x0007FFC0) /* Tells the multiplier value for the PA PLL */ #define PA_PLL_CLKR_MASK (0x0000003F) /* Tells the divider value for the PA PLL */ #define PA_PLL_RESET_MASK (0x00004000) #define CHIP_MISC1 *(unsigned int*)(CHIP_LEVEL_REG + 0x0C7C) #define ARMPLL_ENABLE_OFFSET 13 #define DDR3APLLCTL0 *(unsigned int*)(CHIP_LEVEL_REG + 0x0360) #define DDR3APLLCTL1 *(unsigned int*)(CHIP_LEVEL_REG + 0x0364) #define DFEPLLCTL0 (unsigned int*)(CHIP_LEVEL_REG + 0x378) #define DFEPLLCTL1 (unsigned int*)(CHIP_LEVEL_REG + 0x37C) #define DFE_CLKDIV_CTL (unsigned int*)(CHIP_LEVEL_REG + 0x6E8) #define DFE_CLKSYNC_CTL (unsigned int*)(CHIP_LEVEL_REG + 0x6EC) //****************************************************** // PLL 1 definitions (DSP and ARM clock and subsystems) #define PLL1_BASE 0x02310000 #define PLL1_PLLCTL (*(unsigned int*)(PLL1_BASE + 0x100)) // PLL1 Control #define PLL1_SECCTL (*(unsigned int*)(PLL1_BASE + 0x108)) // PLL1 Secondary Control #define PLL1_PLLM (*(unsigned int*)(PLL1_BASE + 0x110)) // PLL1 Multiplier #define PLL1_DIV1 (*(unsigned int*)(PLL1_BASE + 0x118)) // DIV1 divider #define PLL1_DIV2 (*(unsigned int*)(PLL1_BASE + 0x11C)) // DIV2 divider #define PLL1_DIV3 (*(unsigned int*)(PLL1_BASE + 0x120)) // DIV3 divider #define PLL1_CMD (*(unsigned int*)(PLL1_BASE + 0x138)) // CMD control #define PLL1_STAT (*(unsigned int*)(PLL1_BASE + 0x13C)) // STAT control #define PLL1_ALNCTL (*(unsigned int*)(PLL1_BASE + 0x140)) // ALNCTL control #define PLL1_DCHANGE (*(unsigned int*)(PLL1_BASE + 0x144)) // DCHANGE status #define PLL1_CKEN (*(unsigned int*)(PLL1_BASE + 0x148)) // CKEN control #define PLL1_CKSTAT (*(unsigned int*)(PLL1_BASE + 0x14C)) // CKSTAT status #define PLL1_SYSTAT (*(unsigned int*)(PLL1_BASE + 0x150)) // SYSTAT status #define PLL1_DIV4 (*(unsigned int*)(PLL1_BASE + 0x160)) // DIV4 divider #define PLL1_DIV5 (*(unsigned int*)(PLL1_BASE + 0x164)) // DIV5 divider #define PLL1_DIV6 (*(unsigned int*)(PLL1_BASE + 0x168)) // DIV6 divider #define PLL1_DIV7 (*(unsigned int*)(PLL1_BASE + 0x16C)) // DIV7 divider #define PLL1_DIV8 (*(unsigned int*)(PLL1_BASE + 0x170)) // DIV8 divider #define PLL1_DIV9 (*(unsigned int*)(PLL1_BASE + 0x174)) // DIV9 divider #define PLL1_DIV10 (*(unsigned int*)(PLL1_BASE + 0x178)) // DIV10 divider #define PLL1_DIV11 (*(unsigned int*)(PLL1_BASE + 0x17C)) // DIV11 divider #define PLL1_DIV12 (*(unsigned int*)(PLL1_BASE + 0x180)) // DIV12 divider #define PLL1_DIV13 (*(unsigned int*)(PLL1_BASE + 0x184)) // DIV13 divider #define PLL1_DIV14 (*(unsigned int*)(PLL1_BASE + 0x188)) // DIV14 divider #define PLL1_DIV15 (*(unsigned int*)(PLL1_BASE + 0x18C)) // DIV15 divider #define PLL1_DIV16 (*(unsigned int*)(PLL1_BASE + 0x190)) // DIV16 divider #define PLLPWRDN_OFFSET 1 #define PLLPWRDN_MASK 0xFFFFFFFD #define PLLRST_OFFSET 3 #define PLLRST_MASK 0xFFFFFFF7 #define PLLENSRC_OFFSET 5 #define PLLENSRC_MASK 0xFFFFFFDF #define PLLEN_OFFSET 0 #define PLLEN_MASK 0xFFFFFFFE #define OUTPUT_DIVIDE_OFFSET 19 #define OUTPUT_DIVIDE_MASK 0xFF87FFFF #define BYPASS_OFFSET 23 #define BYPASS_MASK 0xFF7FFFFF #define PLLM_OFFSET 0 #define PLLM_MASK 0xFFFFFFC0 #define GOSET_OFFSET 0 #define GOSET_MASK 0xFFFFFFFE #define GOSTAT_OFFSET 0 #define GOSTAT_MASK 0xFFFFFFFE #define OUTPUT_DIVIDE_OFFSET 19 #define OUTPUT_DIVIDE_MASK 0xFF87FFFF // ARMPLL definitions #define SEC_PLLCTL0_PLLM_OFFSET 6 #define SEC_PLLCTL0_PLLM_MASK 0xFFFF003F #define SEC_PLLCTL0_BWADJ_OFFSET 24 #define SEC_PLLCTL0_BWADJ_MASK 0x00FFFFFF #define SEC_PLLCTL0_OD_OFFSET 19 #define SEC_PLLCTL0_OD_MASK 0xFF87FFFF #define SEC_PLLCTL0_BYPASS_OFFSET 23 #define SEC_PLLCTL0_BYPASS_MASK 0xFF7FFFFF #define SEC_PLLCTL1_RESET_OFFSET 14 #define SEC_PLLCTL1_RESET_MASK 0xFFFFBFFF #define SEC_PLLCTL1_PWRDWN_OFFSET 15 #define SEC_PLLCTL1_PWRDWN_MASK 0xFFFF7FFF #define SEC_PLLCTL1_ENSTAT_OFFSET 6 #define SEC_PLLCTL1_ENSTAT_MASK 0xFFFFFFBF /*----------------DDR3A Register definition---------------------*/ #define DDR3A_BASE_ADDR (0x21010000) #define DDR3A_STATUS (*(int*)(DDR3A_BASE_ADDR + 0x00000004)) #define DDR3A_SDCFG (*(int*)(DDR3A_BASE_ADDR + 0x00000008)) #define DDR3A_SDRFC (*(int*)(DDR3A_BASE_ADDR + 0x00000010)) #define DDR3A_SDTIM1 (*(int*)(DDR3A_BASE_ADDR + 0x00000018)) #define DDR3A_SDTIM2 (*(int*)(DDR3A_BASE_ADDR + 0x0000001C)) #define DDR3A_SDTIM3 (*(int*)(DDR3A_BASE_ADDR + 0x00000020)) #define DDR3A_SDTIM4 (*(int*)(DDR3A_BASE_ADDR + 0x00000028)) #define DDR3A_ZQCFG (*(int*)(DDR3A_BASE_ADDR + 0x000000C8)) #define DDR3A_TMPALRT (*(int*)(DDR3A_BASE_ADDR + 0x000000CC)) #define DDR3A_DDRPHYC (*(int*)(DDR3A_BASE_ADDR + 0x000000E4)) #define DDR3A_PHY_CFG_BASE (0x02329000) #define DDR3A_PIR (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000004)) #define DDR3A_PGCR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000008)) #define DDR3A_PGCR1 (*(int*)(DDR3A_PHY_CFG_BASE + 0x0000000C)) #define DDR3A_PGCR2 (*(int*)(DDR3A_PHY_CFG_BASE + 0x0000008C)) #define DDR3A_PGSR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000010)) #define DDR3A_PGSR1 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000014)) #define DDR3A_PLLCR (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000018)) #define DDR3A_PTR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x0000001C)) #define DDR3A_PTR1 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000020)) #define DDR3A_PTR2 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000024)) #define DDR3A_PTR3 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000028)) #define DDR3A_PTR4 (*(int*)(DDR3A_PHY_CFG_BASE + 0x0000002C)) #define DDR3A_DSGCR (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000040)) #define DDR3A_DCR (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000044)) #define DDR3A_MR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000054)) #define DDR3A_MR1 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000058)) #define DDR3A_MR2 (*(int*)(DDR3A_PHY_CFG_BASE + 0x0000005C)) #define DDR3A_DTCR (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000068)) #define DDR3A_DTPR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000048)) #define DDR3A_DTPR1 (*(int*)(DDR3A_PHY_CFG_BASE + 0x0000004C)) #define DDR3A_DTPR2 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000050)) #define DDR3A_ZQ0CR1 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000184)) #define DDR3A_ZQ1CR1 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000194)) #define DDR3A_ZQ2CR1 (*(int*)(DDR3A_PHY_CFG_BASE + 0x000001A4)) #define DDR3A_ZQ3CR1 (*(int*)(DDR3A_PHY_CFG_BASE + 0x000001B4)) #define DDR3A_DATX8_8 (*(int*)(DDR3A_PHY_CFG_BASE + 0x000003C0)) #define DDR3_TEST_START_ADDRESS (*(int*)(0x80000000)) #define IODDRM_MASK 0x00000180 #define ZCKSEL_MASK 0x01800000 #define CL_MASK 0x00000072 #define WR_MASK 0x00000E00 #define BL_MASK 0x00000003 #define RRMODE_MASK 0x00040000 #define UDIMM_MASK 0x20000000 #define BYTEMASK_MASK 0x0000FC00 #define MPRDQ_MASK 0x00000080 #define PDQ_MASK 0x00000070 #define NOSRA_MASK 0x08000000 #define ECC_MASK 0x00000001 #define RRMODE_MASK 0x00040000 #define DDR3A_DX0GSR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x000001C4)) //0x71 #define DDR3A_DX1GSR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000204)) //0x81 #define DDR3A_DX2GSR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000244)) //0x91 #define DDR3A_DX3GSR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000284)) //0xA1 #define DDR3A_DX4GSR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x000002C4)) //0xB1 #define DDR3A_DX5GSR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000304)) //0xC1 #define DDR3A_DX6GSR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000344)) //0xD1 #define DDR3A_DX7GSR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x00000384)) //0xE1 #define DDR3A_DX8GSR0 (*(int*)(DDR3A_PHY_CFG_BASE + 0x000003C4)) //0xF1 #define DDR3A_TEST_START_ADDRESS (0x80000000) #define DDR3A_TEST_END_ADDRESS (DDR3A_TEST_START_ADDRESS + (4 * 100)) #define DDR3A_BASE_ADDRESS 0x80000000 #define TETRIS_BASE 0x01E80000 #define TETRIS_CPU0_PTCMD *(unsigned int*)(TETRIS_BASE + 0x0400) #define TETRIS_CPU0_PDSTAT *(unsigned int*)(TETRIS_BASE + 0x0404) #define TETRIS_CPU0_PDCTL *(unsigned int*)(TETRIS_BASE + 0x0408) #define TETRIS_CPU1_PTCMD *(unsigned int*)(TETRIS_BASE + 0x040C) #define TETRIS_CPU1_PDSTAT *(unsigned int*)(TETRIS_BASE + 0x0410) #define TETRIS_CPU1_PDCTL *(unsigned int*)(TETRIS_BASE + 0x0414) #define SECPLLCTL0 *(unsigned int*)(CHIP_LEVEL_REG + 0x0370) #define SECPLLCTL1 *(unsigned int*)(CHIP_LEVEL_REG + 0x0374) unsigned int read_val; /**************************************************************************** * * NAME * OnTargetConnect * * PURPOSE: * Setup almost everything ready for a new debug session: * DSP modules and EVM board modules, at target connection. * Do nothing if target is in realtime mode. * This routine is called when you connect to the target board. * * IMPORTANT: this routine won't attempt to connect to the target * if the target is not in real-time mode and that the dsp boot * mode switches are not set in emulation boot mode. * * USAGE * This routine is a callback routine and called by CCS only. * * RETURN VALUE * NONE * * REFERENCE * ****************************************************************************/ OnTargetConnect() { /*------------------------------------------------------*/ /* GEL_Reset() is used to deal with the worst case */ /* senario of unknown target state. If for some reason */ /* a reset is not desired upon target connection, */ /* GEL_Reset() may be removed and replaced with */ /* something "less brutal" like a cache initialization */ /* function. */ /*------------------------------------------------------*/ //GEL_Reset(); //xmc_setup(); //ddr3_setup(); GEL_TextOut("\nConnecting Target...\n"); // Check if target is not in real-time mode. If it is in stop mode, // initialize everything. In real-time mode, do nothing to connect // unobtrusively... if (!GEL_IsInRealtimeMode()) { // Validates if emulation boot mode if (DEVSTAT & 0x0000000E) { GEL_TextOut("No initialization performed since bootmode = %x \n",,,,,(DEVSTAT >> 1 ) & 0xF); GEL_TextOut("You can manually initialize with GlobalDefaultSetup\n"); } else { // Comment the following line at production application test // when the application need to initialize everything, but not the // GEL file. Global_Default_Setup_Silent(); } } else { GEL_TextOut("No initialization performed in real time mode\n"); } } /*--------------------------------------------------------------*/ /* OnReset() */ /* This function is called by CCS when you do Debug->Resest. */ /* The goal is to put the C6x into a known good state with */ /* respect to cache, edma and interrupts. */ /*--------------------------------------------------------------*/ OnReset( int nErrorCode ) { } /*--------------------------------------------------------------*/ /* xmc_setup() */ /* XMC MPAX register setting to access DDR3 config space */ /*--------------------------------------------------------------*/ #define XMC_BASE_ADDR (0x08000000) #define XMPAX2_L (*(int*)(XMC_BASE_ADDR + 0x00000010)) #define XMPAX2_H (*(int*)(XMC_BASE_ADDR + 0x00000014)) xmc_setup() { /* mapping for ddr emif registers XMPAX*2 */ XMPAX2_L = 0x121010FF; /* replacement addr + perm */ XMPAX2_H = 0x2101000B; /* base addr + seg size (64KB)*/ //"1B"-->"B" by xj GEL_TextOut("XMC setup complete.\n"); } /**************************************************************************** * * NAME * Global_Default_Setup_Silent * * PURPOSE: * Setup almost everything ready for a new debug session: * DSP modules and EVM board modules. * * USAGE * This routine can be called as: * * Global_Default_Setup_Silent() * * RETURN VALUE * NONE * * REFERENCE * ****************************************************************************/ Global_Default_Setup_Silent() { float gel_ver = GEL_VERSION; // Set DSP cache to pre defined values... GEL_TextOut( "TCI6630k2l GEL file Ver is %f \n",,,,, (float) (gel_ver/1.0)); //Set_DSP_Cache(); // Only core 0 can set these if (DNUM == 0) { // Setup main PLL DSP @ 983 MHz Set_Pll1(3); // call Set_Pll1 with index = 3 -> 122.88 MHz to 983.04 MHz operation // Setup all Power Domains on Set_Psc_All_On(); // Setup PA PLL PaPllConfig(); GEL_TextOut("DDR begin\n"); xmc_setup(); ddr3A_64bit_DDR1600_setup(0); GEL_TextOut("DDR done\n"); } } /**************************************************************************** * * NAME * Set_PSC_State * * PURPOSE: * Set a new power state for the specified domain id in a power controler * domain. Wait for the power transition to complete. * * USAGE * This routine can be called as: * * Set_PSC_State(unsigned int pd,unsigned int id,unsigned int state) * * pd - (i) power domain. * * id - (i) module id to use for module in the specified power domain * * state - (i) new state value to set * 0 = RESET * 1 = SYNC RESET * 2 = DISABLE * 3 = ENABLE * * RETURN VALUE * 0 if ok, !=0 for error * * REFERENCE * ****************************************************************************/ Set_PSC_State(unsigned int pd,unsigned int id,unsigned int state) { unsigned int* mdctl; unsigned int* mdstat; unsigned int* pdctl; int ret=0; // Only core0 can set PSC if (DNUM == 0) { mdctl = ( unsigned int* )(PSC_MDCTL_BASE + ( 4 * id )); mdstat = ( unsigned int* )( PSC_MDSTAT_BASE + ( 4 * id )); pdctl = ( unsigned int* )(PSC_PDCTL_BASE + ( 4 * pd )); // If state is already set, do nothing if ( ( *mdstat & 0x1f ) == state ) { return(0); } // Wait for GOSTAT to clear Set_Timeout(GTIMEOUT); while( Get_Timeout() && (PSC_PTSTAT & (0x1 << pd)) != 0 ); // Check if we got timeout error while waiting if (!Get_Timeout()) { GEL_TextOut( "Set_PSC_State... Timeout Error #01 pd=%d, md=%d!\n",,2,,,pd,id); ret=1; } else { // Set power domain control *pdctl = (*pdctl) | 0x00000001; // Set MDCTL NEXT to new state *mdctl = ((*mdctl) & ~(0x1f)) | state; // Start power transition by setting PTCMD GO to 1 PSC_PTCMD = (PSC_PTCMD) | (0x1< 614.4 MHz CLKIN_val = 122.88; // setup CLKIN to 122.88 MHz PLLM_val = 10; // setup PLLM (PLL multiplier) to x10 PLLD_val = 1; // setup PLLD (reference divider) to /1 OD_val = 2; // setup OD to a fixed /2 } else if(index == 2){ // 122.88MHz -> 737.28 MHz CLKIN_val = 122.88; // setup CLKIN to 122.88 MHz PLLM_val = 12; // setup PLLM (PLL multiplier) to x12 PLLD_val = 1; // setup PLLD (reference divider) to /1 OD_val = 2; // setup OD to a fixed /2 } else if(index == 3){ // 122.88MHz -> 983.04 MHz CLKIN_val = 122.88; // setup CLKIN to 122.88 MHz PLLM_val = 16; // setup PLLM (PLL multiplier) to x12 PLLD_val = 1; // setup PLLD (reference divider) to /1 OD_val = 2; // setup OD to a fixed /2 } else if(index == 4){ // 122.88 MHz -> 1.2 GHz CLKIN_val = 122.88; // setup CLKIN to 122.88 MHz PLLM_val = 20; // setup PLLM (PLL multiplier) to x20 PLLD_val = 1; // setup PLLD (reference divider) to /1 OD_val = 2; // setup OD to a fixed /2 } else if(index == 5){ // 122.88 MHz -> 1.35 GHz CLKIN_val = 122.88; // setup CLKIN to 122.88 MHz PLLM_val = 22; // setup PLLM (PLL multiplier) to x22 PLLD_val = 1; // setup PLLD (reference divider) to /1 OD_val = 2; // setup OD to a fixed /2 } PLLDIV3_val = 3; // setup PLL output divider 3 to /3 PLLDIV4_val = 5; // setup PLL output divider 4 to /3 PLLDIV7_val = 6; // setup PLL output divider 7 to /6 BYPASS_val = PLL1_SECCTL & ~BYPASS_MASK; // get value of the BYPASS field BWADJ_val = (PLLM_val) >> 1; // setup BWADJ to be 1/2 the value of PLLM debug_info_on = 1; delay = 1000; // fix this! /* Step 1: Unlock Boot Config Registers */ KICK0 = KICK0_UNLOCK; KICK1 = KICK1_UNLOCK; /* Step 2: Check if SECCTL bypass is low or high indicating what state the Main PLL is currently in. if the Main PLL is in bypass still (not yet setup) execute the following steps. */ if(BYPASS_val != 0x00000000){ // PLL bypass enabled - Execute PLL setup for PLL fresh out of power on reset if(debug_info_on){ GEL_TextOut("Detected PLL bypass enabled: SECCTL[BYPASS] = %x\n",,,,, BYPASS_val); } /* Step 2a: Set MAINPLLCTL1[ENSAT] = 1 - This enables proper biasing of PLL analog circuitry */ MAINPLLCTL1 |= (1 << MAIN_ENSAT_OFFSET); if(debug_info_on){ GEL_TextOut("(2a) MAINPLLCTL1 = %x\n",,,,, MAINPLLCTL1); } /* Step 2b: Set PLLCTL[PLLEN] = 0 This enables bypass in PLL controller MUX */ PLL1_PLLCTL &= ~(1 << PLLEN_OFFSET); if(debug_info_on){ GEL_TextOut("(2b) PLLCTL = %x\n",,,,, PLL1_PLLCTL); } /* Step 2c: Set PLLCTL[PLLENSRC] = 0 - This enables PLLEN to control PLL controller MUX */ PLL1_PLLCTL &= ~(1 << PLLENSRC_OFFSET); if(debug_info_on){ GEL_TextOut("(2c) PLLCTL = %x\n",,,,, PLL1_PLLCTL); } /* Step 2d: Wait 4 reference clock cycles (slowest of ALTCORE or SYSCLK) to make sure that the PLL controller MUX switches properly to bypass. */ if(debug_info_on){ GEL_TextOut("(2d) Delay...\n",,,,,); } for(i = 0; i < delay; i++); // this delay is much more than required /* Step 2e: Set SECCTL[BYPASS] = 1 - enables bypass in PLL MUX */ PLL1_SECCTL |= (1 << BYPASS_OFFSET); if(debug_info_on){ GEL_TextOut("(2e) SECCTL = %x\n",,,,, PLL1_SECCTL); } /* Step 2f: Set PLLCTL[PLLPWRDN] = 1 - power down the PLL */ PLL1_PLLCTL |= (1 << PLLPWRDN_OFFSET); if(debug_info_on){ GEL_TextOut("(2f) PLLCTL = %x\n",,,,, PLL1_PLLCTL); } /* Step 2g: Wait for at least 5us for the PLL to power down */ if(debug_info_on){ GEL_TextOut("(2g) Delay...\n",,,,,); } for(i = 0; i < delay; i++); // this delay is much more than required /* Step 2h: Set PLLCTL[PLLPWRDN] = 0 - Power the PLL back up */ PLL1_PLLCTL &= ~(1 << PLLPWRDN_OFFSET); if(debug_info_on){ GEL_TextOut("(2h) PLLCTL = %x\n",,,,, PLL1_PLLCTL); } } else{ // PLL bypass disabled - Execute PLL setup for PLL that has previously been locked (skip to Step 3) if(debug_info_on){ GEL_TextOut("Detected PLL bypass disabled: SECCTL[BYPASS] = %x\n",,,,, BYPASS_val); } /* Step 3a: Set PLLCTL[PLLEN] = 0 This enables bypass in PLL controller MUX */ PLL1_PLLCTL &= ~(1 << PLLEN_OFFSET); if(debug_info_on){ GEL_TextOut("(3a) PLLCTL = %x\n",,,,, PLL1_PLLCTL); } /* Step 3b: Set PLLCTL[PLLENSRC] = 0 - This enables PLLEN to control PLL controller MUX */ PLL1_PLLCTL &= ~(1 << PLLENSRC_OFFSET); if(debug_info_on){ GEL_TextOut("(3b) PLLCTL = %x\n",,,,, PLL1_PLLCTL); } /* Step 3c: Wait 4 reference clock cycles (slowest of ALTCORE or SYSCLK) to make sure that the PLL controller MUX switches properly to bypass. */ if(debug_info_on){ GEL_TextOut("(3c) Delay...\n",,,,,); } for(i = 0; i < delay; i++); // this delay is much more than required } /* Step 4: Programming PLLM[5:0] in the PLLM register of the PLL controller and programming PLLM[12:6] in the MAINPLLCTL0 register */ PLL1_PLLM &= PLLM_MASK; // clear the PLLM[5:0] bit field PLL1_PLLM |= ~PLLM_MASK & (PLLM_val - 1); // set the PLLM[5:0] bit field to the 6 LSB of PLLM_val if(debug_info_on){ GEL_TextOut("(4)PLLM[PLLM] = %x\n",,,,, PLL1_PLLM); } MAINPLLCTL0 &= MAIN_PLLM_MASK; // clear the PLLM[12:6] bit field MAINPLLCTL0 |= ~MAIN_PLLM_MASK & (( (PLLM_val - 1) >> 6) << MAIN_PLLM_OFFSET); // set the PLLM[12:6] bit field to the 7 MSB of PLL_val if(debug_info_on){ GEL_TextOut("MAINPLLCTL0 = %x\n",,,,, MAINPLLCTL0); } /* Step 5: Programming BWADJ[7:0] in the MAINPLLCTL0 register and BWADJ[11:8] in MAINPLLCTL1 register */ MAINPLLCTL0 &= MAIN_BWADJ0_MASK; // clear the MAIN_BWADJ0 bit field MAINPLLCTL0 |= ~MAIN_BWADJ0_MASK & ((BWADJ_val - 1) << MAIN_BWADJ0_OFFSET); // set the MAIN_BWADJ[7:0] bit field to the 8 LSB of BWADJ_val if(debug_info_on){ GEL_TextOut("(5) MAINPLLCTL0 = %x\n",,,,, MAINPLLCTL0); } MAINPLLCTL1 &= MAIN_BWADJ1_MASK; // clear the MAIN_BWADJ1 bit field MAINPLLCTL1 |= ~MAIN_BWADJ1_MASK & (( (BWADJ_val - 1) >> 8) << MAIN_BWADJ1_OFFSET); // set the MAIN_BWADJ[11:8] bit field to the 4 MSB of BWADJ_val if(debug_info_on){ GEL_TextOut("(5) MAINPLLCTL1 = %x\n",,,,, MAINPLLCTL1); } /* Step 6: Programming PLLD[5:0] in the MAINPLLCTL0 register */ MAINPLLCTL0 &= MAIN_PLLD_MASK; // clear the PLLD bit field MAINPLLCTL0 |= ~MAIN_PLLD_MASK & (PLLD_val - 1); // set the PLLD[5:0] bit field of PLLD to PLLD_val if(debug_info_on){ GEL_TextOut("(6) MAINPLLCTL0 = %x\n",,,,, MAINPLLCTL0); } /* Step 7: Programming OD[3:0] in the SECCTL register */ PLL1_SECCTL &= OUTPUT_DIVIDE_MASK; // clear the OD bit field PLL1_SECCTL |= ~OUTPUT_DIVIDE_MASK & (OD_val - 1) << OUTPUT_DIVIDE_OFFSET; // set the OD[3:0] bit field of PLLD to OD_val if(debug_info_on){ GEL_TextOut("(7) SECCTL = %x\n",,,,, PLL1_SECCTL); } /* Step 8: Following steps are needed to change the default output dividers */ /* Step 8a: Check that the GOSTAT bit in PLLSTAT is cleared to show that no GO operation is currently in progress*/ if(debug_info_on){ GEL_TextOut("(8a) Delay...\n",,,,,); } while((PLL1_STAT) & 0x00000001); /* Step 8b: Program the RATIO field in PLLDIVn to the desired new divide-down rate. If RATIO field is changed, the PLL controller will flag the change in the corresponding bit of DCHANGE*/ PLL1_DIV3 = (PLLDIV3_val-1) | 0x8000; //Set PLLDIV3 PLL1_DIV4 = (PLLDIV4_val-1) | 0x8000; //Set PLLDIV4 PLL1_DIV7 = (PLLDIV7_val-1) | 0x8000; //Set PLLDIV7 if(debug_info_on){ GEL_TextOut("PLL1_DIV3 = %x\n",,,,, PLL1_DIV3); GEL_TextOut("PLL1_DIV4 = %x\n",,,,, PLL1_DIV4); GEL_TextOut("PLL1_DIV7 = %x\n",,,,, PLL1_DIV7); } /* Step 8c: Set GOSET bit in PLLCMD to initiate the GO operation to change the divide values and align the SYSCLKs as programmed */ PLL1_CMD |= 0x00000001; /*Step 8d/e: Read the GOSTAT bit in PLLSTAT to make sure the bit returns to 0 to indicate that the GO operation has completed */ if(debug_info_on){ GEL_TextOut("(8d/e) Delay...\n",,,,,); } while((PLL1_STAT) & 0x00000001); /* Step 9: Set PLLCTL[PLLRST] = 1 - Assert PLL reset (Previously Step 3)*/ PLL1_PLLCTL |= (1 << PLLRST_OFFSET); /* Step 10: Wait for the at least 7us for the PLL reset properly (128 CLKIN1 cycles) */ if(debug_info_on){ GEL_TextOut("(10) Delay...\n",,,,,); } for(i=0;i 1.0 GHz CLKIN_val = 125; // setup CLKIN to 125 MHz PLLM_val = 16; // setup PLLM (PLL multiplier) to x20 OD_val = 2; // setup OD to a fixed /2 } else if(index == 2){ // 100 MHz -> 1.4 GHz CLKIN_val = 125; // setup CLKIN to 125 MHz PLLM_val = 22; // setup PLLM (PLL multiplier) to x28 OD_val = 2; // setup OD to a fixed /2 } else if(index == 3){ // 174.825MHz -> 1.4 GHz CLKIN_val = 174.825; // setup CLKIN to 174.825 MHz PLLM_val = 16; // setup PLLM (PLL multiplier) to x16 OD_val = 2; // setup OD to a fixed /2 } BWADJ_val = (PLLM_val-1) >> 1; // setup BWADJ to be 1/2 the value of PLLM /* Step 1: Unlock Boot Config Registers */ KICK0 = KICK0_UNLOCK; KICK1 = KICK1_UNLOCK; //Step 1 : Assert SEC PLL Reset SECPLLCTL1 = ((1 << SEC_PLLCTL1_RESET_OFFSET) | (1 << SEC_PLLCTL1_ENSTAT_OFFSET)); //Step 2 : Change CLKF/OD/BWADJ etc. for SEC PLL SECPLLCTL0 = ((BWADJ_val << SEC_PLLCTL0_BWADJ_OFFSET) | ((OD_val-1) << SEC_PLLCTL0_OD_OFFSET)| ((PLLM_val-1) << SEC_PLLCTL0_PLLM_OFFSET)); //Step 3 : Make sure the resets are held for 5us for(i = 0; i < 200000; i++); //Step 4 : Remove SEC PLL reset SECPLLCTL1 = (1 << SEC_PLLCTL1_ENSTAT_OFFSET); //Step 5 : Wait for PLL to lock (4000 CLKIN1 cycles) for(i = 0; i < 4000; i++); //Step 6 : Get the PLL out of Bypass //SECPLLCTL0 &= ~(1 << SEC_PLLCTL0_BYPASS_OFFSET); CHIP_MISC1 |= (1 << ARMPLL_ENABLE_OFFSET); //Step 6 : Lock Boot Config Registers KICK0 = 0x00000000; KICK1 = 0x00000000; GEL_TextOut("ARM PLL has been configured (%f MHz * %d / %d = %f MHz)\n",,,,, CLKIN_val, PLLM_val, OD_val, (CLKIN_val * PLLM_val)/OD_val); } /* Set the desired PA PLL configuration */ PaPllConfig() { unsigned int passclksel = (DEVSTAT & PASSCLKSEL_MASK); unsigned int papllctl0val_orig = PAPLLCTL0; unsigned int papllctl1val_orig = PAPLLCTL1; unsigned int papllctl0val_final; unsigned int papllctl1val_final; unsigned int papllclkf = 204; //31; // 204; 20 (if PASSREFCLK == 100mhz) Multiply by clkf + 1 unsigned int papllclkd = 11; //11; 1 (if PASSREFCLK == 100mhz) Divide by clkd + 1 unsigned int i = 0; if (passclksel != PASSCLKSEL_MASK) GEL_TextOut("WARNING: SYSCLK is the input to the PA PLL.\n"); /* Unlock Chip Level Registers */ KICK0 = KICK0_UNLOCK; KICK1 = KICK1_UNLOCK; // PAPLLCTL1 = PAPLLCTL1 | 0x00000040; //Set ENSAT = 1; Set PLL Select to 0 (for SYCLK0 as input of PASS) PAPLLCTL1 = PAPLLCTL1 | 0x00002040; //Set ENSAT = 1; Set PLL Select to 1 (for PA PLL as input of PASS) /*in PAPLLCTL0, clear bypass bit to set the PA PLL in Bypass Mode*/ //PAPLLCTL0 &= ~(1<>1)-1)<<24); PAPLLCTL1 &= ~(0x0000000F); PAPLLCTL1 |= (((((papllclkf + 1)>>1)-1) >> 8) & 0x0000000F); //PAPLLCTL1 = PAPLLCTL1 | 0x00002000; /*Wait for PLL to properly reset (128 CLKIN1 cycles) */ for(i=0;i<1000;i++); /* take the PA PLL out of reset */ PAPLLCTL1 &= (~PA_PLL_RESET_MASK); /*Wait for PLL to lock (2000 CLKIN1 cycles) */ for(i=0;i<5000;i++); /* enable PLL mode */ PAPLLCTL0 &= ~(1< 63) return(0); /* Unlock Boot Config Registers */ KICK0 = KICK0_UNLOCK; KICK1 = KICK1_UNLOCK; // Reset DFEPLLCTL0, DFEPLLCTL1, DFE_CLKDIV_CTL, DFE_CLKSYNC_CTL *dfepllctl0 = 0x098803C0; *dfepllctl1 = 0x00000040; *dfe_clkdiv_ctl = 0x00000000; *dfe_clksync_ctl = 0x00000000; // Step 1: Put PLL in bypass. *dfepllctl0 |= DFE_PLL_BYPASS_SET; // Step 2: Put PLL in reset. *dfepllctl1 |= DFE_PLL_RESET_SET; // Step 3: Program PLL clkf (CLKF) *dfepllctl0 &= ~(DFE_PLL_MULT_MASK << DFE_PLL_MULT_SHIFT); *dfepllctl0 |= ((clkf & DFE_PLL_MULT_MASK) << DFE_PLL_MULT_SHIFT); // Step 4: Set bwadj factor. *dfepllctl0 &= DFE_PLL_BWADJ_MASK; *dfepllctl0 |= (clkf/2) << DFE_PLL_BWADJ_SHIFT; // Step 5: set PLL post div (CLKOD) *dfepllctl0 &= ~(DFE_PLL_ODIV_MASK << DFE_PLL_ODIV_SHIFT); *dfepllctl0 |= ((clkod & DFE_PLL_ODIV_MASK) << DFE_PLL_ODIV_SHIFT); // Step 6: Wait for 5us based on refclk for(i=0;i<30000;i++); // Step 7: Set Divmode in DFE_CLKDIV_CTL *dfe_clkdiv_ctl &= ~(DFE_PLL_DIVMODE_MASK << DFE_PLL_DIVMODE_SHIFT); *dfe_clkdiv_ctl |= ((divmode & DFE_PLL_DIVMODE_MASK) << DFE_PLL_DIVMODE_SHIFT); // Step 8: Release PLL reset. But make sure reset is at least 5us. for(i=0;i<30000;i++); *dfepllctl1 &= ~DFE_PLL_RESET_SET; // Step 9: wait for PLL to lock. --// NEED TO UPDATE Wait for at least 500 * REFCLK cycles * (PLLD + 1) (PLL lock time) //waitfor(((*stat & DFE_PLL_LOCK_SET) == DFE_PLL_LOCK_SET), 1000); //if ((*stat & DFE_PLL_LOCK_SET) != DFE_PLL_LOCK_SET) return(FAIL); for(i=0;i<30000;i++); // Step 10: Disable PLL bypass *dfepllctl0 &= ~DFE_PLL_BYPASS_SET; for(i=0;i<10;i++); // Step 11: Program sync_en (DFECLKSYNC) *dfe_clksync_ctl = 0x00000001; for(i=0;i<100;i++); // Step 12: Set PLLSEL = 1 *dfepllctl1 |= DFE_PLL_PLLSEL_SET; /* Lock Boot Config Registers */ KICK0 = KICK_LOCK; KICK1 = KICK_LOCK; return(1); } //************************************************************************************************* //************************************************************************************************* //************************************************************************************************* //************************************************************************************************* //************************************************************************************************* //************************************************************************************************* //--------DDR3A Memory test---------------------- ddr3A_memory_test () { unsigned int index, value; GEL_TextOut( "DDR3A memory test... Started\n" ); /* Write a pattern */ for (index = DDR3A_TEST_START_ADDRESS; index < DDR3A_TEST_END_ADDRESS; index += 4) { *index = index; } /* Read and check the pattern */ for (index = DDR3A_TEST_START_ADDRESS; index < DDR3A_TEST_END_ADDRESS; index += 4) { value = *index; if (value != index) { GEL_TextOut( "DDR3A memory test... Failed\n" ); return -1; } } /* Write a pattern for complementary values */ for (index = DDR3A_TEST_START_ADDRESS; index < DDR3A_TEST_END_ADDRESS; index += 4) { *index = ~index; } /* Read and check the pattern */ for (index = DDR3A_TEST_START_ADDRESS; index < DDR3A_TEST_END_ADDRESS; index += 4) { value = *index; if (value != ~index) { GEL_TextOut( "DDR3A memory test... Failed\n" ); return -1; } } GEL_TextOut( "DDR3A memory test... Passed\n" ); return 0; } //--------------------------------------------------- /**************************************************************************** * * NAME * Setup_Memory_Map * * PURPOSE: * Setup the Memory Map for EVMC6678L. * Defined memory location avoid debugger access outside these locations. * * USAGE * This routine can be called as: * * Setup_Memory_Map() * * RETURN VALUE * NONE * * REFERENCE * Based on TMS320C6678 datasheet. * ****************************************************************************/ hotmenu Setup_Memory_Map( ) { GEL_TextOut("Setup_Memory_Map...\n",,); GEL_MapOn( ); GEL_MapReset( ); GEL_MapAddStr( 0x00000000, 0, 0x21400000, "R|W|AS4", 0 ); // GEL_MapAddStr( 0x21400000,0, 0x00000080, "R|W|AS4", 0 ); // Hyperlink Config (remote) //GEL_MapAddStr( 0x21400080,0, 0x00000080, "R|W|AS4", 0 ); // Hyperlink Config (remote) GEL_MapAddStr( 0x21400200, 0, 0xdebffe00, "R|W|AS4", 0 ); // GEL_TextOut( "Setup_Memory_Map... Done.\n" ); } /*----------------------------------------------------- DDR3A : DDR1066, 64bit--------------------------------------------------------------------------*/ ddr3A_64bit_DDR1066_setup(int ECC_Enable) { unsigned int multiplier = 15; unsigned int divider = 0; unsigned int OD_val = 6; int temp,i; int delay = 2000; KICK0 = 0x83E70B13; KICK1 = 0x95A4F1E0; // Poll for IDONE=1 in the PHY General Status Register 0 (address offset 0x010). do { read_val = DDR3A_PGSR0; } while ((read_val&0x00000001) != 0x00000001); // Clocks are enabled and frequency is stable--------------------------------------- // DDR3A PLL setup GEL_TextOut ( "DDR3 PLL Setup ... \n"); // DDR3APLLCTL0 = DDR3APLLCTL0 & 0xFF7FFFFF; // Set ENSAT = 1 DDR3APLLCTL1 |= 0x00000040; // Put the PLL in PLL Mode DDR3APLLCTL0 |= 0x00800000; // Program the necessary multipliers/dividers and BW adjustments // Set the divider values DDR3APLLCTL0 &= ~(0x0000003F); DDR3APLLCTL0 |= (divider & 0x0000003F); // Program OD[3:0] in the SECCTL register DDR3APLLCTL0 &= OUTPUT_DIVIDE_MASK; // clear the OD bit field DDR3APLLCTL0 |= ~OUTPUT_DIVIDE_MASK & (OD_val - 1) << OUTPUT_DIVIDE_OFFSET; // set the OD[3:0] bit field of PLLD to OD_val // Set the Multipler values DDR3APLLCTL0 &= ~(0x0007FFC0); DDR3APLLCTL0 |= ((multiplier << 6) & 0x0007FFC0 ); temp = ((multiplier + 1) >> 1) - 1; DDR3APLLCTL0 &= ~(0xFF000000); DDR3APLLCTL0 |= ((temp << 24) & 0xFF000000); DDR3APLLCTL1 &= ~(0x0000000F); DDR3APLLCTL1 |= ((temp >> 8) & 0x0000000F); // In PLL Controller, reset the PLL (bit 13 in DDR3APLLCTL1 register) DDR3APLLCTL1 |= 0x00004000; for(i=0;i> 1) - 1; DDR3APLLCTL0 &= ~(0xFF000000); DDR3APLLCTL0 |= ((temp << 24) & 0xFF000000); DDR3APLLCTL1 &= ~(0x0000000F); DDR3APLLCTL1 |= ((temp >> 8) & 0x0000000F); // In PLL Controller, reset the PLL (bit 13 in DDR3APLLCTL1 register) DDR3APLLCTL1 |= 0x00004000; for(i=0;i> 1) - 1; DDR3APLLCTL0 &= ~(0xFF000000); DDR3APLLCTL0 |= ((temp << 24) & 0xFF000000); DDR3APLLCTL1 &= ~(0x0000000F); DDR3APLLCTL1 |= ((temp >> 8) & 0x0000000F); // In PLL Controller, reset the PLL (bit 13 in DDR3APLLCTL1 register) DDR3APLLCTL1 |= 0x00004000; for(i=0;i 122.88 MHz to 614.4 MHz operation } hotmenu CORE_PLL_INIT_122_88MHZ_to_737_28MHz() { Set_Pll1(2); // call Set_Pll1 with index = 2 -> 122.88 MHz to 737.28 MHz operation } hotmenu CORE_PLL_INIT_122_88MHZ_to_983_04MHz() { Set_Pll1(3); // call Set_Pll1 with index = 3 -> 122.88 MHz to 983.04 MHz operation } hotmenu CORE_PLL_INIT_122_88MHZ_to_1_2GHz() { Set_Pll1(4); // call Set_Pll1 with index = 4 -> 122.88 MHz to 1.2 GHz operation } hotmenu CORE_PLL_INIT_122_88MHZ_to_1_3Gz() { Set_Pll1(5); // call Set_Pll1 with index = 4 -> 122.88 MHz to 1.2 GHz operation } hotmenu TETRIS_POWERUP_AND_PLL_INIT_100MHZ_to_1000MHz() { Set_Tetris_Pll(1); // 100 MHz to 1.0 GHz operation } hotmenu TETRIS_POWERUP_AND_PLL_INIT_100MHZ_to_1400MHz() { Set_Tetris_Pll(2); // 100 MHz to 1.4 GHz operation } hotmenu TETRIS_POWERUP_AND_PLL_INIT_175MHZ_to_1400MHz() { Set_Tetris_Pll(3); // 175 MHz to 1.4 GHz operation } hotmenu PA_PLL_Config() { PaPllConfig(); } hotmenu DFE_PLL_Init_122MHZ_to_245MHz() { // DFE PLL REFCLK = 122.88 MHz // DFE PLL CLKR = 0x0 (Default: no prediv) // DFE PLL CLKF = 0x7(Default) or 0x5 (multiplier = n+1 = 8,or 6) // DFE PLL CLKOD = 0x0(Default) (postdiv = 1, no postdiv) // DFE PLL CLKOUT = 983.04 (Default) or 737.28MHz //DFECLKSYNC_CTL register DIVMODE configured to /4 (default) or /2, to support //DFE operating frequency of 245.76 (default), 368.64 or 491.52 MHz. Note 491.52 is //frequency is only supported for internal testing. //DFE Frequency PLL Configuration DFECLKSYNC Divider Mode //245.76 MHz x8 (983.04 MHz) /4 //491.52 MHz x8 (983.04 MHz) /2 //368.64 MHz x6 (737.28 MHz) /2 dfepll_setup(CHIP_LEVEL_REG, 0, 8-1, 1-1, 0); GEL_TextOut("DFE_CLK setup to 245.76Mh complete!\n",,,,,); } hotmenu InitDDR3A_64bit_DDR1066_NOECC() { ddr3A_64bit_DDR1066_setup(0); } hotmenu InitDDR3A_64bit_DDR1333_NOECC() { ddr3A_64bit_DDR1333_setup(0); } hotmenu InitDDR3A_64bit_DDR1600_NOECC() { ddr3A_64bit_DDR1600_setup(0); } ///* Function to enable CORE PLL observation clock for PLL output */// hotmenu ENABLE_CORE_PLL_OBSCLK() { /* Unlock Chip Level Registers */ KICK0 = KICK0_UNLOCK; KICK1 = KICK1_UNLOCK; /* set bit 1 to enable power to the CORE PLL observation clock, clear bit 0 to view the CORE PLL observation (output) clock */ OBSCLKCTL |= (1 << 1); /* set bit 1 to enable power to the observation clock */ OBSCLKCTL &= ~(1 << 0); /* clear bit 0 to view the CORE PLL clock */ /* Lock Chip Level Registers */ KICK0 = 0x00000000; KICK1 = 0x00000000; GEL_TextOut("CORE PLL observation clock enabled and configured to show CORE PLL output\n"); } /* Function to enable DDR PLL observation clock for PLL output */ hotmenu ENABLE_DDR_PLL_OBSCLK () { /* Unlock Chip Level Registers */ KICK0 = KICK0_UNLOCK; KICK1 = KICK1_UNLOCK; /* set bit 1 to enable power to the CORE PLL observation clock, clear bit 0 to view the CORE PLL observation (output) clock */ OBSCLKCTL |= (1 << 3); /* set bit 3 to enable power to the observation clock */ OBSCLKCTL |= (1 << 2); /* set bit 2 to view the DDR PLL clock */ /* Lock Chip Level Registers */ //KICK0 = 0x00000000; // KICK1 = 0x00000000; GEL_TextOut("DDR PLL observation clock enabled and configured to show DDR PLL output\n"); } hotmenu ENABLE_ARM_PLL_OBSCLK () { /* Unlock Chip Level Registers */ KICK0 = KICK0_UNLOCK; KICK1 = KICK1_UNLOCK; /* set bit 1 to enable power to the CORE PLL observation clock, clear bit 0 to view the CORE PLL observation (output) clock */ //OBSCLKCTL |= (1 << 3); /* set bit 3 to enable power to the observation clock */ OBSCLKCTL |= (1 << 6); /* set bit 2 to view the DDR PLL clock */ /* Lock Chip Level Registers */ KICK0 = 0x00000000; KICK1 = 0x00000000; GEL_TextOut("DDR PLL observation clock enabled and configured to show DDR PLL output\n"); } hotmenu ENABLE_PA_PLL_OBSCLK () { /* Unlock Chip Level Registers */ KICK0 = KICK0_UNLOCK; KICK1 = KICK1_UNLOCK; /* set bit 1 to enable power to the CORE PLL observation clock, clear bit 0 to view the CORE PLL observation (output) clock */ OBSCLKCTL |= (1 << 4); /* set bit 3 to enable power to the observation clock */ OBSCLKCTL |= (1 << 5); /* set bit 2 to view the DDR PLL clock */ /* Lock Chip Level Registers */ KICK0 = 0x00000000; KICK1 = 0x00000000; GEL_TextOut("DDR PLL observation clock enabled and configured to show DDR PLL output\n"); } hotmenu ddr3A_write_read_test() { //int data_set[4]; //= {0xAAAAAAAA, 0x55555555, 0xFFFFFFFF, 0x00000000}; unsigned int write_data = 0xAAAAAAAA; unsigned int read_data = 0x0; unsigned int errors = 0; int dw; unsigned int i, mem_start, mem_size, mem_location; mem_start = DDR3A_BASE_ADDRESS + (DNUM * 0x01000000); mem_size = 0x100; for(dw=0;dw<4;dw++) { if (dw == 0) write_data = 0xAAAAAAAA; if (dw == 1) write_data = 0x55555555; if (dw == 2) write_data = 0xFFFFFFFF; if (dw == 3) write_data = 0x00000000; mem_location = mem_start; GEL_TextOut( "Memory Test Write Core: %d, Mem Start: 0x%x, Mem Size: 0x%x, value: 0x%x ...\n",,2,,,DNUM,mem_start,mem_size,write_data); for(i=0;i> CSL_##PER_REG_FIELD##_SHIFT) #endif */ /* the Field MaKe macro */ #define CSL_FMK(SHIFT, MASK, val) (((val) << SHIFT) & MASK) /* the Field EXTract macro */ #define CSL_FEXT(reg, SHIFT, MASK) (((reg) & MASK) >> SHIFT) #define PHY_REG_PAGE_ADDR 22 phy_hwwrite(unsigned short phy_addr, unsigned short addr, unsigned short val) { unsigned int retVal=1; unsigned int i, delay=2000; MDIO_USER_ACCESS_REG = CSL_FMK (CSL_MDIO_USER_ACCESS_REG_GO_SHIFT, CSL_MDIO_USER_ACCESS_REG_GO_MASK, 1u) | CSL_FMK (CSL_MDIO_USER_ACCESS_REG_WRITE_SHIFT, CSL_MDIO_USER_ACCESS_REG_WRITE_MASK, 1) | CSL_FMK (CSL_MDIO_USER_ACCESS_REG_REGADR_SHIFT, CSL_MDIO_USER_ACCESS_REG_REGADR_MASK, addr) | CSL_FMK (CSL_MDIO_USER_ACCESS_REG_PHYADR_SHIFT, CSL_MDIO_USER_ACCESS_REG_PHYADR_MASK, phy_addr) | CSL_FMK (CSL_MDIO_USER_ACCESS_REG_DATA_SHIFT, CSL_MDIO_USER_ACCESS_REG_DATA_MASK, val); while(1) { retVal=CSL_FEXT(MDIO_USER_ACCESS_REG, CSL_MDIO_USER_ACCESS_REG_GO_SHIFT, CSL_MDIO_USER_ACCESS_REG_GO_MASK); if(retVal == 0) break; for(i = 0; i < delay; i++); // this delay is much more than required } } phy_hwread(unsigned short phy_addr, unsigned short addr, unsigned short *val) { MDIO_USER_ACCESS_REG = CSL_FMK (CSL_MDIO_USER_ACCESS_REG_GO_SHIFT, CSL_MDIO_USER_ACCESS_REG_GO_MASK, 1u) | CSL_FMK (CSL_MDIO_USER_ACCESS_REG_REGADR_SHIFT, CSL_MDIO_USER_ACCESS_REG_REGADR_MASK, addr) | CSL_FMK (CSL_MDIO_USER_ACCESS_REG_PHYADR_SHIFT, CSL_MDIO_USER_ACCESS_REG_PHYADR_MASK, phy_addr); PHYREG0_waitResultsAck(*val, ack); if(!ack) GEL_TextOut("Reg read error for PHY: %d\n",,,,, phy_addr); } #define PHYREG0_waitResultsAck( results, ack ) { \ results = CSL_FEXT( MDIO_USER_ACCESS_REG, CSL_MDIO_USER_ACCESS_REG_DATA_SHIFT, CSL_MDIO_USER_ACCESS_REG_DATA_MASK); \ ack = CSL_FEXT( MDIO_USER_ACCESS_REG, CSL_MDIO_USER_ACCESS_REG_ACK_SHIFT, CSL_MDIO_USER_ACCESS_REG_ACK_MASK); } phy_miiread (unsigned short phyaddr, unsigned short page, unsigned int addr, unsigned short *val) { phy_hwwrite(phyaddr, PHY_REG_PAGE_ADDR, page); phy_hwread(phyaddr, addr, val); } phy_miiwrite(unsigned short phyaddr, unsigned short page, unsigned short addr, unsigned short val) { phy_hwwrite(phyaddr, PHY_REG_PAGE_ADDR, page); phy_hwwrite(phyaddr, addr, val); } setupPhy(unsigned short phyaddr) { unsigned short val = 0; unsigned int delay = 0x40000; unsigned int i = 0; GEL_TextOut("Staring Setup for PHY: %d\n",,,,, phyaddr); /* PHY settings as per Release Note, Errata section 3.1 */ phy_hwwrite(phyaddr, 22, 0x00ff); phy_hwwrite(phyaddr, 17, 0x214B); phy_hwwrite(phyaddr, 16, 0x2144); phy_hwwrite(phyaddr, 17, 0x0C28); phy_hwwrite(phyaddr, 16, 0x2146); phy_hwwrite(phyaddr, 17, 0xB233); phy_hwwrite(phyaddr, 16, 0x214D); phy_hwwrite(phyaddr, 17, 0xCC0C); phy_hwwrite(phyaddr, 16, 0x2159); phy_hwwrite(phyaddr, 22, 0x0000); /* Set SGMII to Copper mode Page 18, Reg 20.2:0 = 1 */ phy_hwwrite(phyaddr, 22, 18); phy_hwwrite(phyaddr, 20, 0x1); /* PHY Reset Page 18, Reg 20.15 = 1 */ phy_hwwrite(phyaddr, 20, 0x8201); phy_hwwrite(phyaddr, 22, 00); GEL_TextOut("Wait a moment for copper link up for PHY: %d\n",,,,, phyaddr); for(i = 0; i < delay; i++); //fix: need to add phy link register read code here GEL_TextOut("Configuration Completed for PHY: %d\n",,,,, phyaddr); } /**************************************************************************** * * NAME * SetupPhy * * PURPOSE: * Setup Marvell 88e1514 default settings. * * USAGE * This routine shall be called before using external network on Port 0 * Or Port 1 (RJ45 ports) with K2L evm. * * RETURN VALUE * NONE * * REFERENCE * ****************************************************************************/ hotmenu SetupPhy0() { MDIO_USER_CONTROL_REG = (1 << 30) | 0xFA; MDIO_USER_INT_MASK_REG = 0x00; setupPhy(0); } hotmenu SetupPhy1() { MDIO_USER_CONTROL_REG = (1 << 30) | 0xFA; MDIO_USER_INT_MASK_REG = 0x00; setupPhy(1); } menuitem "DSP CLOCK Estimation"; #define TIMER_TSC (1) // The timer used for polling TSCH/TSCL #define TIMER_TSC_POLL_PERIOD (10) // Every 10 seconds unsigned int gPollPeriod = TIMER_TISC_POLL_PERIOD; unsigned int gTSCL = 0; unsigned int gTSCH = 0; // Global var for holding previous read of TSCL/H unsigned int gNumberPoll=0; // Number of pulling */ unsigned int gLoopCount=0; hotmenu dspEnableTsc() { //GEL_TextOut( "dspEnableTsc - write a value to TSCL to enable it\n" ); if( GEL_IsHalted() ) { TSCL = 0; // A write to TSCL will enable TSC (timestamp counter) GEL_Run(); } else { GEL_Halt(); TSCL = 0; GEL_Run(); } } hotmenu dspDumpTsc() { unsigned int tscl, tsch; tscl = TSCL; /* note: need to read TSCL first */ tsch = TSCH; GEL_TextOut( "dspEnableTsc - TSCH=%x, TSCL=%x\n",,,,, tscl, tsch ); } dspPollTsc() { unsigned int tscl, tsch; unsigned long long tsc1, tsc2; if( gLoopCount <= gNumberPoll) { //GEL_EnableRealtime(); GEL_Halt(); tscl = TSCL; /* The read time can be considered as variations */ tsch = TSCH; /* The read won't cause variation */ //GEL_DisableRealtime(); GEL_Run(); tsc2 = (((unsigned long long) tsch)<<32) + tscl; tsc1 = (((unsigned long long)gTSCH)<<32) + gTSCL; gTSCL = tscl; gTSCH = tsch; //tsc1 = (tsc2-tsc1)/TIMER_TSC_POLL_PERIOD; tsc1 = (tsc2-tsc1)/gPollPeriod; GEL_TextOut( "dspPollTsc - [TSCH,TSCL] = [%x, %x], freq=%dhz, i=%d\n",,,,, gTSCH, gTSCL, (tsc1), gLoopCount); } if( gLoopCount>=gNumberPoll ) { dspCancelTscTimer(); } else { gLoopCount++; } } // // To cancel the Timer - TIMER_TSC, after using it. Otherwise, it will continue running. // hotmenu dspCancelTscTimer() { GEL_TextOut( "dspCancelTscTimer\n"); GEL_CancelTimer( TIMER_TSC ); } // // To poll the DSP clock. // dialog dspPollDSPClockFreq( pollPeriod "Polling period (sec) - the longer, the more accurate!", numberOfPoll "Number of Polls" ) { gPollPeriod = pollPeriod; GEL_TextOut( "dspPollDSPClockFreq with - pollPeriod=%dsec, numberOfPoll=%d\n" ,,,,, gPollPeriod, numberOfPoll); gNumberPoll = numberOfPoll-1; gLoopCount = 0; dspEnableTsc(); // Get the initial value of TSC //GEL_EnableRealtime(); GEL_Halt(); gTSCL = TSCL; /* The read time can be considered as variations */ gTSCH = TSCH; /* The read won't cause variation */ //GEL_DisableRealtime(); GEL_Run(); GEL_SetTimer( gPollPeriod*1000, TIMER_TSC, "dspPollTsc()"); }