-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ASoC: SOF: Add support for IPC IO between DSP and Host
Define an IPC ABI for all host <--> DSP communication. This ABI should be transport agnostic. i.e. it should work on MMIO and SPI/I2C style interfaces. Signed-off-by: Guennadi Liakhovetski <guennadi.liakhovetski@linux.intel.com> Signed-off-by: Liam Girdwood <liam.r.girdwood@linux.intel.com> Signed-off-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com> Reviewed-by: Takashi Iwai <tiwai@suse.de> Signed-off-by: Mark Brown <broonie@kernel.org>
- Loading branch information
Liam Girdwood
authored and
Mark Brown
committed
Apr 27, 2019
1 parent
86b02f7
commit 53e0c72
Showing
9 changed files
with
1,782 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,158 @@ | ||
/* SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) 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) 2018 Intel Corporation. All rights reserved. | ||
*/ | ||
|
||
#ifndef __INCLUDE_SOUND_SOF_CONTROL_H__ | ||
#define __INCLUDE_SOUND_SOF_CONTROL_H__ | ||
|
||
#include <uapi/sound/sof/header.h> | ||
#include <sound/sof/header.h> | ||
|
||
/* | ||
* Component Mixers and Controls | ||
*/ | ||
|
||
/* channel positions - uses same values as ALSA */ | ||
enum sof_ipc_chmap { | ||
SOF_CHMAP_UNKNOWN = 0, | ||
SOF_CHMAP_NA, /**< N/A, silent */ | ||
SOF_CHMAP_MONO, /**< mono stream */ | ||
SOF_CHMAP_FL, /**< front left */ | ||
SOF_CHMAP_FR, /**< front right */ | ||
SOF_CHMAP_RL, /**< rear left */ | ||
SOF_CHMAP_RR, /**< rear right */ | ||
SOF_CHMAP_FC, /**< front centre */ | ||
SOF_CHMAP_LFE, /**< LFE */ | ||
SOF_CHMAP_SL, /**< side left */ | ||
SOF_CHMAP_SR, /**< side right */ | ||
SOF_CHMAP_RC, /**< rear centre */ | ||
SOF_CHMAP_FLC, /**< front left centre */ | ||
SOF_CHMAP_FRC, /**< front right centre */ | ||
SOF_CHMAP_RLC, /**< rear left centre */ | ||
SOF_CHMAP_RRC, /**< rear right centre */ | ||
SOF_CHMAP_FLW, /**< front left wide */ | ||
SOF_CHMAP_FRW, /**< front right wide */ | ||
SOF_CHMAP_FLH, /**< front left high */ | ||
SOF_CHMAP_FCH, /**< front centre high */ | ||
SOF_CHMAP_FRH, /**< front right high */ | ||
SOF_CHMAP_TC, /**< top centre */ | ||
SOF_CHMAP_TFL, /**< top front left */ | ||
SOF_CHMAP_TFR, /**< top front right */ | ||
SOF_CHMAP_TFC, /**< top front centre */ | ||
SOF_CHMAP_TRL, /**< top rear left */ | ||
SOF_CHMAP_TRR, /**< top rear right */ | ||
SOF_CHMAP_TRC, /**< top rear centre */ | ||
SOF_CHMAP_TFLC, /**< top front left centre */ | ||
SOF_CHMAP_TFRC, /**< top front right centre */ | ||
SOF_CHMAP_TSL, /**< top side left */ | ||
SOF_CHMAP_TSR, /**< top side right */ | ||
SOF_CHMAP_LLFE, /**< left LFE */ | ||
SOF_CHMAP_RLFE, /**< right LFE */ | ||
SOF_CHMAP_BC, /**< bottom centre */ | ||
SOF_CHMAP_BLC, /**< bottom left centre */ | ||
SOF_CHMAP_BRC, /**< bottom right centre */ | ||
SOF_CHMAP_LAST = SOF_CHMAP_BRC, | ||
}; | ||
|
||
/* control data type and direction */ | ||
enum sof_ipc_ctrl_type { | ||
/* per channel data - uses struct sof_ipc_ctrl_value_chan */ | ||
SOF_CTRL_TYPE_VALUE_CHAN_GET = 0, | ||
SOF_CTRL_TYPE_VALUE_CHAN_SET, | ||
/* component data - uses struct sof_ipc_ctrl_value_comp */ | ||
SOF_CTRL_TYPE_VALUE_COMP_GET, | ||
SOF_CTRL_TYPE_VALUE_COMP_SET, | ||
/* bespoke data - uses struct sof_abi_hdr */ | ||
SOF_CTRL_TYPE_DATA_GET, | ||
SOF_CTRL_TYPE_DATA_SET, | ||
}; | ||
|
||
/* control command type */ | ||
enum sof_ipc_ctrl_cmd { | ||
SOF_CTRL_CMD_VOLUME = 0, /**< maps to ALSA volume style controls */ | ||
SOF_CTRL_CMD_ENUM, /**< maps to ALSA enum style controls */ | ||
SOF_CTRL_CMD_SWITCH, /**< maps to ALSA switch style controls */ | ||
SOF_CTRL_CMD_BINARY, /**< maps to ALSA binary style controls */ | ||
}; | ||
|
||
/* generic channel mapped value data */ | ||
struct sof_ipc_ctrl_value_chan { | ||
uint32_t channel; /**< channel map - enum sof_ipc_chmap */ | ||
uint32_t value; | ||
} __packed; | ||
|
||
/* generic component mapped value data */ | ||
struct sof_ipc_ctrl_value_comp { | ||
uint32_t index; /**< component source/sink/control index in control */ | ||
union { | ||
uint32_t uvalue; | ||
int32_t svalue; | ||
}; | ||
} __packed; | ||
|
||
/* generic control data */ | ||
struct sof_ipc_ctrl_data { | ||
struct sof_ipc_reply rhdr; | ||
uint32_t comp_id; | ||
|
||
/* control access and data type */ | ||
uint32_t type; /**< enum sof_ipc_ctrl_type */ | ||
uint32_t cmd; /**< enum sof_ipc_ctrl_cmd */ | ||
uint32_t index; /**< control index for comps > 1 control */ | ||
|
||
/* control data - can either be appended or DMAed from host */ | ||
struct sof_ipc_host_buffer buffer; | ||
uint32_t num_elems; /**< in array elems or bytes for data type */ | ||
uint32_t elems_remaining; /**< elems remaining if sent in parts */ | ||
|
||
uint32_t msg_index; /**< for large messages sent in parts */ | ||
|
||
/* reserved for future use */ | ||
uint32_t reserved[6]; | ||
|
||
/* control data - add new types if needed */ | ||
union { | ||
/* channel values can be used by volume type controls */ | ||
struct sof_ipc_ctrl_value_chan chanv[0]; | ||
/* component values used by routing controls like mux, mixer */ | ||
struct sof_ipc_ctrl_value_comp compv[0]; | ||
/* data can be used by binary controls */ | ||
struct sof_abi_hdr data[0]; | ||
}; | ||
} __packed; | ||
|
||
/** Event type */ | ||
enum sof_ipc_ctrl_event_type { | ||
SOF_CTRL_EVENT_GENERIC = 0, /**< generic event */ | ||
SOF_CTRL_EVENT_GENERIC_METADATA, /**< generic event with metadata */ | ||
SOF_CTRL_EVENT_KD, /**< keyword detection event */ | ||
SOF_CTRL_EVENT_VAD, /**< voice activity detection event */ | ||
}; | ||
|
||
/** | ||
* Generic notification data. | ||
*/ | ||
struct sof_ipc_comp_event { | ||
struct sof_ipc_reply rhdr; | ||
uint16_t src_comp_type; /**< COMP_TYPE_ */ | ||
uint32_t src_comp_id; /**< source component id */ | ||
uint32_t event_type; /**< event type - SOF_CTRL_EVENT_* */ | ||
uint32_t num_elems; /**< in array elems or bytes for data type */ | ||
|
||
/* reserved for future use */ | ||
uint32_t reserved[8]; | ||
|
||
/* control data - add new types if needed */ | ||
union { | ||
/* data can be used by binary controls */ | ||
struct sof_abi_hdr data[0]; | ||
/* event specific values */ | ||
uint32_t event_value; | ||
}; | ||
} __packed; | ||
|
||
#endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,178 @@ | ||
/* SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) 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) 2018 Intel Corporation. All rights reserved. | ||
*/ | ||
|
||
#ifndef __INCLUDE_SOUND_SOF_DAI_INTEL_H__ | ||
#define __INCLUDE_SOUND_SOF_DAI_INTEL_H__ | ||
|
||
#include <sound/sof/header.h> | ||
|
||
/* ssc1: TINTE */ | ||
#define SOF_DAI_INTEL_SSP_QUIRK_TINTE (1 << 0) | ||
/* ssc1: PINTE */ | ||
#define SOF_DAI_INTEL_SSP_QUIRK_PINTE (1 << 1) | ||
/* ssc2: SMTATF */ | ||
#define SOF_DAI_INTEL_SSP_QUIRK_SMTATF (1 << 2) | ||
/* ssc2: MMRATF */ | ||
#define SOF_DAI_INTEL_SSP_QUIRK_MMRATF (1 << 3) | ||
/* ssc2: PSPSTWFDFD */ | ||
#define SOF_DAI_INTEL_SSP_QUIRK_PSPSTWFDFD (1 << 4) | ||
/* ssc2: PSPSRWFDFD */ | ||
#define SOF_DAI_INTEL_SSP_QUIRK_PSPSRWFDFD (1 << 5) | ||
/* ssc1: LBM */ | ||
#define SOF_DAI_INTEL_SSP_QUIRK_LBM (1 << 6) | ||
|
||
/* here is the possibility to define others aux macros */ | ||
|
||
#define SOF_DAI_INTEL_SSP_FRAME_PULSE_WIDTH_MAX 38 | ||
#define SOF_DAI_INTEL_SSP_SLOT_PADDING_MAX 31 | ||
|
||
/* SSP clocks control settings | ||
* | ||
* Macros for clks_control field in sof_ipc_dai_ssp_params struct. | ||
*/ | ||
|
||
/* mclk 0 disable */ | ||
#define SOF_DAI_INTEL_SSP_MCLK_0_DISABLE BIT(0) | ||
/* mclk 1 disable */ | ||
#define SOF_DAI_INTEL_SSP_MCLK_1_DISABLE BIT(1) | ||
/* mclk keep active */ | ||
#define SOF_DAI_INTEL_SSP_CLKCTRL_MCLK_KA BIT(2) | ||
/* bclk keep active */ | ||
#define SOF_DAI_INTEL_SSP_CLKCTRL_BCLK_KA BIT(3) | ||
/* fs keep active */ | ||
#define SOF_DAI_INTEL_SSP_CLKCTRL_FS_KA BIT(4) | ||
/* bclk idle */ | ||
#define SOF_DAI_INTEL_SSP_CLKCTRL_BCLK_IDLE_HIGH BIT(5) | ||
|
||
/* SSP Configuration Request - SOF_IPC_DAI_SSP_CONFIG */ | ||
struct sof_ipc_dai_ssp_params { | ||
struct sof_ipc_hdr hdr; | ||
uint16_t reserved1; | ||
uint16_t mclk_id; | ||
|
||
uint32_t mclk_rate; /* mclk frequency in Hz */ | ||
uint32_t fsync_rate; /* fsync frequency in Hz */ | ||
uint32_t bclk_rate; /* bclk frequency in Hz */ | ||
|
||
/* TDM */ | ||
uint32_t tdm_slots; | ||
uint32_t rx_slots; | ||
uint32_t tx_slots; | ||
|
||
/* data */ | ||
uint32_t sample_valid_bits; | ||
uint16_t tdm_slot_width; | ||
uint16_t reserved2; /* alignment */ | ||
|
||
/* MCLK */ | ||
uint32_t mclk_direction; | ||
|
||
uint16_t frame_pulse_width; | ||
uint16_t tdm_per_slot_padding_flag; | ||
uint32_t clks_control; | ||
uint32_t quirks; | ||
} __packed; | ||
|
||
/* HDA Configuration Request - SOF_IPC_DAI_HDA_CONFIG */ | ||
struct sof_ipc_dai_hda_params { | ||
struct sof_ipc_hdr hdr; | ||
uint32_t link_dma_ch; | ||
} __packed; | ||
|
||
/* DMIC Configuration Request - SOF_IPC_DAI_DMIC_CONFIG */ | ||
|
||
/* This struct is defined per 2ch PDM controller available in the platform. | ||
* Normally it is sufficient to set the used microphone specific enables to 1 | ||
* and keep other parameters as zero. The customizations are: | ||
* | ||
* 1. If a device mixes different microphones types with different polarity | ||
* and/or the absolute polarity matters the PCM signal from a microphone | ||
* can be inverted with the controls. | ||
* | ||
* 2. If the microphones in a stereo pair do not appear in captured stream | ||
* in desired order due to board schematics choises they can be swapped with | ||
* the clk_edge parameter. | ||
* | ||
* 3. If PDM bit errors are seen in capture (poor quality) the skew parameter | ||
* that delays the sampling time of data by half cycles of DMIC source clock | ||
* can be tried for improvement. However there is no guarantee for this to fix | ||
* data integrity problems. | ||
*/ | ||
struct sof_ipc_dai_dmic_pdm_ctrl { | ||
struct sof_ipc_hdr hdr; | ||
uint16_t id; /**< PDM controller ID */ | ||
|
||
uint16_t enable_mic_a; /**< Use A (left) channel mic (0 or 1)*/ | ||
uint16_t enable_mic_b; /**< Use B (right) channel mic (0 or 1)*/ | ||
|
||
uint16_t polarity_mic_a; /**< Optionally invert mic A signal (0 or 1) */ | ||
uint16_t polarity_mic_b; /**< Optionally invert mic B signal (0 or 1) */ | ||
|
||
uint16_t clk_edge; /**< Optionally swap data clock edge (0 or 1) */ | ||
uint16_t skew; /**< Adjust PDM data sampling vs. clock (0..15) */ | ||
|
||
uint16_t reserved[3]; /**< Make sure the total size is 4 bytes aligned */ | ||
} __packed; | ||
|
||
/* This struct contains the global settings for all 2ch PDM controllers. The | ||
* version number used in configuration data is checked vs. version used by | ||
* device driver src/drivers/dmic.c need to match. It is incremented from | ||
* initial value 1 if updates done for the to driver would alter the operation | ||
* of the microhone. | ||
* | ||
* Note: The microphone clock (pdmclk_min, pdmclk_max, duty_min, duty_max) | ||
* parameters need to be set as defined in microphone data sheet. E.g. clock | ||
* range 1.0 - 3.2 MHz is usually supported microphones. Some microphones are | ||
* multi-mode capable and there may be denied mic clock frequencies between | ||
* the modes. In such case set the clock range limits of the desired mode to | ||
* avoid the driver to set clock to an illegal rate. | ||
* | ||
* The duty cycle could be set to 48-52% if not known. Generally these | ||
* parameters can be altered within data sheet specified limits to match | ||
* required audio application performance power. | ||
* | ||
* The microphone clock needs to be usually about 50-80 times the used audio | ||
* sample rate. With highest sample rates above 48 kHz this can relaxed | ||
* somewhat. | ||
* | ||
* The parameter wake_up_time describes how long time the microphone needs | ||
* for the data line to produce valid output from mic clock start. The driver | ||
* will mute the captured audio for the given time. The min_clock_on_time | ||
* parameter is used to prevent too short clock bursts to happen. The driver | ||
* will keep the clock active after capture stop if this time is not yet | ||
* met. The unit for both is microseconds (us). Exceed of 100 ms will be | ||
* treated as an error. | ||
*/ | ||
struct sof_ipc_dai_dmic_params { | ||
struct sof_ipc_hdr hdr; | ||
uint32_t driver_ipc_version; /**< Version (1..N) */ | ||
|
||
uint32_t pdmclk_min; /**< Minimum microphone clock in Hz (100000..N) */ | ||
uint32_t pdmclk_max; /**< Maximum microphone clock in Hz (min...N) */ | ||
|
||
uint32_t fifo_fs; /**< FIFO sample rate in Hz (8000..96000) */ | ||
uint32_t reserved_1; /**< Reserved */ | ||
uint16_t fifo_bits; /**< FIFO word length (16 or 32) */ | ||
uint16_t reserved_2; /**< Reserved */ | ||
|
||
uint16_t duty_min; /**< Min. mic clock duty cycle in % (20..80) */ | ||
uint16_t duty_max; /**< Max. mic clock duty cycle in % (min..80) */ | ||
|
||
uint32_t num_pdm_active; /**< Number of active pdm controllers */ | ||
|
||
uint32_t wake_up_time; /**< Time from clock start to data (us) */ | ||
uint32_t min_clock_on_time; /**< Min. time that clk is kept on (us) */ | ||
|
||
/* reserved for future use */ | ||
uint32_t reserved[6]; | ||
|
||
/**< variable number of pdm controller config */ | ||
struct sof_ipc_dai_dmic_pdm_ctrl pdm[0]; | ||
} __packed; | ||
|
||
#endif |
Oops, something went wrong.