mirror of https://github.com/thesofproject/sof.git
topology: keyword: Add keyword detection topology for APL
Add initial pipeline for keyword detection on APL platform. Signed-off-by: Liam Girdwood <liam.r.girdwood@linux.intel.com> Signed-off-by: Ranjani Sridharan <ranjani.sridharan@linux.intel.com> Signed-off-by: Keyon Jie <yang.jie@linux.intel.com>
This commit is contained in:
parent
500d64fe5d
commit
e31ef3b96a
|
@ -12,6 +12,7 @@ set(MACHINES
|
|||
sof-cht-rt5682
|
||||
sof-hda-intel-common
|
||||
sof-apl-nocodec
|
||||
sof-apl-keyword-detect
|
||||
sof-byt-nocodec
|
||||
sof-bdw-rt286
|
||||
sof-bdw-rt5640
|
||||
|
|
|
@ -0,0 +1,97 @@
|
|||
#
|
||||
# Topology for ApolloLake with direct attach digital microphones array for
|
||||
# keyword detection and triggering use case.
|
||||
#
|
||||
|
||||
# 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')
|
||||
|
||||
define(KWD_PERIOD_FRAMES, 320)
|
||||
define(KWD_PIPE_SCH_DEADLINE_US, 20000)
|
||||
|
||||
#
|
||||
# Define the pipelines
|
||||
#
|
||||
# PCM 0 <-------+- KPBM 0 <-- B0 <-- DMIC6 (DMIC01)
|
||||
# |
|
||||
# Keyword <-----+
|
||||
|
||||
dnl PIPELINE_PCM_ADD(pipeline,
|
||||
dnl pipe id, pcm, max channels, format,
|
||||
dnl frames, deadline, priority, core)
|
||||
|
||||
# Passthrough capture pipeline 1 on PCM 0 using max 2 channels.
|
||||
# Schedule 320 frames per 1000us deadline on core 0 with priority 0
|
||||
PIPELINE_PCM_ADD(sof/pipe-kfbm-capture.m4,
|
||||
1, 0, 2, s16le,
|
||||
KWD_PERIOD_FRAMES,
|
||||
KWD_PIPE_SCH_DEADLINE_US,
|
||||
0, 0)
|
||||
|
||||
#
|
||||
# DAIs configuration
|
||||
#
|
||||
|
||||
dnl DAI_ADD(pipeline,
|
||||
dnl pipe id, dai type, dai_index, dai_be,
|
||||
dnl buffer, periods, format,
|
||||
dnl frames, deadline, priority, core)
|
||||
|
||||
|
||||
# capture DAI is DMIC 0 using 2 periods
|
||||
# Buffers use s16le format, with 320 frame per 1000us on core 0 with priority 0
|
||||
DAI_ADD(sof/pipe-dai-capture.m4,
|
||||
1, DMIC, 0, NoCodec-6,
|
||||
PIPELINE_SINK_1, 2, s16le,
|
||||
KWD_PERIOD_FRAMES,
|
||||
KWD_PIPE_SCH_DEADLINE_US,
|
||||
0, 0)
|
||||
|
||||
# keyword detector pipe
|
||||
dnl PIPELINE_ADD(pipeline,
|
||||
dnl pipe id, max channels, format,
|
||||
dnl frames, deadline, priority, core)
|
||||
PIPELINE_ADD(sof/pipe-detect.m4, 2, 2, s16le,
|
||||
KWD_PERIOD_FRAMES,
|
||||
KWD_PIPE_SCH_DEADLINE_US,
|
||||
0, 0, PIPELINE_SCHED_COMP_1)
|
||||
|
||||
# Connect pipelines together
|
||||
SectionGraph."pipe-sof-apl-keyword-detect" {
|
||||
index "0"
|
||||
|
||||
lines [
|
||||
# keyword detect
|
||||
dapm(PIPELINE_SINK_2, PIPELINE_SOURCE_1)
|
||||
dapm(PIPELINE_PCM_1, PIPELINE_DETECT_2)
|
||||
]
|
||||
}
|
||||
|
||||
#
|
||||
# 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,
|
||||
dnl sample_rate,
|
||||
dnl fifo word length, type, dai_index, pdm controller config)
|
||||
DMIC_CONFIG(1, 500000, 4800000, 40, 60, 16000,
|
||||
dnl DMIC_WORD_LENGTH(frame_format)
|
||||
DMIC_WORD_LENGTH(s16le), DMIC, 0,
|
||||
dnl PDM_CONFIG(type, dai_index, num pdm active, pdm tuples list)
|
||||
dnl STEREO_PDM0 is a pre-defined pdm config for stereo capture
|
||||
PDM_CONFIG(DMIC, 0, STEREO_PDM0)))
|
||||
|
Loading…
Reference in New Issue