ipa_power.h 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /* Copyright (c) 2012-2018, The Linux Foundation. All rights reserved.
  3. * Copyright (C) 2018-2022 Linaro Ltd.
  4. */
  5. #ifndef _IPA_POWER_H_
  6. #define _IPA_POWER_H_
  7. struct device;
  8. struct ipa;
  9. struct ipa_power_data;
  10. /* IPA device power management function block */
  11. extern const struct dev_pm_ops ipa_pm_ops;
  12. /**
  13. * ipa_core_clock_rate() - Return the current IPA core clock rate
  14. * @ipa: IPA structure
  15. *
  16. * Return: The current clock rate (in Hz), or 0.
  17. */
  18. u32 ipa_core_clock_rate(struct ipa *ipa);
  19. /**
  20. * ipa_power_modem_queue_stop() - Possibly stop the modem netdev TX queue
  21. * @ipa: IPA pointer
  22. */
  23. void ipa_power_modem_queue_stop(struct ipa *ipa);
  24. /**
  25. * ipa_power_modem_queue_wake() - Possibly wake the modem netdev TX queue
  26. * @ipa: IPA pointer
  27. */
  28. void ipa_power_modem_queue_wake(struct ipa *ipa);
  29. /**
  30. * ipa_power_modem_queue_active() - Report modem netdev TX queue active
  31. * @ipa: IPA pointer
  32. */
  33. void ipa_power_modem_queue_active(struct ipa *ipa);
  34. /**
  35. * ipa_power_retention() - Control register retention on power collapse
  36. * @ipa: IPA pointer
  37. * @enable: Whether retention should be enabled or disabled
  38. */
  39. void ipa_power_retention(struct ipa *ipa, bool enable);
  40. /**
  41. * ipa_power_setup() - Set up IPA power management
  42. * @ipa: IPA pointer
  43. *
  44. * Return: 0 if successful, or a negative error code
  45. */
  46. int ipa_power_setup(struct ipa *ipa);
  47. /**
  48. * ipa_power_teardown() - Inverse of ipa_power_setup()
  49. * @ipa: IPA pointer
  50. */
  51. void ipa_power_teardown(struct ipa *ipa);
  52. /**
  53. * ipa_power_init() - Initialize IPA power management
  54. * @dev: IPA device
  55. * @data: Clock configuration data
  56. *
  57. * Return: A pointer to an ipa_power structure, or a pointer-coded error
  58. */
  59. struct ipa_power *ipa_power_init(struct device *dev,
  60. const struct ipa_power_data *data);
  61. /**
  62. * ipa_power_exit() - Inverse of ipa_power_init()
  63. * @power: IPA power pointer
  64. */
  65. void ipa_power_exit(struct ipa_power *power);
  66. #endif /* _IPA_POWER_H_ */