reset-spacemit-common.c 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /* SpacemiT reset controller driver - common implementation */
  3. #include <linux/container_of.h>
  4. #include <linux/device.h>
  5. #include <linux/module.h>
  6. #include <soc/spacemit/ccu.h>
  7. #include "reset-spacemit-common.h"
  8. static int spacemit_reset_update(struct reset_controller_dev *rcdev,
  9. unsigned long id, bool assert)
  10. {
  11. struct ccu_reset_controller *controller;
  12. const struct ccu_reset_data *data;
  13. u32 mask;
  14. u32 val;
  15. controller = container_of(rcdev, struct ccu_reset_controller, rcdev);
  16. data = &controller->data->reset_data[id];
  17. mask = data->assert_mask | data->deassert_mask;
  18. val = assert ? data->assert_mask : data->deassert_mask;
  19. return regmap_update_bits(controller->regmap, data->offset, mask, val);
  20. }
  21. static int spacemit_reset_assert(struct reset_controller_dev *rcdev,
  22. unsigned long id)
  23. {
  24. return spacemit_reset_update(rcdev, id, true);
  25. }
  26. static int spacemit_reset_deassert(struct reset_controller_dev *rcdev,
  27. unsigned long id)
  28. {
  29. return spacemit_reset_update(rcdev, id, false);
  30. }
  31. static const struct reset_control_ops spacemit_reset_control_ops = {
  32. .assert = spacemit_reset_assert,
  33. .deassert = spacemit_reset_deassert,
  34. };
  35. static int spacemit_reset_controller_register(struct device *dev,
  36. struct ccu_reset_controller *controller)
  37. {
  38. struct reset_controller_dev *rcdev = &controller->rcdev;
  39. rcdev->ops = &spacemit_reset_control_ops;
  40. rcdev->owner = dev->driver->owner;
  41. rcdev->of_node = dev->of_node;
  42. rcdev->nr_resets = controller->data->count;
  43. return devm_reset_controller_register(dev, &controller->rcdev);
  44. }
  45. int spacemit_reset_probe(struct auxiliary_device *adev,
  46. const struct auxiliary_device_id *id)
  47. {
  48. struct spacemit_ccu_adev *rdev = to_spacemit_ccu_adev(adev);
  49. struct ccu_reset_controller *controller;
  50. struct device *dev = &adev->dev;
  51. controller = devm_kzalloc(dev, sizeof(*controller), GFP_KERNEL);
  52. if (!controller)
  53. return -ENOMEM;
  54. controller->data = (const struct ccu_reset_controller_data *)id->driver_data;
  55. controller->regmap = rdev->regmap;
  56. return spacemit_reset_controller_register(dev, controller);
  57. }
  58. EXPORT_SYMBOL_NS_GPL(spacemit_reset_probe, "RESET_SPACEMIT");
  59. MODULE_DESCRIPTION("SpacemiT reset controller driver - common code");
  60. MODULE_LICENSE("GPL");