2018-05-18 19:56:01 +07:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
#ifndef __Q6_ASM_H__
|
|
|
|
#define __Q6_ASM_H__
|
2018-05-18 19:56:03 +07:00
|
|
|
#include "q6dsp-common.h"
|
|
|
|
#include <dt-bindings/sound/qcom,q6asm.h>
|
|
|
|
|
|
|
|
/* ASM client callback events */
|
|
|
|
#define CMD_PAUSE 0x0001
|
|
|
|
#define ASM_CLIENT_EVENT_CMD_PAUSE_DONE 0x1001
|
|
|
|
#define CMD_FLUSH 0x0002
|
|
|
|
#define ASM_CLIENT_EVENT_CMD_FLUSH_DONE 0x1002
|
|
|
|
#define CMD_EOS 0x0003
|
|
|
|
#define ASM_CLIENT_EVENT_CMD_EOS_DONE 0x1003
|
|
|
|
#define CMD_CLOSE 0x0004
|
|
|
|
#define ASM_CLIENT_EVENT_CMD_CLOSE_DONE 0x1004
|
|
|
|
#define CMD_OUT_FLUSH 0x0005
|
|
|
|
#define ASM_CLIENT_EVENT_CMD_OUT_FLUSH_DONE 0x1005
|
|
|
|
#define CMD_SUSPEND 0x0006
|
|
|
|
#define ASM_CLIENT_EVENT_CMD_SUSPEND_DONE 0x1006
|
|
|
|
#define ASM_CLIENT_EVENT_CMD_RUN_DONE 0x1008
|
|
|
|
#define ASM_CLIENT_EVENT_DATA_WRITE_DONE 0x1009
|
|
|
|
#define ASM_CLIENT_EVENT_DATA_READ_DONE 0x100a
|
2020-07-27 16:38:00 +07:00
|
|
|
#define ASM_WRITE_TOKEN_MASK GENMASK(15, 0)
|
|
|
|
#define ASM_WRITE_TOKEN_LEN_MASK GENMASK(31, 16)
|
|
|
|
#define ASM_WRITE_TOKEN_LEN_SHIFT 16
|
2018-05-18 19:56:03 +07:00
|
|
|
|
|
|
|
enum {
|
|
|
|
LEGACY_PCM_MODE = 0,
|
|
|
|
LOW_LATENCY_PCM_MODE,
|
|
|
|
ULTRA_LOW_LATENCY_PCM_MODE,
|
|
|
|
ULL_POST_PROCESSING_PCM_MODE,
|
|
|
|
};
|
2018-05-18 19:56:01 +07:00
|
|
|
|
|
|
|
#define MAX_SESSIONS 8
|
2018-05-18 19:56:03 +07:00
|
|
|
#define FORMAT_LINEAR_PCM 0x0000
|
2018-05-18 19:56:01 +07:00
|
|
|
|
2019-11-15 17:27:04 +07:00
|
|
|
struct q6asm_flac_cfg {
|
|
|
|
u32 sample_rate;
|
|
|
|
u32 ext_sample_rate;
|
|
|
|
u32 min_frame_size;
|
|
|
|
u32 max_frame_size;
|
|
|
|
u16 stream_info_present;
|
|
|
|
u16 min_blk_size;
|
|
|
|
u16 max_blk_size;
|
|
|
|
u16 ch_cfg;
|
|
|
|
u16 sample_size;
|
|
|
|
u16 md5_sum;
|
|
|
|
};
|
|
|
|
|
2020-03-16 12:52:16 +07:00
|
|
|
struct q6asm_wma_cfg {
|
|
|
|
u32 fmtag;
|
|
|
|
u32 num_channels;
|
|
|
|
u32 sample_rate;
|
|
|
|
u32 bytes_per_sec;
|
|
|
|
u32 block_align;
|
|
|
|
u32 bits_per_sample;
|
|
|
|
u32 channel_mask;
|
|
|
|
u32 enc_options;
|
|
|
|
u32 adv_enc_options;
|
|
|
|
u32 adv_enc_options2;
|
|
|
|
};
|
|
|
|
|
2020-03-16 12:52:19 +07:00
|
|
|
struct q6asm_alac_cfg {
|
|
|
|
u32 frame_length;
|
|
|
|
u8 compatible_version;
|
|
|
|
u8 bit_depth;
|
|
|
|
u8 pb;
|
|
|
|
u8 mb;
|
|
|
|
u8 kb;
|
|
|
|
u8 num_channels;
|
|
|
|
u16 max_run;
|
|
|
|
u32 max_frame_bytes;
|
|
|
|
u32 avg_bit_rate;
|
|
|
|
u32 sample_rate;
|
|
|
|
u32 channel_layout_tag;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct q6asm_ape_cfg {
|
|
|
|
u16 compatible_version;
|
|
|
|
u16 compression_level;
|
|
|
|
u32 format_flags;
|
|
|
|
u32 blocks_per_frame;
|
|
|
|
u32 final_frame_blocks;
|
|
|
|
u32 total_frames;
|
|
|
|
u16 bits_per_sample;
|
|
|
|
u16 num_channels;
|
|
|
|
u32 sample_rate;
|
|
|
|
u32 seek_table_present;
|
|
|
|
};
|
|
|
|
|
2018-05-18 19:56:01 +07:00
|
|
|
typedef void (*q6asm_cb) (uint32_t opcode, uint32_t token,
|
|
|
|
void *payload, void *priv);
|
|
|
|
struct audio_client;
|
|
|
|
struct audio_client *q6asm_audio_client_alloc(struct device *dev,
|
|
|
|
q6asm_cb cb, void *priv,
|
|
|
|
int session_id, int perf_mode);
|
|
|
|
void q6asm_audio_client_free(struct audio_client *ac);
|
2020-07-27 16:37:58 +07:00
|
|
|
int q6asm_write_async(struct audio_client *ac, uint32_t stream_id, uint32_t len,
|
|
|
|
uint32_t msw_ts, uint32_t lsw_ts, uint32_t flags);
|
|
|
|
int q6asm_open_write(struct audio_client *ac, uint32_t stream_id,
|
|
|
|
uint32_t format, u32 codec_profile,
|
2020-07-27 16:38:02 +07:00
|
|
|
uint16_t bits_per_sample, bool is_gapless);
|
2020-07-27 16:37:58 +07:00
|
|
|
|
|
|
|
int q6asm_open_read(struct audio_client *ac, uint32_t stream_id,
|
|
|
|
uint32_t format, uint16_t bits_per_sample);
|
2018-05-18 19:56:03 +07:00
|
|
|
int q6asm_enc_cfg_blk_pcm_format_support(struct audio_client *ac,
|
2020-07-27 16:37:58 +07:00
|
|
|
uint32_t stream_id, uint32_t rate,
|
|
|
|
uint32_t channels,
|
|
|
|
uint16_t bits_per_sample);
|
|
|
|
|
|
|
|
int q6asm_read(struct audio_client *ac, uint32_t stream_id);
|
2018-05-18 19:56:03 +07:00
|
|
|
|
|
|
|
int q6asm_media_format_block_multi_ch_pcm(struct audio_client *ac,
|
2020-07-27 16:37:58 +07:00
|
|
|
uint32_t stream_id,
|
2018-05-18 19:56:03 +07:00
|
|
|
uint32_t rate, uint32_t channels,
|
|
|
|
u8 channel_map[PCM_MAX_NUM_CHANNEL],
|
|
|
|
uint16_t bits_per_sample);
|
2019-11-15 17:27:04 +07:00
|
|
|
int q6asm_stream_media_format_block_flac(struct audio_client *ac,
|
2020-07-27 16:37:58 +07:00
|
|
|
uint32_t stream_id,
|
2019-11-15 17:27:04 +07:00
|
|
|
struct q6asm_flac_cfg *cfg);
|
2020-03-16 12:52:16 +07:00
|
|
|
int q6asm_stream_media_format_block_wma_v9(struct audio_client *ac,
|
2020-07-27 16:37:58 +07:00
|
|
|
uint32_t stream_id,
|
2020-03-16 12:52:16 +07:00
|
|
|
struct q6asm_wma_cfg *cfg);
|
|
|
|
int q6asm_stream_media_format_block_wma_v10(struct audio_client *ac,
|
2020-07-27 16:37:58 +07:00
|
|
|
uint32_t stream_id,
|
2020-03-16 12:52:16 +07:00
|
|
|
struct q6asm_wma_cfg *cfg);
|
2020-03-16 12:52:19 +07:00
|
|
|
int q6asm_stream_media_format_block_alac(struct audio_client *ac,
|
2020-07-27 16:37:58 +07:00
|
|
|
uint32_t stream_id,
|
2020-03-16 12:52:19 +07:00
|
|
|
struct q6asm_alac_cfg *cfg);
|
|
|
|
int q6asm_stream_media_format_block_ape(struct audio_client *ac,
|
2020-07-27 16:37:58 +07:00
|
|
|
uint32_t stream_id,
|
2020-03-16 12:52:19 +07:00
|
|
|
struct q6asm_ape_cfg *cfg);
|
2020-07-27 16:37:58 +07:00
|
|
|
int q6asm_run(struct audio_client *ac, uint32_t stream_id, uint32_t flags,
|
|
|
|
uint32_t msw_ts, uint32_t lsw_ts);
|
|
|
|
int q6asm_run_nowait(struct audio_client *ac, uint32_t stream_id,
|
|
|
|
uint32_t flags, uint32_t msw_ts, uint32_t lsw_ts);
|
2020-07-27 16:38:01 +07:00
|
|
|
int q6asm_stream_remove_initial_silence(struct audio_client *ac,
|
|
|
|
uint32_t stream_id,
|
|
|
|
uint32_t initial_samples);
|
|
|
|
int q6asm_stream_remove_trailing_silence(struct audio_client *ac,
|
|
|
|
uint32_t stream_id,
|
|
|
|
uint32_t trailing_samples);
|
2020-07-27 16:37:58 +07:00
|
|
|
int q6asm_cmd(struct audio_client *ac, uint32_t stream_id, int cmd);
|
|
|
|
int q6asm_cmd_nowait(struct audio_client *ac, uint32_t stream_id, int cmd);
|
2018-05-18 19:56:01 +07:00
|
|
|
int q6asm_get_session_id(struct audio_client *ac);
|
2018-05-18 19:56:02 +07:00
|
|
|
int q6asm_map_memory_regions(unsigned int dir,
|
|
|
|
struct audio_client *ac,
|
|
|
|
phys_addr_t phys,
|
|
|
|
size_t bufsz, unsigned int bufcnt);
|
|
|
|
int q6asm_unmap_memory_regions(unsigned int dir, struct audio_client *ac);
|
2018-05-18 19:56:01 +07:00
|
|
|
#endif /* __Q6_ASM_H__ */
|