sci.h 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * Copyright 2018 NXP
  4. */
  5. #ifndef _SC_SCI_H
  6. #define _SC_SCI_H
  7. #include <asm/arch/sci/types.h>
  8. #include <asm/arch/sci/svc/misc/api.h>
  9. #include <asm/arch/sci/svc/pad/api.h>
  10. #include <asm/arch/sci/svc/pm/api.h>
  11. #include <asm/arch/sci/svc/rm/api.h>
  12. #include <asm/arch/sci/rpc.h>
  13. #include <dt-bindings/soc/imx_rsrc.h>
  14. #include <linux/errno.h>
  15. static inline int sc_err_to_linux(sc_err_t err)
  16. {
  17. int ret;
  18. switch (err) {
  19. case SC_ERR_NONE:
  20. return 0;
  21. case SC_ERR_VERSION:
  22. case SC_ERR_CONFIG:
  23. case SC_ERR_PARM:
  24. ret = -EINVAL;
  25. break;
  26. case SC_ERR_NOACCESS:
  27. case SC_ERR_LOCKED:
  28. case SC_ERR_UNAVAILABLE:
  29. ret = -EACCES;
  30. break;
  31. case SC_ERR_NOTFOUND:
  32. case SC_ERR_NOPOWER:
  33. ret = -ENODEV;
  34. break;
  35. case SC_ERR_IPC:
  36. ret = -EIO;
  37. break;
  38. case SC_ERR_BUSY:
  39. ret = -EBUSY;
  40. break;
  41. case SC_ERR_FAIL:
  42. ret = -EIO;
  43. break;
  44. default:
  45. ret = 0;
  46. break;
  47. }
  48. debug("%s %d %d\n", __func__, err, ret);
  49. return ret;
  50. }
  51. /* PM API*/
  52. int sc_pm_set_resource_power_mode(sc_ipc_t ipc, sc_rsrc_t resource,
  53. sc_pm_power_mode_t mode);
  54. int sc_pm_set_clock_rate(sc_ipc_t ipc, sc_rsrc_t resource, sc_pm_clk_t clk,
  55. sc_pm_clock_rate_t *rate);
  56. int sc_pm_get_clock_rate(sc_ipc_t ipc, sc_rsrc_t resource, sc_pm_clk_t clk,
  57. sc_pm_clock_rate_t *rate);
  58. int sc_pm_set_clock_rate(sc_ipc_t ipc, sc_rsrc_t resource, sc_pm_clk_t clk,
  59. sc_pm_clock_rate_t *rate);
  60. int sc_pm_get_clock_rate(sc_ipc_t ipc, sc_rsrc_t resource, sc_pm_clk_t clk,
  61. sc_pm_clock_rate_t *rate);
  62. int sc_pm_clock_enable(sc_ipc_t ipc, sc_rsrc_t resource, sc_pm_clk_t clk,
  63. sc_bool_t enable, sc_bool_t autog);
  64. /* MISC API */
  65. int sc_misc_get_control(sc_ipc_t ipc, sc_rsrc_t resource, sc_ctrl_t ctrl,
  66. u32 *val);
  67. void sc_misc_get_boot_dev(sc_ipc_t ipc, sc_rsrc_t *boot_dev);
  68. void sc_misc_boot_status(sc_ipc_t ipc, sc_misc_boot_status_t status);
  69. void sc_misc_build_info(sc_ipc_t ipc, u32 *build, u32 *commit);
  70. int sc_misc_otp_fuse_read(sc_ipc_t ipc, u32 word, u32 *val);
  71. /* RM API */
  72. sc_bool_t sc_rm_is_memreg_owned(sc_ipc_t ipc, sc_rm_mr_t mr);
  73. int sc_rm_get_memreg_info(sc_ipc_t ipc, sc_rm_mr_t mr, sc_faddr_t *addr_start,
  74. sc_faddr_t *addr_end);
  75. sc_bool_t sc_rm_is_resource_owned(sc_ipc_t ipc, sc_rsrc_t resource);
  76. /* PAD API */
  77. int sc_pad_set(sc_ipc_t ipc, sc_pad_t pad, u32 val);
  78. #endif