blob: 2d47691afb7151f1292aeb62f5a24e175ac9d44b [file] [log] [blame]
/* SPDX-License-Identifier: (GPL-2.0+ OR MIT) */
/*
* Copyright (c) 2019 Amlogic, Inc. All rights reserved.
*/
#ifndef __AML_AUDIO_RESAMPLE_HW_H__
#define __AML_AUDIO_RESAMPLE_HW_H__
#include "ddr_mngr.h"
enum samplerate_index {
RATE_OFF,
RATE_32K,
RATE_44K,
RATE_48K,
RATE_88K,
RATE_96K,
RATE_176K,
RATE_192K,
RATE_16K,
RATE_MAX,
};
#define DEFAULT_SPK_SAMPLERATE 48000
#define DEFAULT_MIC_SAMPLERATE 16000
bool resample_get_status(enum resample_idx id);
void resample_enable(enum resample_idx id, bool enable);
int resample_init(enum resample_idx id, int input_sr);
int resample_set_hw_param(enum resample_idx id,
enum samplerate_index rate_index);
void resample_src_select(int src);
void resample_src_select_ab(enum resample_idx id, enum resample_src src);
void resample_format_set(enum resample_idx id, int ch_num, int bits);
int resample_ctrl_read(enum resample_idx id);
void resample_ctrl_write(enum resample_idx id, int value);
int resample_set_hw_pause_thd(enum resample_idx id, unsigned int thd);
void aml_resample_chsync_enable(enum resample_idx id, bool enable);
void aml_resample_chsync_set(enum resample_idx id, int channel);
#ifdef AA_FILTER_DEBUG
void check_ram_coeff_aa(enum resample_idx id, int len,
unsigned int *params);
void check_ram_coeff_sinc(enum resample_idx id, int len,
unsigned int *params);
void new_resample_set_ram_coeff_aa(enum resample_idx id, int len,
unsigned int *params);
#endif
void new_resample_set_ram_coeff_sinc(enum resample_idx id, int len,
unsigned int *params);
void new_resample_init_param(enum resample_idx id);
void new_resample_enable(enum resample_idx id, bool enable, int channel);
void new_resampleA_set_format(enum resample_idx id, int source, int channel);
void new_resampleB_set_format(enum resample_idx id, int output_sr, int channel);
void new_resample_set_ratio(enum resample_idx id, int input_sr, int output_sr);
bool new_resample_get_status(enum resample_idx id);
void new_resample_src_select(enum resample_idx id, enum resample_src src);
void new_resample_src_select_v2(enum resample_idx id, unsigned int src);
void new_resample_enable_watchdog(enum resample_idx id, bool enable);
#endif