2018-10-23 16:27:25 +08:00
|
|
|
#
|
|
|
|
# Topology for Apollo Lake with direct attach digital microphones array
|
|
|
|
#
|
|
|
|
|
|
|
|
# Include topology builder
|
|
|
|
include(`utils.m4')
|
|
|
|
include(`dai.m4')
|
|
|
|
include(`pipeline.m4')
|
|
|
|
|
|
|
|
# Include TLV library
|
|
|
|
include(`common/tlv.m4')
|
|
|
|
|
|
|
|
# Include Token library
|
|
|
|
include(`sof/tokens.m4')
|
|
|
|
|
|
|
|
# Include Apollolake DSP configuration
|
|
|
|
include(`platform/intel/bxt.m4')
|
|
|
|
include(`platform/intel/dmic.m4')
|
|
|
|
|
2019-03-15 03:13:24 +08:00
|
|
|
define(DMIC_PDM_CONFIG, ifelse(CHANNELS, `4', ``FOUR_CH_PDM0_PDM1'',
|
2019-04-15 20:29:47 +08:00
|
|
|
`ifelse(CHANNELS, `2', ``STEREO_PDM0'', `')'))
|
2019-03-15 03:13:24 +08:00
|
|
|
|
2018-10-23 16:27:25 +08:00
|
|
|
#
|
|
|
|
# Define the pipelines
|
|
|
|
#
|
2019-01-18 01:42:08 +08:00
|
|
|
# PCM6 <----- DMIC6 (DMIC01)
|
|
|
|
# PCM7 <----- DMIC7 (DMIC16k)
|
2018-10-23 16:27:25 +08:00
|
|
|
#
|
|
|
|
|
2019-10-22 15:09:58 +08:00
|
|
|
dnl PIPELINE_PCM_ADD(pipeline,
|
2018-10-23 16:27:25 +08:00
|
|
|
dnl pipe id, pcm, max channels, format,
|
2019-01-03 20:11:21 +08:00
|
|
|
dnl period, priority, core,
|
2019-10-22 15:09:58 +08:00
|
|
|
dnl pcm_min_rate, pcm_max_rate, pipeline_rate,
|
|
|
|
dnl time_domain, sched_comp)
|
2018-10-23 16:27:25 +08:00
|
|
|
|
2019-03-15 03:13:24 +08:00
|
|
|
# Passthrough capture pipeline 6 on PCM 6 using max channels defined by CHANNELS.
|
2019-01-03 20:11:21 +08:00
|
|
|
# Set 1000us deadline on core 0 with priority 0
|
2019-10-22 15:09:58 +08:00
|
|
|
PIPELINE_PCM_ADD(sof/pipe-volume-capture.m4,
|
2019-03-15 03:13:24 +08:00
|
|
|
6, 6, CHANNELS, s32le,
|
2019-10-22 15:09:58 +08:00
|
|
|
1000, 0, 0,
|
2019-01-03 20:11:21 +08:00
|
|
|
48000, 48000, 48000)
|
2018-10-23 16:27:25 +08:00
|
|
|
|
2019-03-15 03:13:24 +08:00
|
|
|
# Passthrough capture pipeline 7 on PCM 7 using max channels defined by CHANNELS.
|
2019-01-03 20:11:21 +08:00
|
|
|
# Set 1000us deadline on core 0 with priority 0
|
2019-10-22 15:09:58 +08:00
|
|
|
PIPELINE_PCM_ADD(sof/pipe-volume-capture.m4,
|
2019-04-16 22:34:09 +08:00
|
|
|
7, 7, CHANNELS, s32le,
|
2019-10-22 15:09:58 +08:00
|
|
|
1000, 0, 0,
|
2019-01-03 20:11:21 +08:00
|
|
|
16000, 16000, 16000)
|
2018-10-23 16:27:25 +08:00
|
|
|
|
|
|
|
#
|
|
|
|
# DAIs configuration
|
|
|
|
#
|
|
|
|
|
|
|
|
dnl DAI_ADD(pipeline,
|
|
|
|
dnl pipe id, dai type, dai_index, dai_be,
|
|
|
|
dnl buffer, periods, format,
|
2019-09-19 22:19:49 +08:00
|
|
|
dnl deadline, priority, core, time_domain)
|
2018-10-23 16:27:25 +08:00
|
|
|
|
2019-10-22 15:09:58 +08:00
|
|
|
# capture DAI is DMIC 0 using 2 periods
|
2019-01-03 20:11:21 +08:00
|
|
|
# Buffers use s32le format, 1000us deadline on core 0 with priority 0
|
2018-10-23 16:27:25 +08:00
|
|
|
DAI_ADD(sof/pipe-dai-capture.m4,
|
2019-01-18 01:42:08 +08:00
|
|
|
6, DMIC, 0, NoCodec-6,
|
2019-10-22 15:09:58 +08:00
|
|
|
PIPELINE_SINK_6, 2, s32le,
|
2019-10-15 19:40:26 +08:00
|
|
|
1000, 0, 0, SCHEDULE_TIME_DOMAIN_TIMER)
|
2018-10-23 16:27:25 +08:00
|
|
|
|
2019-10-22 15:09:58 +08:00
|
|
|
# capture DAI is DMIC 1 using 2 periods
|
2019-01-03 20:11:21 +08:00
|
|
|
# Buffers use s16le format, 1000us deadline on core 0 with priority 0
|
2019-01-18 01:42:08 +08:00
|
|
|
DAI_ADD(sof/pipe-dai-capture.m4,
|
|
|
|
7, DMIC, 1, NoCodec-7,
|
2019-10-22 15:09:58 +08:00
|
|
|
PIPELINE_SINK_7, 2, s16le,
|
2019-10-15 19:40:26 +08:00
|
|
|
1000, 0, 0, SCHEDULE_TIME_DOMAIN_TIMER)
|
2018-10-23 16:27:25 +08:00
|
|
|
|
2019-03-15 03:13:24 +08:00
|
|
|
|
2019-01-18 01:42:08 +08:00
|
|
|
dnl PCM_DUPLEX_ADD(name, pcm_id, playback, capture)
|
2018-10-23 16:27:25 +08:00
|
|
|
dnl PCM_CAPTURE_ADD(name, pipeline, capture)
|
2019-01-18 01:42:08 +08:00
|
|
|
PCM_CAPTURE_ADD(DMIC01, 6, PIPELINE_PCM_6)
|
|
|
|
PCM_CAPTURE_ADD(DMIC16k, 7, PIPELINE_PCM_7)
|
2018-10-23 16:27:25 +08:00
|
|
|
|
|
|
|
#
|
|
|
|
# BE configurations - overrides config in ACPI if present
|
|
|
|
#
|
|
|
|
|
|
|
|
dnl DAI_CONFIG(type, dai_index, link_id, name, ssp_config/dmic_config)
|
|
|
|
|
|
|
|
DAI_CONFIG(DMIC, 0, 6, NoCodec-6,
|
|
|
|
dnl DMIC_CONFIG(driver_version, clk_min, clk_mac, duty_min, duty_max,
|
2019-06-03 22:35:13 +08:00
|
|
|
dnl sample_rate, fifo word length, unmute time, type,
|
|
|
|
dnl dai_index, pdm controller config)
|
2018-10-23 16:27:25 +08:00
|
|
|
DMIC_CONFIG(1, 500000, 4800000, 40, 60, 48000,
|
2019-06-03 22:35:13 +08:00
|
|
|
DMIC_WORD_LENGTH(s32le), 400, DMIC, 0,
|
2019-03-15 03:13:24 +08:00
|
|
|
PDM_CONFIG(DMIC, 0, DMIC_PDM_CONFIG)))
|
2018-10-23 16:27:25 +08:00
|
|
|
|
2019-01-18 01:42:08 +08:00
|
|
|
DAI_CONFIG(DMIC, 1, 7, NoCodec-7,
|
|
|
|
dnl DMIC_CONFIG(driver_version, clk_min, clk_mac, duty_min, duty_max,
|
2019-06-03 22:35:13 +08:00
|
|
|
dnl sample_rate, fifo word length, unmute time, type,
|
|
|
|
dnl dai_index, pdm controller config)
|
2019-01-18 01:42:08 +08:00
|
|
|
DMIC_CONFIG(1, 500000, 4800000, 40, 60, 16000,
|
2019-06-03 22:35:13 +08:00
|
|
|
DMIC_WORD_LENGTH(s16le), 400, DMIC, 1,
|
2019-03-15 03:13:24 +08:00
|
|
|
PDM_CONFIG(DMIC, 1, DMIC_PDM_CONFIG)))
|