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