2022-05-11 17:16:45 +00:00
|
|
|
/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause) */
|
|
|
|
/*
|
|
|
|
* This file is provided under a dual BSD/GPLv2 license. When using or
|
|
|
|
* redistributing this file, you may do so under either license.
|
|
|
|
*
|
|
|
|
* Copyright(c) 2022 Intel Corporation. All rights reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __SOUND_SOC_SOF_IPC4_PRIV_H
|
|
|
|
#define __SOUND_SOC_SOF_IPC4_PRIV_H
|
|
|
|
|
|
|
|
#include <linux/idr.h>
|
2022-05-11 17:16:47 +00:00
|
|
|
#include <sound/sof/ext_manifest4.h>
|
2022-05-11 17:16:45 +00:00
|
|
|
#include "sof-priv.h"
|
2022-09-09 11:43:28 +00:00
|
|
|
|
|
|
|
/* The DSP window indices are fixed */
|
2023-02-02 13:29:47 +00:00
|
|
|
#define SOF_IPC4_INBOX_WINDOW_IDX 0
|
2022-09-09 11:43:28 +00:00
|
|
|
#define SOF_IPC4_OUTBOX_WINDOW_IDX 1
|
2022-09-09 11:43:29 +00:00
|
|
|
#define SOF_IPC4_DEBUG_WINDOW_IDX 2
|
2022-05-11 17:16:45 +00:00
|
|
|
|
2022-09-09 11:43:30 +00:00
|
|
|
enum sof_ipc4_mtrace_type {
|
|
|
|
SOF_IPC4_MTRACE_NOT_AVAILABLE = 0,
|
|
|
|
SOF_IPC4_MTRACE_INTEL_CAVS_1_5,
|
|
|
|
SOF_IPC4_MTRACE_INTEL_CAVS_1_8,
|
|
|
|
SOF_IPC4_MTRACE_INTEL_CAVS_2,
|
|
|
|
};
|
|
|
|
|
2022-10-20 12:12:28 +00:00
|
|
|
/**
|
|
|
|
* struct sof_ipc4_fw_module - IPC4 module info
|
|
|
|
* @sof_man4_module: Module info
|
|
|
|
* @m_ida: Module instance identifier
|
|
|
|
* @bss_size: Module object size
|
|
|
|
* @private: Module private data
|
|
|
|
*/
|
|
|
|
struct sof_ipc4_fw_module {
|
|
|
|
struct sof_man4_module man4_module_entry;
|
|
|
|
struct ida m_ida;
|
|
|
|
u32 bss_size;
|
|
|
|
void *private;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* struct sof_ipc4_fw_library - IPC4 library information
|
|
|
|
* @sof_fw: SOF Firmware of the library
|
|
|
|
* @id: Library ID. 0 is reserved for basefw, external libraries must have unique
|
|
|
|
* ID number between 1 and (sof_ipc4_fw_data.max_libs_count - 1)
|
|
|
|
* Note: sof_ipc4_fw_data.max_libs_count == 1 implies that external libraries
|
|
|
|
* are not supported
|
|
|
|
* @num_modules : Number of FW modules in the library
|
|
|
|
* @modules: Array of FW modules
|
|
|
|
*/
|
|
|
|
struct sof_ipc4_fw_library {
|
|
|
|
struct sof_firmware sof_fw;
|
2022-10-20 12:12:38 +00:00
|
|
|
const char *name;
|
2022-10-20 12:12:28 +00:00
|
|
|
u32 id;
|
|
|
|
int num_modules;
|
|
|
|
struct sof_ipc4_fw_module *modules;
|
|
|
|
};
|
|
|
|
|
2022-05-11 17:16:45 +00:00
|
|
|
/**
|
|
|
|
* struct sof_ipc4_fw_data - IPC4-specific data
|
|
|
|
* @manifest_fw_hdr_offset: FW header offset in the manifest
|
2022-10-20 12:12:28 +00:00
|
|
|
* @fw_lib_xa: XArray for firmware libraries, including basefw (ID = 0)
|
|
|
|
* Used to store the FW libraries and to manage the unique IDs of the
|
|
|
|
* libraries.
|
2022-06-09 03:26:38 +00:00
|
|
|
* @nhlt: NHLT table either from the BIOS or the topology manifest
|
2022-09-09 11:43:30 +00:00
|
|
|
* @mtrace_type: mtrace type supported on the booted platform
|
|
|
|
* @mtrace_log_bytes: log bytes as reported by the firmware via fw_config reply
|
2022-11-08 00:29:09 +00:00
|
|
|
* @max_num_pipelines: max number of pipelines
|
2022-10-20 12:12:27 +00:00
|
|
|
* @max_libs_count: Maximum number of libraries support by the FW including the
|
|
|
|
* base firmware
|
2022-10-20 12:12:32 +00:00
|
|
|
*
|
|
|
|
* @load_library: Callback function for platform dependent library loading
|
2023-01-27 12:00:28 +00:00
|
|
|
* @pipeline_state_mutex: Mutex to protect pipeline triggers, ref counts, states and deletion
|
2022-05-11 17:16:45 +00:00
|
|
|
*/
|
|
|
|
struct sof_ipc4_fw_data {
|
|
|
|
u32 manifest_fw_hdr_offset;
|
2022-10-20 12:12:28 +00:00
|
|
|
struct xarray fw_lib_xa;
|
2022-06-09 03:26:38 +00:00
|
|
|
void *nhlt;
|
2022-09-09 11:43:30 +00:00
|
|
|
enum sof_ipc4_mtrace_type mtrace_type;
|
|
|
|
u32 mtrace_log_bytes;
|
2022-11-08 00:29:09 +00:00
|
|
|
int max_num_pipelines;
|
2022-10-20 12:12:27 +00:00
|
|
|
u32 max_libs_count;
|
2022-10-20 12:12:32 +00:00
|
|
|
|
|
|
|
int (*load_library)(struct snd_sof_dev *sdev,
|
|
|
|
struct sof_ipc4_fw_library *fw_lib, bool reload);
|
2023-01-27 12:00:28 +00:00
|
|
|
struct mutex pipeline_state_mutex; /* protect pipeline triggers, ref counts and states */
|
2022-05-11 17:16:45 +00:00
|
|
|
};
|
|
|
|
|
2023-02-02 13:29:48 +00:00
|
|
|
/**
|
|
|
|
* struct sof_ipc4_timestamp_info - IPC4 timestamp info
|
|
|
|
* @host_copier: the host copier of the pcm stream
|
|
|
|
* @dai_copier: the dai copier of the pcm stream
|
|
|
|
* @stream_start_offset: reported by fw in memory window
|
|
|
|
* @llp_offset: llp offset in memory window
|
|
|
|
*/
|
|
|
|
struct sof_ipc4_timestamp_info {
|
|
|
|
struct sof_ipc4_copier *host_copier;
|
|
|
|
struct sof_ipc4_copier *dai_copier;
|
|
|
|
u64 stream_start_offset;
|
|
|
|
u32 llp_offset;
|
|
|
|
};
|
|
|
|
|
2022-05-11 17:16:47 +00:00
|
|
|
extern const struct sof_ipc_fw_loader_ops ipc4_loader_ops;
|
2022-06-09 03:26:22 +00:00
|
|
|
extern const struct sof_ipc_tplg_ops ipc4_tplg_ops;
|
2022-06-09 03:26:30 +00:00
|
|
|
extern const struct sof_ipc_tplg_control_ops tplg_ipc4_control_ops;
|
2022-06-09 03:26:31 +00:00
|
|
|
extern const struct sof_ipc_pcm_ops ipc4_pcm_ops;
|
2022-09-09 11:43:30 +00:00
|
|
|
extern const struct sof_ipc_fw_tracing_ops ipc4_mtrace_ops;
|
2022-05-11 17:16:47 +00:00
|
|
|
|
2022-06-09 03:26:35 +00:00
|
|
|
int sof_ipc4_set_pipeline_state(struct snd_sof_dev *sdev, u32 id, u32 state);
|
2022-09-09 11:43:30 +00:00
|
|
|
int sof_ipc4_mtrace_update_pos(struct snd_sof_dev *sdev, int core);
|
2022-10-20 12:12:29 +00:00
|
|
|
|
2022-10-20 12:12:36 +00:00
|
|
|
int sof_ipc4_query_fw_configuration(struct snd_sof_dev *sdev);
|
2022-10-20 12:12:38 +00:00
|
|
|
int sof_ipc4_reload_fw_libraries(struct snd_sof_dev *sdev);
|
2022-10-20 12:12:29 +00:00
|
|
|
struct sof_ipc4_fw_module *sof_ipc4_find_module_by_uuid(struct snd_sof_dev *sdev,
|
|
|
|
const guid_t *uuid);
|
2022-05-11 17:16:45 +00:00
|
|
|
#endif
|