apr.h 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (c) 2010-2017, 2019-2021, The Linux Foundation. All rights reserved.
  4. */
  5. #ifndef __APR_H_
  6. #define __APR_H_
  7. #include <linux/mutex.h>
  8. enum apr_subsys_state {
  9. APR_SUBSYS_DOWN,
  10. APR_SUBSYS_UP,
  11. APR_SUBSYS_LOADED,
  12. APR_SUBSYS_UNKNOWN,
  13. };
  14. struct apr_q6 {
  15. void *pil;
  16. atomic_t q6_state;
  17. atomic_t modem_state;
  18. struct mutex lock;
  19. /*
  20. * ToDo - Multiple client support to be added.
  21. * And checking for state UNKNOWN currently.
  22. */
  23. void (*state_notify_cb)(enum apr_subsys_state state,
  24. void *client_handle);
  25. void *client_handle;
  26. };
  27. struct apr_hdr {
  28. uint16_t hdr_field;
  29. uint16_t pkt_size;
  30. uint8_t src_svc;
  31. uint8_t src_domain;
  32. uint16_t src_port;
  33. uint8_t dest_svc;
  34. uint8_t dest_domain;
  35. uint16_t dest_port;
  36. uint32_t token;
  37. uint32_t opcode;
  38. };
  39. #define APR_HDR_LEN(hdr_len) ((hdr_len)/4)
  40. #define APR_PKT_SIZE(hdr_len, payload_len) ((hdr_len) + (payload_len))
  41. #define APR_HDR_FIELD(msg_type, hdr_len, ver)\
  42. (((msg_type & 0x3) << 8) | ((hdr_len & 0xF) << 4) | (ver & 0xF))
  43. #define APR_HDR_SIZE sizeof(struct apr_hdr)
  44. /* Version */
  45. #define APR_PKT_VER 0x0
  46. /* Command and Response Types */
  47. #define APR_MSG_TYPE_EVENT 0x0
  48. #define APR_MSG_TYPE_CMD_RSP 0x1
  49. #define APR_MSG_TYPE_SEQ_CMD 0x2
  50. #define APR_MSG_TYPE_NSEQ_CMD 0x3
  51. #define APR_MSG_TYPE_MAX 0x04
  52. /* APR Basic Response Message */
  53. #define APR_BASIC_RSP_RESULT 0x000110E8
  54. #define APR_RSP_ACCEPTED 0x000100BE
  55. /* Domain IDs */
  56. #define APR_DOMAIN_SIM 0x1
  57. #define APR_DOMAIN_PC 0x2
  58. #define APR_DOMAIN_MODEM 0x3
  59. #define APR_DOMAIN_ADSP 0x4
  60. #define APR_DOMAIN_APPS 0x5
  61. #define APR_DOMAIN_MAX 0x6
  62. /* ADSP service IDs */
  63. #define APR_SVC_TEST_CLIENT 0x2
  64. #define APR_SVC_ADSP_CORE 0x3
  65. #define APR_SVC_AFE 0x4
  66. #define APR_SVC_VSM 0x5
  67. #define APR_SVC_VPM 0x6
  68. #define APR_SVC_ASM 0x7
  69. #define APR_SVC_ADM 0x8
  70. #define APR_SVC_ADSP_MVM 0x09
  71. #define APR_SVC_ADSP_CVS 0x0A
  72. #define APR_SVC_ADSP_CVP 0x0B
  73. #define APR_SVC_USM 0x0C
  74. #define APR_SVC_LSM 0x0D
  75. #define APR_SVC_VIDC 0x16
  76. #define APR_SVC_MAX 0x17
  77. /* Modem Service IDs */
  78. #define APR_SVC_MVS 0x3
  79. #define APR_SVC_MVM 0x4
  80. #define APR_SVC_CVS 0x5
  81. #define APR_SVC_CVP 0x6
  82. #define APR_SVC_SRD 0x7
  83. /* APR Port IDs */
  84. #define APR_MAX_PORTS 0x80
  85. #define APR_NAME_MAX 0x40
  86. #define RESET_EVENTS 0x000130D7
  87. #define LPASS_RESTART_EVENT 0x1000
  88. #define LPASS_RESTART_READY 0x1001
  89. struct apr_client_data {
  90. uint16_t reset_event;
  91. uint16_t reset_proc;
  92. uint16_t payload_size;
  93. uint16_t hdr_len;
  94. uint16_t msg_type;
  95. uint16_t src;
  96. uint16_t dest_svc;
  97. uint16_t src_port;
  98. uint16_t dest_port;
  99. uint32_t token;
  100. uint32_t opcode;
  101. void *payload;
  102. };
  103. typedef int32_t (*apr_fn)(struct apr_client_data *data, void *priv);
  104. struct apr_svc {
  105. uint16_t id;
  106. uint16_t dest_id;
  107. uint16_t client_id;
  108. uint16_t dest_domain;
  109. uint8_t rvd;
  110. uint8_t port_cnt;
  111. uint8_t svc_cnt;
  112. uint8_t need_reset;
  113. apr_fn port_fn[APR_MAX_PORTS];
  114. void *port_priv[APR_MAX_PORTS];
  115. apr_fn fn;
  116. void *priv;
  117. struct mutex m_lock;
  118. spinlock_t w_lock;
  119. uint8_t pkt_owner;
  120. #ifdef CONFIG_MSM_QDSP6_APRV2_VM
  121. uint16_t vm_dest_svc;
  122. uint32_t vm_handle;
  123. #endif
  124. };
  125. struct apr_client {
  126. uint8_t id;
  127. uint8_t svc_cnt;
  128. uint8_t rvd;
  129. struct mutex m_lock;
  130. struct apr_svc_ch_dev *handle;
  131. struct apr_svc svc[APR_SVC_MAX];
  132. };
  133. struct apr_rx_intents {
  134. int num_of_intents;
  135. uint32_t size;
  136. };
  137. struct apr_pkt_cfg {
  138. uint8_t pkt_owner;
  139. struct apr_rx_intents intents;
  140. };
  141. int apr_load_adsp_image(void);
  142. struct apr_client *apr_get_client(int dest_id, int client_id);
  143. int apr_wait_for_device_up(int dest_id);
  144. int apr_get_svc(const char *svc_name, int dest_id, int *client_id,
  145. int *svc_idx, int *svc_id);
  146. void apr_cb_func(void *buf, int len, void *priv);
  147. struct apr_svc *apr_register(char *dest, char *svc_name, apr_fn svc_fn,
  148. uint32_t src_port, void *priv);
  149. inline int apr_fill_hdr(void *handle, uint32_t *buf, uint16_t src_port,
  150. uint16_t msg_type, uint16_t dest_port,
  151. uint32_t token, uint32_t opcode, uint16_t len);
  152. int apr_send_pkt(void *handle, uint32_t *buf);
  153. int apr_deregister(void *handle);
  154. void subsys_notif_register(char *client_name, int domain,
  155. struct notifier_block *nb);
  156. void subsys_notif_deregister(char *client_name);
  157. int apr_get_dest_id(char *dest);
  158. uint16_t apr_get_data_src(struct apr_hdr *hdr);
  159. void change_q6_state(int state);
  160. void q6audio_dsp_not_responding(void);
  161. void apr_reset(void *handle);
  162. enum apr_subsys_state apr_get_subsys_state(void);
  163. enum apr_subsys_state apr_get_modem_state(void);
  164. void apr_set_modem_state(enum apr_subsys_state state);
  165. enum apr_subsys_state apr_get_q6_state(void);
  166. int apr_set_q6_state(enum apr_subsys_state state);
  167. void apr_set_subsys_state(void);
  168. const char *apr_get_lpass_subsys_name(void);
  169. uint16_t apr_get_reset_domain(uint16_t proc);
  170. int apr_start_rx_rt(void *handle);
  171. int apr_end_rx_rt(void *handle);
  172. void apr_register_adsp_state_cb(void *adsp_cb, void *client_handle);
  173. #endif