sdram_rk3308.c 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. // SPDX-License-Identifier: GPL-2.0+ OR BSD-3-Clause
  2. /*
  3. * (C) Copyright 2019 Rockchip Electronics Co., Ltd.
  4. */
  5. #include <common.h>
  6. #include <dm.h>
  7. #include <ram.h>
  8. #include <syscon.h>
  9. #include <asm/arch/grf_rk3308.h>
  10. #include <asm/arch-rockchip/clock.h>
  11. #include <asm/arch-rockchip/sdram.h>
  12. struct dram_info {
  13. struct ram_info info;
  14. struct rk3308_grf *grf;
  15. };
  16. static int rk3308_dmc_probe(struct udevice *dev)
  17. {
  18. struct dram_info *priv = dev_get_priv(dev);
  19. priv->grf = syscon_get_first_range(ROCKCHIP_SYSCON_GRF);
  20. priv->info.base = CFG_SYS_SDRAM_BASE;
  21. priv->info.size = rockchip_sdram_size((phys_addr_t)&priv->grf->os_reg2);
  22. return 0;
  23. }
  24. static int rk3308_dmc_get_info(struct udevice *dev, struct ram_info *info)
  25. {
  26. struct dram_info *priv = dev_get_priv(dev);
  27. *info = priv->info;
  28. return 0;
  29. }
  30. static struct ram_ops rk3308_dmc_ops = {
  31. .get_info = rk3308_dmc_get_info,
  32. };
  33. static const struct udevice_id rk3308_dmc_ids[] = {
  34. { .compatible = "rockchip,rk3308-dmc" },
  35. { }
  36. };
  37. U_BOOT_DRIVER(dmc_rk3308) = {
  38. .name = "rockchip_rk3308_dmc",
  39. .id = UCLASS_RAM,
  40. .of_match = rk3308_dmc_ids,
  41. .ops = &rk3308_dmc_ops,
  42. .probe = rk3308_dmc_probe,
  43. .priv_auto = sizeof(struct dram_info),
  44. };