1*83d290c5STom Rini // SPDX-License-Identifier: GPL-2.0 239aa1a73SJon Loeliger /* 339aa1a73SJon Loeliger * Copyright 2008 Freescale Semiconductor, Inc. 439aa1a73SJon Loeliger */ 539aa1a73SJon Loeliger 639aa1a73SJon Loeliger #include <common.h> 739aa1a73SJon Loeliger 85614e71bSYork Sun #include <fsl_ddr_sdram.h> 95614e71bSYork Sun #include <fsl_ddr_dimm_params.h> 1039aa1a73SJon Loeliger fsl_ddr_board_options(memctl_options_t * popts,dimm_params_t * pdimm,unsigned int ctrl_num)11dfb49108SHaiying Wangvoid fsl_ddr_board_options(memctl_options_t *popts, 12dfb49108SHaiying Wang dimm_params_t *pdimm, 13dfb49108SHaiying Wang unsigned int ctrl_num) 1439aa1a73SJon Loeliger { 1539aa1a73SJon Loeliger /* 1639aa1a73SJon Loeliger * Factors to consider for clock adjust: 1739aa1a73SJon Loeliger * - number of chips on bus 1839aa1a73SJon Loeliger * - position of slot 1939aa1a73SJon Loeliger * - DDR1 vs. DDR2? 2039aa1a73SJon Loeliger * - ??? 2139aa1a73SJon Loeliger * 2239aa1a73SJon Loeliger * This needs to be determined on a board-by-board basis. 2339aa1a73SJon Loeliger * 0110 3/4 cycle late 2439aa1a73SJon Loeliger * 0111 7/8 cycle late 2539aa1a73SJon Loeliger */ 2639aa1a73SJon Loeliger popts->clk_adjust = 7; 2739aa1a73SJon Loeliger 2839aa1a73SJon Loeliger /* 2939aa1a73SJon Loeliger * Factors to consider for CPO: 3039aa1a73SJon Loeliger * - frequency 3139aa1a73SJon Loeliger * - ddr1 vs. ddr2 3239aa1a73SJon Loeliger */ 3339aa1a73SJon Loeliger popts->cpo_override = 10; 3439aa1a73SJon Loeliger 3539aa1a73SJon Loeliger /* 3639aa1a73SJon Loeliger * Factors to consider for write data delay: 3739aa1a73SJon Loeliger * - number of DIMMs 3839aa1a73SJon Loeliger * 3939aa1a73SJon Loeliger * 1 = 1/4 clock delay 4039aa1a73SJon Loeliger * 2 = 1/2 clock delay 4139aa1a73SJon Loeliger * 3 = 3/4 clock delay 4239aa1a73SJon Loeliger * 4 = 1 clock delay 4339aa1a73SJon Loeliger * 5 = 5/4 clock delay 4439aa1a73SJon Loeliger * 6 = 3/2 clock delay 4539aa1a73SJon Loeliger */ 4639aa1a73SJon Loeliger popts->write_data_delay = 3; 4739aa1a73SJon Loeliger 48b4983e16SDave Liu /* 2T timing enable */ 490dd38a35SPriyanka Jain popts->twot_en = 1; 50b4983e16SDave Liu 5139aa1a73SJon Loeliger /* 5239aa1a73SJon Loeliger * Factors to consider for half-strength driver enable: 5339aa1a73SJon Loeliger * - number of DIMMs installed 5439aa1a73SJon Loeliger */ 5539aa1a73SJon Loeliger popts->half_strength_driver_enable = 0; 5639aa1a73SJon Loeliger } 57