mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-17 02:10:10 +00:00
696f0a1cb4
100-ddr-marvell-a38x-fix-BYTE_HOMOGENEOUS_SPLIT_OUT-deci.patch [1]: SoC Marvell A38x is used in Turris Omnia, and we thought that with recent fiddling around DDR training to fix it once for all, there were reproduced the issue in the upcoming new revision Turris Omnia boards. 101-arm-mvebu-spl-Add-option-to-reset-the-board-on-DDR-t.patch [2]: This is useful when some board may occasionally fail with DDR training, and it adds the option to reset the board on the DDR training failure 102-arm-mvebu-turris_omnia-Reset-the-board-immediately-o.patch [3]: This enables the option CONFIG_DDR_RESET_ON_TRAINING_FAILURE (added by 101 patch), so the Turris Omnia board is restarted immediately, and it does not require to reset the board manually or wait 120s for MCU to reset the board [1] https://patchwork.ozlabs.org/project/uboot/patch/20220217000837.13003-1-kabel@kernel.org/ [2] https://patchwork.ozlabs.org/project/uboot/patch/20220217000849.13028-1-kabel@kernel.org/ [3] https://patchwork.ozlabs.org/project/uboot/patch/20220217000849.13028-2-kabel@kernel.org/ Signed-off-by: Josef Schlehofer <pepe.schlehofer@gmail.com>
66 lines
2.6 KiB
Diff
66 lines
2.6 KiB
Diff
From c11428c7def52671f57089701efe878f7071b696 Mon Sep 17 00:00:00 2001
|
|
From: =?UTF-8?q?Marek=20Beh=C3=BAn?= <marek.behun@nic.cz>
|
|
Date: Thu, 17 Feb 2022 01:08:37 +0100
|
|
Subject: [PATCH 1/3] ddr: marvell: a38x: fix BYTE_HOMOGENEOUS_SPLIT_OUT
|
|
decision
|
|
MIME-Version: 1.0
|
|
Content-Type: text/plain; charset=UTF-8
|
|
Content-Transfer-Encoding: 8bit
|
|
|
|
In commit 3fc92a215b69 ("ddr: marvell: a38x: fix SPLIT_OUT_MIX state
|
|
decision") I ported a cleaned up and changed version of patch
|
|
mv_ddr: a380: fix SPLIT_OUT_MIX state decision
|
|
|
|
In the port we removed checking for BYTE_HOMOGENEOUS_SPLIT_OUT bit,
|
|
because:
|
|
- the fix seemed to work without it
|
|
- the bit was checked for only at one place out of two, while the second
|
|
bit, BYTE_SPLIT_OUT_MIX, was checked for in both cases
|
|
- without the removal it didn't work on Allied Telesis' x530 board
|
|
|
|
We recently had a chance to test on more boards, and it seems that the
|
|
change needs to be opposite: instead of removing the check for
|
|
BYTE_HOMOGENEOUS_SPLIT_OUT from the first if() statement, the check
|
|
needs to be added also to the second one - it needs to be at both
|
|
places.
|
|
|
|
With this change all the Turris Omnia boards I have had available to
|
|
test seem to work, I didn't encounter not even one failed DDR training.
|
|
|
|
As last time, I am noting that I do not understand what this code is
|
|
actually doing, I haven't studied the DDR training algorithm and
|
|
I suspect that no one will be able to explain it to U-Boot contributors,
|
|
so we are left with this blind poking in the code with testing whether
|
|
it works on several boards and hoping it doesn't break anything for
|
|
anyone :-(.
|
|
|
|
Signed-off-by: Marek Behún <marek.behun@nic.cz>
|
|
Tested-by: Chris Packham <judge.packham@gmail.com>
|
|
Reviewed-by: Stefan Roese <sr@denx.de>
|
|
---
|
|
drivers/ddr/marvell/a38x/ddr3_training_centralization.c | 6 ++++--
|
|
1 file changed, 4 insertions(+), 2 deletions(-)
|
|
|
|
--- a/drivers/ddr/marvell/a38x/ddr3_training_centralization.c
|
|
+++ b/drivers/ddr/marvell/a38x/ddr3_training_centralization.c
|
|
@@ -180,7 +180,8 @@ static int ddr3_tip_centralization(u32 d
|
|
[bit_id],
|
|
EDGE_1);
|
|
if (current_byte_status &
|
|
- BYTE_SPLIT_OUT_MIX) {
|
|
+ (BYTE_SPLIT_OUT_MIX |
|
|
+ BYTE_HOMOGENEOUS_SPLIT_OUT)) {
|
|
if (cur_start_win[bit_id] >= 64)
|
|
cur_start_win[bit_id] -= 64;
|
|
else
|
|
@@ -197,7 +198,8 @@ static int ddr3_tip_centralization(u32 d
|
|
EDGE_1);
|
|
if (cur_end_win[bit_id] >= 64 &&
|
|
(current_byte_status &
|
|
- BYTE_SPLIT_OUT_MIX)) {
|
|
+ (BYTE_SPLIT_OUT_MIX |
|
|
+ BYTE_HOMOGENEOUS_SPLIT_OUT))) {
|
|
cur_end_win[bit_id] -= 64;
|
|
DEBUG_CENTRALIZATION_ENGINE
|
|
(DEBUG_LEVEL_INFO,
|