cff009ed6f
Signed-off-by: Daniel Hellstrom <daniel@gaisler.com>
238 lines
5.4 KiB
C
238 lines
5.4 KiB
C
/* GRLIB Memory controller setup. The register values are used
|
|
* from the associated low level assembler routine implemented
|
|
* in memcfg_low.S.
|
|
*
|
|
* (C) Copyright 2010, 2015
|
|
* Daniel Hellstrom, Cobham Gaisler, daniel@gaisler.com.
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0+
|
|
*/
|
|
|
|
#include <ambapp.h>
|
|
#include "memcfg.h"
|
|
#include <config.h>
|
|
|
|
#ifdef CONFIG_SYS_GRLIB_ESA_MCTRL1
|
|
struct mctrl_setup esa_mctrl1_cfg = {
|
|
.reg_mask = 0x7,
|
|
.regs = {
|
|
{
|
|
.mask = 0x00000300,
|
|
.value = CONFIG_SYS_GRLIB_ESA_MCTRL1_CFG1,
|
|
},
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_ESA_MCTRL1_CFG2,
|
|
},
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_ESA_MCTRL1_CFG3,
|
|
},
|
|
}
|
|
};
|
|
#ifdef CONFIG_SYS_GRLIB_ESA_MCTRL2
|
|
struct mctrl_setup esa_mctrl2_cfg = {
|
|
.reg_mask = 0x7,
|
|
.regs = {
|
|
{
|
|
.mask = 0x00000300,
|
|
.value = CONFIG_SYS_GRLIB_ESA_MCTRL2_CFG1,
|
|
},
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_ESA_MCTRL2_CFG2,
|
|
},
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_ESA_MCTRL2_CFG3,
|
|
},
|
|
}
|
|
};
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_FTMCTRL1
|
|
struct mctrl_setup gaisler_ftmctrl1_cfg = {
|
|
.reg_mask = 0x7,
|
|
.regs = {
|
|
{
|
|
.mask = 0x00000300,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_FTMCTRL1_CFG1,
|
|
},
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_FTMCTRL1_CFG2,
|
|
},
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_FTMCTRL1_CFG3,
|
|
},
|
|
}
|
|
};
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_FTMCTRL2
|
|
struct mctrl_setup gaisler_ftmctrl2_cfg = {
|
|
.reg_mask = 0x7,
|
|
.regs = {
|
|
{
|
|
.mask = 0x00000300,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_FTMCTRL2_CFG1,
|
|
},
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_FTMCTRL2_CFG2,
|
|
},
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_FTMCTRL2_CFG3,
|
|
},
|
|
}
|
|
};
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_SDCTRL1
|
|
struct mctrl_setup gaisler_sdctrl1_cfg = {
|
|
.reg_mask = 0x1,
|
|
.regs = {
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_SDCTRL1_CTRL,
|
|
},
|
|
}
|
|
};
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_SDCTRL2
|
|
struct mctrl_setup gaisler_sdctrl2_cfg = {
|
|
.reg_mask = 0x1,
|
|
.regs = {
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_SDCTRL2_CTRL,
|
|
},
|
|
}
|
|
};
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_DDR2SPA1
|
|
struct ahbmctrl_setup gaisler_ddr2spa1_cfg = {
|
|
.ahb_mbar_no = 1,
|
|
.reg_mask = 0xd,
|
|
.regs = {
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_DDR2SPA1_CFG1,
|
|
},
|
|
{ 0x00000000, 0},
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_DDR2SPA1_CFG3,
|
|
},
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_DDR2SPA1_CFG4,
|
|
},
|
|
}
|
|
};
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_DDR2SPA2
|
|
struct ahbmctrl_setup gaisler_ddr2spa2_cfg = {
|
|
.ahb_mbar_no = 1,
|
|
.reg_mask = 0xd,
|
|
.regs = {
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_DDR2SPA2_CFG1,
|
|
},
|
|
{ 0x00000000, 0},
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_DDR2SPA2_CFG3,
|
|
},
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_DDR2SPA2_CFG4,
|
|
},
|
|
}
|
|
};
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_DDRSPA1
|
|
struct ahbmctrl_setup gaisler_ddrspa1_cfg = {
|
|
.ahb_mbar_no = 1,
|
|
.reg_mask = 0x1,
|
|
.regs = {
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_DDRSPA1_CTRL,
|
|
},
|
|
}
|
|
};
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_DDRSPA2
|
|
struct ahbmctrl_setup gaisler_ddrspa2_cfg = {
|
|
.ahb_mbar_no = 1,
|
|
.reg_mask = 0x1,
|
|
.regs = {
|
|
{
|
|
.mask = 0x00000000,
|
|
.value = CONFIG_SYS_GRLIB_GAISLER_DDRSPA2_CTRL,
|
|
},
|
|
}
|
|
};
|
|
#endif
|
|
#endif
|
|
|
|
struct grlib_mctrl_handler grlib_mctrl_handlers[] = {
|
|
/* ESA MCTRL (PROM/FLASH/IO/SRAM/SDRAM) */
|
|
#ifdef CONFIG_SYS_GRLIB_ESA_MCTRL1
|
|
{DEV_APB_SLV, 0, MH_UNUSED, AMBA_PNP_ID(VENDOR_ESA, ESA_MCTRL),
|
|
_nomem_mctrl_init, (void *)&esa_mctrl1_cfg},
|
|
#ifdef CONFIG_SYS_GRLIB_ESA_MCTRL2
|
|
{DEV_APB_SLV, 1, MH_UNUSED, AMBA_PNP_ID(VENDOR_ESA, ESA_MCTRL),
|
|
_nomem_mctrl_init, (void *)&esa_mctrl2_cfg},
|
|
#endif
|
|
#endif
|
|
|
|
/* GAISLER Fault Tolerant Memory controller (PROM/FLASH/IO/SRAM/SDRAM) */
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_FTMCTRL1
|
|
{DEV_APB_SLV, 0, MH_UNUSED, AMBA_PNP_ID(VENDOR_GAISLER, GAISLER_FTMCTRL),
|
|
_nomem_mctrl_init, (void *)&gaisler_ftmctrl1_cfg},
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_FTMCTRL2
|
|
{DEV_APB_SLV, 1, MH_UNUSED, AMBA_PNP_ID(VENDOR_GAISLER, GAISLER_FTMCTRL),
|
|
_nomem_mctrl_init, (void *)&gaisler_ftmctrl2_cfg},
|
|
#endif
|
|
#endif
|
|
|
|
/* GAISLER SDRAM-only Memory controller (SDRAM) */
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_SDCTRL1
|
|
{DEV_APB_SLV, 0, MH_UNUSED, AMBA_PNP_ID(VENDOR_GAISLER, GAISLER_SDCTRL),
|
|
_nomem_mctrl_init, (void *)&gaisler_sdctrl1_cfg},
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_SDCTRL2
|
|
{DEV_APB_SLV, 1, MH_UNUSED, AMBA_PNP_ID(VENDOR_GAISLER, GAISLER_SDCTRL),
|
|
_nomem_mctrl_init, (void *)&gaisler_sdctrl2_cfg},
|
|
#endif
|
|
#endif
|
|
|
|
/* GAISLER DDR Memory controller (DDR) */
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_DDRSPA1
|
|
{DEV_AHB_SLV, 0, MH_UNUSED, AMBA_PNP_ID(VENDOR_GAISLER, GAISLER_DDRSP),
|
|
_nomem_ahbmctrl_init, (void *)&gaisler_ddrspa1_cfg},
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_DDRSPA2
|
|
{DEV_AHB_SLV, 1, MH_UNUSED, AMBA_PNP_ID(VENDOR_GAISLER, GAISLER_DDRSP),
|
|
_nomem_ahbmctrl_init, (void *)&gaisler_ddrspa2_cfg},
|
|
#endif
|
|
#endif
|
|
|
|
/* GAISLER DDR2 Memory controller (DDR2) */
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_DDR2SPA1
|
|
{DEV_AHB_SLV, 0, MH_UNUSED, AMBA_PNP_ID(VENDOR_GAISLER, GAISLER_DDR2SP),
|
|
_nomem_ahbmctrl_init, (void *)&gaisler_ddr2spa1_cfg},
|
|
#ifdef CONFIG_SYS_GRLIB_GAISLER_DDR2SPA2
|
|
{DEV_AHB_SLV, 1, MH_UNUSED, AMBA_PNP_ID(VENDOR_GAISLER, GAISLER_DDR2SP),
|
|
_nomem_ahbmctrl_init, (void *)&gaisler_ddr2spa2_cfg},
|
|
#endif
|
|
#endif
|
|
|
|
/* Mark end */
|
|
MH_END
|
|
};
|