serial_rockchip.c 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (c) 2015 Google, Inc
  4. */
  5. #include <common.h>
  6. #include <debug_uart.h>
  7. #include <dm.h>
  8. #include <dt-structs.h>
  9. #include <ns16550.h>
  10. #include <serial.h>
  11. #include <asm/arch-rockchip/clock.h>
  12. #include <dm/device-internal.h>
  13. struct rockchip_uart_plat {
  14. #if CONFIG_IS_ENABLED(OF_PLATDATA)
  15. struct dtd_rockchip_uart dtplat;
  16. #endif
  17. struct ns16550_plat plat;
  18. };
  19. #if CONFIG_IS_ENABLED(OF_PLATDATA)
  20. struct dtd_rockchip_uart *dtplat, s_dtplat;
  21. #endif
  22. static int rockchip_serial_probe(struct udevice *dev)
  23. {
  24. #if CONFIG_IS_ENABLED(OF_PLATDATA)
  25. struct rockchip_uart_plat *plat = dev_get_plat(dev);
  26. /* Create some new platform data for the standard driver */
  27. plat->plat.base = plat->dtplat.reg[0];
  28. plat->plat.reg_shift = plat->dtplat.reg_shift;
  29. plat->plat.clock = plat->dtplat.clock_frequency;
  30. plat->plat.fcr = UART_FCR_DEFVAL;
  31. dev_set_plat(dev, &plat->plat);
  32. return ns16550_serial_probe(dev);
  33. #else
  34. return -ENODEV;
  35. #endif
  36. }
  37. U_BOOT_DRIVER(rockchip_uart) = {
  38. .name = "rockchip_uart",
  39. .id = UCLASS_SERIAL,
  40. .priv_auto = sizeof(struct ns16550),
  41. .plat_auto = sizeof(struct rockchip_uart_plat),
  42. .probe = rockchip_serial_probe,
  43. .ops = &ns16550_serial_ops,
  44. .flags = DM_FLAG_PRE_RELOC,
  45. };
  46. DM_DRIVER_ALIAS(rockchip_uart, rockchip_rk3066_uart)
  47. DM_DRIVER_ALIAS(rockchip_uart, rockchip_rk3188_uart)
  48. DM_DRIVER_ALIAS(rockchip_uart, rockchip_rk3288_uart)
  49. DM_DRIVER_ALIAS(rockchip_uart, rockchip_rk3328_uart)
  50. DM_DRIVER_ALIAS(rockchip_uart, rockchip_rk3368_uart)