reset-mtmips.c 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (C) 2019 MediaTek Inc. All Rights Reserved.
  4. *
  5. * Author: Weijie Gao <weijie.gao@mediatek.com>
  6. */
  7. #include <common.h>
  8. #include <dm.h>
  9. #include <errno.h>
  10. #include <log.h>
  11. #include <malloc.h>
  12. #include <reset-uclass.h>
  13. #include <linux/bitops.h>
  14. #include <linux/io.h>
  15. struct mtmips_reset_priv {
  16. void __iomem *base;
  17. };
  18. static int mtmips_reset_assert(struct reset_ctl *reset_ctl)
  19. {
  20. struct mtmips_reset_priv *priv = dev_get_priv(reset_ctl->dev);
  21. setbits_32(priv->base, BIT(reset_ctl->id));
  22. return 0;
  23. }
  24. static int mtmips_reset_deassert(struct reset_ctl *reset_ctl)
  25. {
  26. struct mtmips_reset_priv *priv = dev_get_priv(reset_ctl->dev);
  27. clrbits_32(priv->base, BIT(reset_ctl->id));
  28. return 0;
  29. }
  30. static const struct reset_ops mtmips_reset_ops = {
  31. .rst_assert = mtmips_reset_assert,
  32. .rst_deassert = mtmips_reset_deassert,
  33. };
  34. static int mtmips_reset_probe(struct udevice *dev)
  35. {
  36. return 0;
  37. }
  38. static int mtmips_reset_of_to_plat(struct udevice *dev)
  39. {
  40. struct mtmips_reset_priv *priv = dev_get_priv(dev);
  41. priv->base = (void __iomem *)dev_remap_addr_index(dev, 0);
  42. if (!priv->base)
  43. return -EINVAL;
  44. return 0;
  45. }
  46. static const struct udevice_id mtmips_reset_ids[] = {
  47. { .compatible = "mediatek,mtmips-reset" },
  48. { }
  49. };
  50. U_BOOT_DRIVER(mtmips_reset) = {
  51. .name = "mtmips-reset",
  52. .id = UCLASS_RESET,
  53. .of_match = mtmips_reset_ids,
  54. .of_to_plat = mtmips_reset_of_to_plat,
  55. .probe = mtmips_reset_probe,
  56. .priv_auto = sizeof(struct mtmips_reset_priv),
  57. .ops = &mtmips_reset_ops,
  58. .flags = DM_FLAG_PRE_RELOC,
  59. };