1
0
Fork 0
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

99 lines
2.3 KiB

// SPDX-License-Identifier: GPL-2.0
/*
* Copyright (c) 2020 Rockchip Electronics Co., Ltd
*/
#include <common.h>
#include <dm.h>
#include <ram.h>
#include <asm/io.h>
#include <asm/arch/param.h>
#include <asm/arch/rk_atags.h>
DECLARE_GLOBAL_DATA_PTR;
static void fpga_init_atags(void)
{
#ifdef CONFIG_FPGA_RAM
struct tag_ram_partition t_ram_part;
#endif
struct tag_bootdev t_bootdev;
struct tag_ddr_mem t_ddrmem;
struct tag_serial t_serial;
struct tag_tos_mem t_tos;
#if defined(CONFIG_ARM64) || defined(CONFIG_ARM64_BOOT_AARCH32)
struct tag_atf_mem t_atf;
#endif
/* destroy ! */
atags_destroy();
/* serial */
memset(&t_serial, 0, sizeof(t_serial));
t_serial.version = 0;
t_serial.enable = 1;
t_serial.addr = CONFIG_DEBUG_UART_BASE;
t_serial.baudrate = CONFIG_BAUDRATE;
t_serial.m_mode = 0;
t_serial.id = 2;
atags_set_tag(ATAG_SERIAL, &t_serial);
/* ddr memory */
memset(&t_ddrmem, 0, sizeof(t_ddrmem));
t_ddrmem.version = 0;
t_ddrmem.count = 1;
t_ddrmem.bank[0] = CONFIG_SYS_SDRAM_BASE;
t_ddrmem.bank[1] = SZ_1G;
atags_set_tag(ATAG_DDR_MEM, &t_ddrmem);
/* bootdev */
memset(&t_bootdev, 0, sizeof(t_bootdev));
t_bootdev.version = 0;
#ifdef CONFIG_FPGA_RAM
t_bootdev.devtype = BOOT_TYPE_RAM;
#else
t_bootdev.devtype = BOOT_TYPE_EMMC;
#endif
t_bootdev.devnum = 0;
t_bootdev.sdupdate = 0;
atags_set_tag(ATAG_BOOTDEV, &t_bootdev);
/* atf */
#if defined(CONFIG_ARM64) || defined(CONFIG_ARM64_BOOT_AARCH32)
memset(&t_atf, 0, sizeof(t_atf));
t_atf.version = 0;
t_atf.phy_addr = CONFIG_SYS_SDRAM_BASE;
t_atf.size = SZ_1M;
t_atf.flags = 0;
atags_set_tag(ATAG_ATF_MEM, &t_atf);
#endif
/* op-tee */
memset(&t_tos, 0, sizeof(t_tos));
t_tos.version = 0;
strcpy(t_tos.tee_mem.name, "op-tee");
#ifdef CONFIG_ARM64
t_tos.tee_mem.phy_addr = 0x8400000; /* 132M offset */
t_tos.tee_mem.size = 0x1e00000; /* 30M size */
#endif
t_tos.tee_mem.flags = 1;
atags_set_tag(ATAG_TOS_MEM, &t_tos);
#ifdef CONFIG_FPGA_RAM
/* ram part */
memset(&t_ram_part, 0, sizeof(t_ram_part));
t_ram_part.version = 0;
t_ram_part.count = 1;
strcpy(t_ram_part.part[0].name, "boot");
t_ram_part.part[0].start = 0x4000000; /* 64M offset */
t_ram_part.part[0].size = 0x2000000; /* 32M size */
atags_set_tag(ATAG_RAM_PARTITION, &t_ram_part);
#endif
}
int arch_fpga_init(void)
{
fpga_init_atags();
return 0;
}