Zephyr API Documentation 4.4.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
dmic.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2018, Intel Corporation
3 *
4 * Author: Seppo Ingalsuo <seppo.ingalsuo@linux.intel.com>
5 * Sathish Kuttan <sathish.k.kuttan@intel.com>
6 *
7 * SPDX-License-Identifier: Apache-2.0
8 */
9
16
17#ifndef ZEPHYR_INCLUDE_AUDIO_DMIC_H_
18#define ZEPHYR_INCLUDE_AUDIO_DMIC_H_
19
20
26
36
37#include <zephyr/kernel.h>
38#include <zephyr/device.h>
39#include <zephyr/devicetree.h>
40
41#ifdef __cplusplus
42extern "C" {
43#endif
44
56
67
75
110
116#define PDM_DT_IO_CFG_GET(node_id) \
117 { \
118 .min_pdm_clk_freq = DT_PROP(node_id, clk_frequency_min), \
119 .max_pdm_clk_freq = DT_PROP(node_id, clk_frequency_max), \
120 .min_pdm_clk_dc = DT_PROP(node_id, clk_duty_cycle_min), \
121 .max_pdm_clk_dc = DT_PROP(node_id, clk_duty_cycle_max), \
122 }
123
129#define PDM_DT_HAS_LEFT_CHANNEL(node_id) DT_PROP(node_id, channel_left)
130
136#define PDM_DT_HAS_RIGHT_CHANNEL(node_id) DT_PROP(node_id, channel_right)
137
154
202
215
220
225typedef int (*dmic_configure_t)(const struct device *dev, struct dmic_cfg *config);
226
231typedef int (*dmic_trigger_t)(const struct device *dev, enum dmic_trigger cmd);
232
237typedef int (*dmic_read_t)(const struct device *dev, uint8_t stream, void **buffer,
238 size_t *size, int32_t timeout);
239
246#define _dmic_ops dmic_driver_api __DEPRECATED_MACRO
247
265
269
283 enum pdm_lr lr)
284{
285 return ((((pdm & BIT_MASK(3)) << 1) | lr) <<
286 ((channel & BIT_MASK(3)) * 4U));
287}
288
301static inline void dmic_parse_channel_map(uint32_t channel_map_lo,
302 uint32_t channel_map_hi, uint8_t channel, uint8_t *pdm, enum pdm_lr *lr)
303{
304 uint32_t channel_map;
305
306 channel_map = (channel < 8) ? channel_map_lo : channel_map_hi;
307 channel_map >>= ((channel & BIT_MASK(3)) * 4U);
308
309 *pdm = (channel_map >> 1) & BIT_MASK(3);
310 *lr = (enum pdm_lr) (channel_map & BIT(0));
311}
312
325{
326 return ((skew & BIT_MASK(4)) << ((pdm & BIT_MASK(3)) * 4U));
327}
328
340static inline int dmic_configure(const struct device *dev,
341 struct dmic_cfg *cfg)
342{
343 return DEVICE_API_GET(dmic, dev)->configure(dev, cfg);
344}
345
356static inline int dmic_trigger(const struct device *dev,
357 enum dmic_trigger cmd)
358{
359 return DEVICE_API_GET(dmic, dev)->trigger(dev, cmd);
360}
361
377static inline int dmic_read(const struct device *dev, uint8_t stream,
378 void **buffer,
379 size_t *size, int32_t timeout)
380{
381 return DEVICE_API_GET(dmic, dev)->read(dev, stream, buffer, size, timeout);
382}
383
384#ifdef __cplusplus
385}
386#endif
387
391
392#endif /* ZEPHYR_INCLUDE_AUDIO_DMIC_H_ */
#define DEVICE_API_GET(_class, _dev)
Expands to the pointer of a device's API for a given class.
Definition device.h:1375
Devicetree main header.
int(* dmic_trigger_t)(const struct device *dev, enum dmic_trigger cmd)
Callback API to send a command to a DMIC device.
Definition dmic.h:231
int(* dmic_read_t)(const struct device *dev, uint8_t stream, void **buffer, size_t *size, int32_t timeout)
Callback API to read PCM data from a DMIC device.
Definition dmic.h:237
int(* dmic_configure_t)(const struct device *dev, struct dmic_cfg *config)
Callback API to configure a DMIC device.
Definition dmic.h:225
static int dmic_configure(const struct device *dev, struct dmic_cfg *cfg)
Configure the DMIC driver and controller(s).
Definition dmic.h:340
dmic_trigger
DMIC driver trigger commands.
Definition dmic.h:60
static uint32_t dmic_build_channel_map(uint8_t channel, uint8_t pdm, enum pdm_lr lr)
Build the channel map to populate struct pdm_chan_cfg.
Definition dmic.h:282
static int dmic_read(const struct device *dev, uint8_t stream, void **buffer, size_t *size, int32_t timeout)
Read received decimated PCM data stream.
Definition dmic.h:377
pdm_lr
PDM Channels LEFT / RIGHT.
Definition dmic.h:71
static void dmic_parse_channel_map(uint32_t channel_map_lo, uint32_t channel_map_hi, uint8_t channel, uint8_t *pdm, enum pdm_lr *lr)
Helper function to parse the channel map in pdm_chan_cfg.
Definition dmic.h:301
dmic_state
DMIC driver states.
Definition dmic.h:48
static uint32_t dmic_build_clk_skew_map(uint8_t pdm, uint8_t skew)
Build a bit map of clock skew values for each PDM channel.
Definition dmic.h:324
@ DMIC_TRIGGER_START
Start stream.
Definition dmic.h:62
@ DMIC_TRIGGER_PAUSE
Pause stream.
Definition dmic.h:63
@ DMIC_TRIGGER_RELEASE
Release paused stream.
Definition dmic.h:64
@ DMIC_TRIGGER_RESET
Reset stream.
Definition dmic.h:65
@ DMIC_TRIGGER_STOP
Stop stream.
Definition dmic.h:61
@ PDM_CHAN_RIGHT
Right channel.
Definition dmic.h:73
@ PDM_CHAN_LEFT
Left channel.
Definition dmic.h:72
@ DMIC_STATE_PAUSED
Paused.
Definition dmic.h:53
@ DMIC_STATE_UNINIT
Uninitialized.
Definition dmic.h:49
@ DMIC_STATE_CONFIGURED
Configured.
Definition dmic.h:51
@ DMIC_STATE_INITIALIZED
Initialized.
Definition dmic.h:50
@ DMIC_STATE_ERROR
Error.
Definition dmic.h:54
@ DMIC_STATE_ACTIVE
Active.
Definition dmic.h:52
static void cmd(uint32_t command)
Execute a display list command by co-processor engine.
Definition ft8xx_reference_api.h:153
#define BIT(n)
Unsigned integer with bit position n set (signed in assembly language).
Definition util_macro.h:44
#define BIT_MASK(n)
Bit mask with bits 0 through n-1 (inclusive) set, or 0 if n is 0.
Definition util_macro.h:74
Public kernel APIs.
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__INT32_TYPE__ int32_t
Definition stdint.h:74
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Runtime device structure (in ROM) per driver instance.
Definition device.h:513
Input configuration structure for the DMIC configuration API.
Definition dmic.h:206
struct pcm_stream_cfg * streams
Array of pcm_stream_cfg for application to provide configuration for each stream.
Definition dmic.h:212
struct pdm_chan_cfg channel
Definition dmic.h:213
struct pdm_io_cfg io
Definition dmic.h:207
<span class="mlabel">Driver Operations</span> Digital Microphone driver operations
Definition dmic.h:251
dmic_configure_t configure
<span class="op-badge op-req" title="This operation MUST be implemented by the driver....
Definition dmic.h:255
dmic_read_t read
<span class="op-badge op-req" title="This operation MUST be implemented by the driver....
Definition dmic.h:263
dmic_trigger_t trigger
<span class="op-badge op-req" title="This operation MUST be implemented by the driver....
Definition dmic.h:259
Configuration of the PCM streams to be output by the PDM hardware.
Definition dmic.h:144
uint16_t block_size
PCM sample block size per transfer.
Definition dmic.h:150
uint8_t pcm_width
PCM sample width of stream.
Definition dmic.h:148
struct k_mem_slab * mem_slab
SLAB for DMIC driver to allocate buffers for stream.
Definition dmic.h:152
uint32_t pcm_rate
PCM sample rate of stream.
Definition dmic.h:146
Mapping/ordering of the PDM channels to logical PCM output channel.
Definition dmic.h:176
uint32_t req_chan_map_lo
Channels 0 to 7.
Definition dmic.h:181
uint32_t req_chan_map_hi
Channels 8 to 15.
Definition dmic.h:182
uint8_t act_num_chan
Actual number of channels that the driver could configure.
Definition dmic.h:196
uint32_t act_chan_map_lo
Channels 0 to 7.
Definition dmic.h:189
uint8_t act_num_streams
Actual number of streams that the driver could configure.
Definition dmic.h:200
uint32_t act_chan_map_hi
Channels 8 to 15.
Definition dmic.h:190
uint8_t req_num_chan
Requested number of channels.
Definition dmic.h:194
uint8_t req_num_streams
Requested number of streams for each channel.
Definition dmic.h:198
PDM Input/Output signal configuration.
Definition dmic.h:79
uint8_t min_pdm_clk_dc
Minimum duty cycle in % supported by the mic.
Definition dmic.h:89
uint8_t pdm_clk_pol
Bit mask to optionally invert PDM clock.
Definition dmic.h:101
uint32_t max_pdm_clk_freq
Maximum clock frequency supported by the mic.
Definition dmic.h:87
uint32_t pdm_clk_skew
Collection of clock skew values for each PDM port.
Definition dmic.h:105
uint8_t max_pdm_clk_dc
Maximum duty cycle in % supported by the mic.
Definition dmic.h:91
uint8_t pdm_data_pol
Bit mask to optionally invert mic data.
Definition dmic.h:103
uint32_t min_pdm_clk_freq
Minimum clock frequency supported by the mic.
Definition dmic.h:85