mt8173: dram: Add more sample points to improve dram timing margin
BRANCH=none BUG=chrome-os-partner:52959 TEST=verified on elm-EVT SKU1/SKU2, Oak-rev5 2GB/4GB models. Change-Id: I228c629d9a3d6cd8fc5c4e8ba24cc52d5283b4e6 Signed-off-by: Martin Roth <martinroth@chromium.org> Original-Commit-Id: 3c19e7d Original-Change-Id: I22356aa8d196c4c126742cfc7e85cc693acd9b39 Original-Signed-off-by: PH Hsu <ph.hsu@mediatek.com> Original-Reviewed-on: https://chromium-review.googlesource.com/347716 Original-Commit-Ready: Yidi Lin <yidi.lin@mediatek.com> Original-Tested-by: Yidi Lin <yidi.lin@mediatek.com> Original-Reviewed-by: Julius Werner <jwerner@chromium.org> Reviewed-on: https://review.coreboot.org/15115 Tested-by: build bot (Jenkins) Reviewed-by: Furquan Shaikh <furquan@google.com>
This commit is contained in:
parent
99f065fb6e
commit
cf6526c211
5 changed files with 36 additions and 33 deletions
|
@ -21,12 +21,12 @@
|
|||
|
||||
.gating_win = {
|
||||
[CHANNEL_A] = {
|
||||
{ 28, 56},
|
||||
{ 28, 56}
|
||||
{ 28, 64},
|
||||
{ 28, 64}
|
||||
},
|
||||
[CHANNEL_B] = {
|
||||
{ 28, 56},
|
||||
{ 28, 56}
|
||||
{ 28, 64},
|
||||
{ 28, 64}
|
||||
}
|
||||
},
|
||||
|
||||
|
|
|
@ -21,11 +21,11 @@
|
|||
|
||||
.gating_win = {
|
||||
[CHANNEL_A] = {
|
||||
{ 28, 56},
|
||||
{ 28, 64},
|
||||
{ 0, 0}
|
||||
},
|
||||
[CHANNEL_B] = {
|
||||
{ 28, 56},
|
||||
{ 28, 64},
|
||||
{ 0, 0}
|
||||
}
|
||||
},
|
||||
|
|
|
@ -21,18 +21,18 @@
|
|||
|
||||
.gating_win = {
|
||||
[CHANNEL_A] = {
|
||||
{ 28, 56},
|
||||
{ 28, 56}
|
||||
{ 28, 64},
|
||||
{ 28, 64}
|
||||
},
|
||||
[CHANNEL_B] = {
|
||||
{ 28, 56},
|
||||
{ 28, 56}
|
||||
{ 28, 64},
|
||||
{ 28, 64}
|
||||
}
|
||||
},
|
||||
|
||||
.rx_dqs_dly = {
|
||||
[CHANNEL_A] = 0x110e0b0b,
|
||||
[CHANNEL_B] = 0x12100d0d
|
||||
[CHANNEL_B] = 0x0D100d0d
|
||||
},
|
||||
|
||||
.rx_dq_dly = {
|
||||
|
|
|
@ -539,8 +539,11 @@ void dramc_init(u32 channel, const struct mt8173_sdram_params *sdram_params)
|
|||
write32(&ch[channel].ao_regs->conf1,
|
||||
sdram_params->ac_timing.conf1);
|
||||
|
||||
/* bit 17,18 would bypass some dummy path */
|
||||
write32(&ch[channel].ddrphy_regs->dqsgctl, 0x1 << 31 |
|
||||
0x1 << 30 |
|
||||
0x1 << 17 |
|
||||
0x1 << 18 |
|
||||
0x1 << 4 |
|
||||
0x1 << 0);
|
||||
|
||||
|
@ -691,6 +694,9 @@ void dramc_phy_reset(u32 channel)
|
|||
void dramc_runtime_config(u32 channel,
|
||||
const struct mt8173_sdram_params *sdram_params)
|
||||
{
|
||||
setbits_le32(&ch[channel].ddrphy_regs->dqsgctl,
|
||||
BIT(17)|BIT(18));
|
||||
|
||||
/* enable hw gating */
|
||||
setbits_le32(&ch[channel].ao_regs->dqscal0,
|
||||
1 << DQSCAL0_STBCALEN_SHIFT);
|
||||
|
|
|
@ -13,9 +13,9 @@
|
|||
* GNU General Public License for more details.
|
||||
*/
|
||||
|
||||
#include <delay.h>
|
||||
#include <boardid.h>
|
||||
#include <arch/io.h>
|
||||
#include <assert.h>
|
||||
#include <delay.h>
|
||||
#include <stdlib.h>
|
||||
#include <soc/addressmap.h>
|
||||
#include <soc/dramc_common.h>
|
||||
|
@ -305,31 +305,27 @@ static int dqs_gw_test(u32 channel)
|
|||
static u8 dqs_gw_fine_tune_calib(u32 channel, u8 fine_val)
|
||||
{
|
||||
u8 i, opt_fine_val;
|
||||
s8 gw_ret[3], delta[3] = {0, -16, 16};
|
||||
s8 delta[7] = {-48, -32, -16, 0, 16, 32, 48};
|
||||
int matches = 0, sum = 0;
|
||||
|
||||
for (i = 0; i < 3; i++) {
|
||||
/* adjust gw fine tune */
|
||||
/* fine tune range from 0 to 127 */
|
||||
fine_val = min(max(fine_val, 0 - delta[0]), 127 - delta[6]);
|
||||
|
||||
/* test gw fine tune */
|
||||
for (i = 0; i < ARRAY_SIZE(delta); i++) {
|
||||
opt_fine_val = fine_val + delta[i];
|
||||
set_gw_fine_factor(channel, opt_fine_val, 0);
|
||||
/* get gw test result */
|
||||
gw_ret[i] = dqs_gw_test(channel);
|
||||
if (dqs_gw_test(channel)) {
|
||||
matches++;
|
||||
sum += delta[i];
|
||||
}
|
||||
}
|
||||
|
||||
/* start fine tune adjustment from default fine value */
|
||||
opt_fine_val = fine_val;
|
||||
if (matches == 0) {
|
||||
die("[GW] ERROR, Fine-Tuning failed.\n");
|
||||
}
|
||||
|
||||
if (gw_ret[0] && gw_ret[1] && gw_ret[2]) {
|
||||
opt_fine_val += ((delta[0] + delta[1] + delta[2]) / 3);
|
||||
}
|
||||
else if (gw_ret[0] && gw_ret[1]) {
|
||||
opt_fine_val += ((delta[0] + delta[1]) / 2);
|
||||
}
|
||||
else if (gw_ret[0] && gw_ret[2]) {
|
||||
opt_fine_val += ((delta[0] + delta[2]) / 2);
|
||||
}
|
||||
else { /* abnormal test result, set to default fine tune value */
|
||||
printk(BIOS_ERR, "[GW] ERROR, No found fine tune!!!\n");
|
||||
}
|
||||
opt_fine_val = fine_val + (sum / matches);
|
||||
|
||||
return opt_fine_val;
|
||||
}
|
||||
|
@ -737,7 +733,8 @@ u8 rx_datlat_cal(u32 channel, u8 rank,
|
|||
|
||||
if (err[0]) {
|
||||
/* dle test error */
|
||||
printk(BIOS_ERR, "[DLE] calibration ERROR!\n");
|
||||
printk(BIOS_ERR, "[DLE] CH:%d calibration ERROR CMP_ERR =%xh,\n",
|
||||
channel, err[0]);
|
||||
} else {
|
||||
/* judge dle test result */
|
||||
for (i = 0; i < DLE_TEST_NUM; i++) {
|
||||
|
|
Loading…
Reference in a new issue