mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-14 17:07:38 +00:00
60abbadfc0
Add driver for StarFive JH7110 to support ddr initialization in SPL. Signed-off-by: Yanhong Wang <yanhong.wang@starfivetech.com> Tested-by: Conor Dooley <conor.dooley@microchip.com>
383 lines
3.4 KiB
C
383 lines
3.4 KiB
C
// SPDX-License-Identifier: GPL-2.0+
|
|
/*
|
|
* Copyright (C) 2022 StarFive Technology Co., Ltd.
|
|
* Author: Yanhong Wang<yanhong.wang@starfivetech.com>
|
|
*/
|
|
|
|
#include <common.h>
|
|
#include <asm/io.h>
|
|
|
|
static const u32 ddr_train_data[] = {
|
|
0xb00,
|
|
0x101,
|
|
0x640000,
|
|
0x1,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x1,
|
|
0x7,
|
|
0x10002,
|
|
0x300080f,
|
|
0x1,
|
|
0x5,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x1010000,
|
|
0x280a0000,
|
|
0x0,
|
|
0x1,
|
|
0x3200000f,
|
|
0x0,
|
|
0x0,
|
|
0x10102,
|
|
0x1,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0xaa,
|
|
0x55,
|
|
0xb5,
|
|
0x4a,
|
|
0x56,
|
|
0xa9,
|
|
0xa9,
|
|
0xb5,
|
|
0x1000000,
|
|
0x1000000,
|
|
0x0,
|
|
0xf0f0000,
|
|
0x14,
|
|
0x7d0,
|
|
0x300,
|
|
0x0,
|
|
0x0,
|
|
0x1000000,
|
|
0x10101,
|
|
0x0,
|
|
0x30000,
|
|
0x100,
|
|
0x170f,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0xa140a01,
|
|
0x204010a,
|
|
0x2080510,
|
|
0x40400,
|
|
0x1000101,
|
|
0x10100,
|
|
0x2040f00,
|
|
0x34000000,
|
|
0x0,
|
|
0x0,
|
|
0x1000000,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x10100,
|
|
0x80101,
|
|
0x2000200,
|
|
0x1000100,
|
|
0x1000000,
|
|
0x2000200,
|
|
0x200,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0xe000004,
|
|
0xc0d100f,
|
|
0xa09080b,
|
|
0x2010000,
|
|
0x80103,
|
|
0x200,
|
|
0x0,
|
|
0xf000000,
|
|
0x4,
|
|
0xa,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x30100,
|
|
0x1010001,
|
|
0x10200,
|
|
0x4000103,
|
|
0x1050001,
|
|
0x10600,
|
|
0x107,
|
|
0x0,
|
|
0x0,
|
|
0x10001,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x10000,
|
|
0x4,
|
|
0x0,
|
|
0x10000,
|
|
0x0,
|
|
0x3c0003,
|
|
0x80100a0,
|
|
0x16,
|
|
0x2c,
|
|
0x33,
|
|
0x20043,
|
|
0x2000200,
|
|
0x4,
|
|
0x60c,
|
|
0xa1400,
|
|
0x280000,
|
|
0x6,
|
|
0x46,
|
|
0x70,
|
|
0x610,
|
|
0x12b,
|
|
0x4001035,
|
|
0x1010404,
|
|
0x1e01,
|
|
0x1e001e,
|
|
0x1000100,
|
|
0x100,
|
|
0x0,
|
|
0x5060403,
|
|
0x1011108,
|
|
0x1010101,
|
|
0xf0a0a,
|
|
0x0,
|
|
0x0,
|
|
0x4000000,
|
|
0x4021008,
|
|
0x4020206,
|
|
0xc0034,
|
|
0x100038,
|
|
0x17003f,
|
|
0x10001,
|
|
0x10001,
|
|
0x10005,
|
|
0x20064,
|
|
0x100010b,
|
|
0x60006,
|
|
0x650100,
|
|
0x1000065,
|
|
0x10c010c,
|
|
0x1e1a1e1a,
|
|
0x1011e1a,
|
|
0xa070601,
|
|
0xa07060d,
|
|
0x100b080d,
|
|
0xc00f,
|
|
0xc01000,
|
|
0xc01000,
|
|
0x21000,
|
|
0x120005,
|
|
0x190064,
|
|
0x10b,
|
|
0x1100,
|
|
0x1e1a0056,
|
|
0x6000101,
|
|
0x130204,
|
|
0x1e1a0058,
|
|
0x1000101,
|
|
0x230408,
|
|
0x1e1a005e,
|
|
0x9000101,
|
|
0x610,
|
|
0x4040800,
|
|
0x40100,
|
|
0x3000277,
|
|
0xa032001,
|
|
0xa0a,
|
|
0x80908,
|
|
0x901,
|
|
0x1100315c,
|
|
0xa062002,
|
|
0xa0a,
|
|
0x141708,
|
|
0x150d,
|
|
0x2d00838e,
|
|
0xf102004,
|
|
0xf0b,
|
|
0x8c,
|
|
0x578,
|
|
0xc20,
|
|
0x7940,
|
|
0x206a,
|
|
0x14424,
|
|
0x730006,
|
|
0x3030133,
|
|
0x4,
|
|
0x0,
|
|
0x4,
|
|
0x1,
|
|
0x5,
|
|
0x2,
|
|
0x6,
|
|
0x50,
|
|
0x1,
|
|
0x5,
|
|
0x28,
|
|
0x73,
|
|
0xd6,
|
|
0x1,
|
|
0x5,
|
|
0x6b,
|
|
0x1000133,
|
|
0x140040,
|
|
0x10001,
|
|
0x1900040,
|
|
0x1000c,
|
|
0x42b0040,
|
|
0x320,
|
|
0x360014,
|
|
0x1010101,
|
|
0x2020101,
|
|
0x8080404,
|
|
0x67676767,
|
|
0x67676767,
|
|
0x67676767,
|
|
0x67676767,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x5500,
|
|
0x5a00,
|
|
0x55003c,
|
|
0x0,
|
|
0x3c00005a,
|
|
0x5500,
|
|
0x5a00,
|
|
0x55003c,
|
|
0x0,
|
|
0x3c00005a,
|
|
0x18171615,
|
|
0x14131211,
|
|
0x7060504,
|
|
0x3020100,
|
|
0x0,
|
|
0x0,
|
|
0x0,
|
|
0x1000000,
|
|
0x4020201,
|
|
0x80804,
|
|
0x0,
|
|
0x4,
|
|
0x0,
|
|
0x31,
|
|
0x31,
|
|
0x0,
|
|
0x0,
|
|
0x4d4d,
|
|
0x0,
|
|
0x14,
|
|
0x9,
|
|
0x31,
|
|
0x31,
|
|
0x0,
|
|
0x0,
|
|
0x4d4d,
|
|
0x0,
|
|
0x34,
|
|
0x1b,
|
|
0x31,
|
|
0x31,
|
|
0x0,
|
|
0x0,
|
|
0x4d4d,
|
|
0x0,
|
|
0x4,
|
|
0x0,
|
|
0x31,
|
|
0x31,
|
|
0x0,
|
|
0x0,
|
|
0x4d4d,
|
|
0x0,
|
|
0x14,
|
|
0x9,
|
|
0x31,
|
|
0x31,
|
|
0x0,
|
|
0x0,
|
|
0x4d4d,
|
|
0x0,
|
|
0x34,
|
|
0x1b,
|
|
0x31,
|
|
0x31,
|
|
0x0,
|
|
0x0,
|
|
0x4d4d,
|
|
0x0,
|
|
0x4,
|
|
0x0,
|
|
0x31,
|
|
0x31,
|
|
0x0,
|
|
0x0,
|
|
0x4d4d,
|
|
0x0,
|
|
0x14,
|
|
0x9,
|
|
0x31,
|
|
0x31,
|
|
0x0,
|
|
0x0,
|
|
0x4d4d,
|
|
0x0,
|
|
0x34,
|
|
0x1b,
|
|
0x31,
|
|
0x31,
|
|
0x0,
|
|
0x0,
|
|
0x4d4d,
|
|
0x0,
|
|
0x4,
|
|
0x0,
|
|
0x31,
|
|
0x31,
|
|
0x0,
|
|
0x0,
|
|
0x4d4d,
|
|
0x0,
|
|
0x14,
|
|
0x9,
|
|
0x31,
|
|
0x31,
|
|
0x0,
|
|
0x0,
|
|
0x4d4d,
|
|
0x0,
|
|
0x34,
|
|
0x1b,
|
|
0x31,
|
|
0x31,
|
|
0x0,
|
|
0x0,
|
|
0x4d4d,
|
|
};
|
|
|
|
void ddr_phy_train(u32 *phyreg)
|
|
{
|
|
u32 i, len;
|
|
|
|
len = ARRAY_SIZE(ddr_train_data);
|
|
for (i = 0; i < len; i++)
|
|
out_le32(phyreg + i, ddr_train_data[i]);
|
|
}
|