Prechádzať zdrojové kódy

ASoC: dsp: Update LSM driver to support Instance ID

Add support to set and get LSM module params with
Instance ID support. Maintain support for non
Instance ID set and get param structures as well.

CRs-Fixed: 2151551
Change-Id: Id9aa5ee89bab1a4e15ff1f7868bceb42d6c25d19
Signed-off-by: Vignesh Kulothungan <[email protected]>
Vignesh Kulothungan 7 rokov pred
rodič
commit
a65e3010a2
3 zmenil súbory, kde vykonal 428 pridanie a 495 odobranie
  1. 412 390
      dsp/q6lsm.c
  2. 1 0
      include/dsp/apr_audio-v2.h
  3. 15 105
      include/dsp/q6lsm.h

Rozdielové dáta súboru neboli zobrazené, pretože súbor je príliš veľký
+ 412 - 390
dsp/q6lsm.c


+ 1 - 0
include/dsp/apr_audio-v2.h

@@ -9569,6 +9569,7 @@ struct avcs_fwk_ver_info {
 #define LSM_SESSION_CMD_CLOSE_TX			(0x00012A88)
 #define LSM_SESSION_CMD_SET_PARAMS			(0x00012A83)
 #define LSM_SESSION_CMD_SET_PARAMS_V2			(0x00012A8F)
+#define LSM_SESSION_CMD_SET_PARAMS_V3			(0x00012A92)
 #define LSM_SESSION_CMD_REGISTER_SOUND_MODEL		(0x00012A84)
 #define LSM_SESSION_CMD_DEREGISTER_SOUND_MODEL		(0x00012A85)
 #define LSM_SESSION_CMD_START				(0x00012A86)

+ 15 - 105
include/dsp/q6lsm.h

@@ -110,31 +110,27 @@ struct lsm_custom_topologies {
 	uint32_t buffer_size;
 } __packed;
 
-struct lsm_param_size_reserved {
-	uint16_t param_size;
-	uint16_t reserved;
-} __packed;
-
-union lsm_param_size {
-	uint32_t param_size;
-	struct lsm_param_size_reserved sr;
+struct lsm_session_cmd_set_params_v2 {
+	struct apr_hdr apr_hdr;
+	uint32_t payload_size;
+	struct mem_mapping_hdr mem_hdr;
+	u32 param_data[0];
 } __packed;
 
-struct lsm_param_payload_common {
-	uint32_t	module_id;
-	uint32_t	param_id;
-	union lsm_param_size p_size;
+struct lsm_session_cmd_set_params_v3 {
+	struct apr_hdr apr_hdr;
+	struct mem_mapping_hdr mem_hdr;
+	uint32_t payload_size;
+	u32 param_data[0];
 } __packed;
 
 struct lsm_param_op_mode {
-	struct lsm_param_payload_common common;
 	uint32_t	minor_version;
 	uint16_t	mode;
 	uint16_t	reserved;
 } __packed;
 
 struct lsm_param_connect_to_port {
-	struct lsm_param_payload_common common;
 	uint32_t	minor_version;
 	/* AFE port id that receives voice wake up data */
 	uint16_t	port_id;
@@ -142,20 +138,17 @@ struct lsm_param_connect_to_port {
 } __packed;
 
 struct lsm_param_poll_enable {
-	struct lsm_param_payload_common common;
 	uint32_t	minor_version;
 	/* indicates to voice wakeup that HW MAD/SW polling is enabled or not */
 	uint32_t	polling_enable;
 } __packed;
 
 struct lsm_param_fwk_mode_cfg {
-	struct lsm_param_payload_common common;
 	uint32_t	minor_version;
 	uint32_t	mode;
 } __packed;
 
 struct lsm_param_media_fmt {
-	struct lsm_param_payload_common common;
 	uint32_t	minor_version;
 	uint32_t	sample_rate;
 	uint16_t	num_channels;
@@ -163,78 +156,23 @@ struct lsm_param_media_fmt {
 	uint8_t		channel_mapping[LSM_MAX_NUM_CHANNELS];
 } __packed;
 
-/*
- * This param cannot be sent in this format.
- * The actual number of confidence level values
- * need to appended to this param payload.
- */
-struct lsm_param_min_confidence_levels {
-	struct lsm_param_payload_common common;
-	uint8_t		num_confidence_levels;
-} __packed;
-
-struct lsm_set_params_hdr {
-	uint32_t	data_payload_size;
-	uint32_t	data_payload_addr_lsw;
-	uint32_t	data_payload_addr_msw;
-	uint32_t	mem_map_handle;
-} __packed;
-
-struct lsm_cmd_set_params {
-	struct apr_hdr  msg_hdr;
-	struct lsm_set_params_hdr param_hdr;
-} __packed;
-
-struct lsm_cmd_set_params_conf {
-	struct apr_hdr  msg_hdr;
-	struct lsm_set_params_hdr params_hdr;
-	struct lsm_param_min_confidence_levels	conf_payload;
-} __packed;
-
-struct lsm_cmd_set_params_opmode {
-	struct apr_hdr  msg_hdr;
-	struct lsm_set_params_hdr params_hdr;
-	struct lsm_param_op_mode op_mode;
-} __packed;
-
-struct lsm_cmd_set_connectport {
-	struct apr_hdr msg_hdr;
-	struct lsm_set_params_hdr params_hdr;
-	struct lsm_param_connect_to_port connect_to_port;
-} __packed;
-
-struct lsm_cmd_poll_enable {
-	struct apr_hdr  msg_hdr;
-	struct lsm_set_params_hdr params_hdr;
-	struct lsm_param_poll_enable poll_enable;
+struct lsm_param_confidence_levels {
+	uint8_t num_confidence_levels;
+	uint8_t confidence_levels[0];
 } __packed;
 
 struct lsm_param_epd_thres {
-	struct lsm_param_payload_common common;
 	uint32_t	minor_version;
 	uint32_t	epd_begin;
 	uint32_t	epd_end;
 } __packed;
 
-struct lsm_cmd_set_epd_threshold {
-	struct apr_hdr msg_hdr;
-	struct lsm_set_params_hdr param_hdr;
-	struct lsm_param_epd_thres epd_thres;
-} __packed;
-
 struct lsm_param_gain {
-	struct lsm_param_payload_common common;
 	uint32_t	minor_version;
 	uint16_t	gain;
 	uint16_t	reserved;
 } __packed;
 
-struct lsm_cmd_set_gain {
-	struct apr_hdr msg_hdr;
-	struct lsm_set_params_hdr param_hdr;
-	struct lsm_param_gain lsm_gain;
-} __packed;
-
 struct lsm_cmd_reg_snd_model {
 	struct apr_hdr	hdr;
 	uint32_t	model_size;
@@ -243,31 +181,16 @@ struct lsm_cmd_reg_snd_model {
 	uint32_t	mem_map_handle;
 } __packed;
 
-struct lsm_lab_enable {
-	struct lsm_param_payload_common common;
+struct lsm_param_lab_enable {
 	uint16_t enable;
 	uint16_t reserved;
 } __packed;
 
-struct lsm_params_lab_enable {
-	struct apr_hdr msg_hdr;
-	struct lsm_set_params_hdr params_hdr;
-	struct lsm_lab_enable lab_enable;
-} __packed;
-
-struct lsm_lab_config {
-	struct lsm_param_payload_common common;
+struct lsm_param_lab_config {
 	uint32_t minor_version;
 	uint32_t wake_up_latency_ms;
 } __packed;
 
-
-struct lsm_params_lab_config {
-	struct apr_hdr  msg_hdr;
-	struct lsm_set_params_hdr params_hdr;
-	struct lsm_lab_config lab_config;
-} __packed;
-
 struct lsm_cmd_read {
 	struct apr_hdr hdr;
 	uint32_t buf_addr_lsw;
@@ -289,19 +212,6 @@ struct lsm_cmd_read_done {
 	uint32_t flags;
 } __packed;
 
-struct lsm_cmd_set_fwk_mode_cfg {
-	struct apr_hdr  msg_hdr;
-	struct lsm_set_params_hdr params_hdr;
-	struct lsm_param_fwk_mode_cfg fwk_mode_cfg;
-} __packed;
-
-struct lsm_cmd_set_media_fmt {
-	struct apr_hdr  msg_hdr;
-	struct lsm_set_params_hdr params_hdr;
-	struct lsm_param_media_fmt media_fmt;
-} __packed;
-
-
 struct lsm_client *q6lsm_client_alloc(lsm_app_cb cb, void *priv);
 void q6lsm_client_free(struct lsm_client *client);
 int q6lsm_open(struct lsm_client *client, uint16_t app_id);

Niektoré súbory nie sú zobrazené, pretože je v týchto rozdielových dátach zmenené mnoho súborov