reset-bcm6345.c 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2017 Álvaro Fernández Rojas <noltari@gmail.com>
  4. *
  5. * Derived from linux/arch/mips/bcm63xx/reset.c:
  6. * Copyright (C) 2012 Jonas Gorski <jonas.gorski@gmail.com>
  7. */
  8. #include <common.h>
  9. #include <dm.h>
  10. #include <errno.h>
  11. #include <log.h>
  12. #include <malloc.h>
  13. #include <reset-uclass.h>
  14. #include <asm/io.h>
  15. #include <linux/bitops.h>
  16. #include <linux/delay.h>
  17. #define MAX_RESETS 32
  18. struct bcm6345_reset_priv {
  19. void __iomem *regs;
  20. };
  21. static int bcm6345_reset_assert(struct reset_ctl *rst)
  22. {
  23. struct bcm6345_reset_priv *priv = dev_get_priv(rst->dev);
  24. clrbits_be32(priv->regs, BIT(rst->id));
  25. mdelay(20);
  26. return 0;
  27. }
  28. static int bcm6345_reset_deassert(struct reset_ctl *rst)
  29. {
  30. struct bcm6345_reset_priv *priv = dev_get_priv(rst->dev);
  31. setbits_be32(priv->regs, BIT(rst->id));
  32. mdelay(20);
  33. return 0;
  34. }
  35. static int bcm6345_reset_request(struct reset_ctl *rst)
  36. {
  37. if (rst->id >= MAX_RESETS)
  38. return -EINVAL;
  39. return bcm6345_reset_assert(rst);
  40. }
  41. struct reset_ops bcm6345_reset_reset_ops = {
  42. .request = bcm6345_reset_request,
  43. .rst_assert = bcm6345_reset_assert,
  44. .rst_deassert = bcm6345_reset_deassert,
  45. };
  46. static const struct udevice_id bcm6345_reset_ids[] = {
  47. { .compatible = "brcm,bcm6345-reset" },
  48. { /* sentinel */ }
  49. };
  50. static int bcm6345_reset_probe(struct udevice *dev)
  51. {
  52. struct bcm6345_reset_priv *priv = dev_get_priv(dev);
  53. priv->regs = dev_remap_addr(dev);
  54. if (!priv->regs)
  55. return -EINVAL;
  56. return 0;
  57. }
  58. U_BOOT_DRIVER(bcm6345_reset) = {
  59. .name = "bcm6345-reset",
  60. .id = UCLASS_RESET,
  61. .of_match = bcm6345_reset_ids,
  62. .ops = &bcm6345_reset_reset_ops,
  63. .probe = bcm6345_reset_probe,
  64. .priv_auto = sizeof(struct bcm6345_reset_priv),
  65. };