mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-08 11:18:53 +00:00
aa6e94deab
The rest of the unmigrated CONFIG symbols in the CONFIG_SYS_SDRAM namespace do not easily transition to Kconfig. In many cases they likely should come from the device tree instead. Move these out of CONFIG namespace and in to CFG namespace. Signed-off-by: Tom Rini <trini@konsulko.com> Reviewed-by: Simon Glass <sjg@chromium.org>
58 lines
1.2 KiB
C
58 lines
1.2 KiB
C
// SPDX-License-Identifier: GPL-2.0+ OR BSD-3-Clause
|
|
/*
|
|
* (C) Copyright 2017 Rockchip Electronics Co., Ltd.
|
|
*/
|
|
|
|
#include <common.h>
|
|
#include <dm.h>
|
|
#include <log.h>
|
|
#include <ram.h>
|
|
#include <syscon.h>
|
|
#include <asm/arch-rockchip/clock.h>
|
|
#include <asm/arch-rockchip/grf_rk3128.h>
|
|
#include <asm/arch-rockchip/sdram.h>
|
|
|
|
struct dram_info {
|
|
struct ram_info info;
|
|
struct rk3128_grf *grf;
|
|
};
|
|
|
|
static int rk3128_dmc_probe(struct udevice *dev)
|
|
{
|
|
struct dram_info *priv = dev_get_priv(dev);
|
|
|
|
priv->grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
|
|
debug("%s: grf=%p\n", __func__, priv->grf);
|
|
priv->info.base = CFG_SYS_SDRAM_BASE;
|
|
priv->info.size = rockchip_sdram_size(
|
|
(phys_addr_t)&priv->grf->os_reg[1]);
|
|
|
|
return 0;
|
|
}
|
|
|
|
static int rk3128_dmc_get_info(struct udevice *dev, struct ram_info *info)
|
|
{
|
|
struct dram_info *priv = dev_get_priv(dev);
|
|
|
|
*info = priv->info;
|
|
|
|
return 0;
|
|
}
|
|
|
|
static struct ram_ops rk3128_dmc_ops = {
|
|
.get_info = rk3128_dmc_get_info,
|
|
};
|
|
|
|
static const struct udevice_id rk3128_dmc_ids[] = {
|
|
{ .compatible = "rockchip,rk3128-dmc" },
|
|
{ }
|
|
};
|
|
|
|
U_BOOT_DRIVER(dmc_rk3128) = {
|
|
.name = "rockchip_rk3128_dmc",
|
|
.id = UCLASS_RAM,
|
|
.of_match = rk3128_dmc_ids,
|
|
.ops = &rk3128_dmc_ops,
|
|
.probe = rk3128_dmc_probe,
|
|
.priv_auto = sizeof(struct dram_info),
|
|
};
|