Zephyr API Documentation  3.6.0
A Scalable Open Source RTOS
3.6.0
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
codec.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2018 Intel Corporation.
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
14#ifndef ZEPHYR_INCLUDE_AUDIO_CODEC_H_
15#define ZEPHYR_INCLUDE_AUDIO_CODEC_H_
16
25#include <zephyr/drivers/i2s.h>
26
27#ifdef __cplusplus
28extern "C" {
29#endif
30
34typedef enum {
44
48typedef enum {
54
58typedef enum {
62
66typedef enum {
70
74typedef enum {
86
92typedef union {
93 struct i2s_config i2s;
94 /* Other DAI types go here */
96
104};
105
109typedef union {
110 int vol;
111 bool mute;
113
120
123
126
129
132};
133
141typedef void (*audio_codec_error_callback_t)(const struct device *dev, uint32_t errors);
142
148struct audio_codec_api {
149 int (*configure)(const struct device *dev,
150 struct audio_codec_cfg *cfg);
151 void (*start_output)(const struct device *dev);
152 void (*stop_output)(const struct device *dev);
153 int (*set_property)(const struct device *dev,
154 audio_property_t property,
155 audio_channel_t channel,
157 int (*apply_properties)(const struct device *dev);
158 int (*clear_errors)(const struct device *dev);
159 int (*register_error_callback)(const struct device *dev,
161};
177static inline int audio_codec_configure(const struct device *dev,
178 struct audio_codec_cfg *cfg)
179{
180 const struct audio_codec_api *api =
181 (const struct audio_codec_api *)dev->api;
182
183 return api->configure(dev, cfg);
184}
185
193static inline void audio_codec_start_output(const struct device *dev)
194{
195 const struct audio_codec_api *api =
196 (const struct audio_codec_api *)dev->api;
197
198 api->start_output(dev);
199}
200
208static inline void audio_codec_stop_output(const struct device *dev)
209{
210 const struct audio_codec_api *api =
211 (const struct audio_codec_api *)dev->api;
212
213 api->stop_output(dev);
214}
215
228static inline int audio_codec_set_property(const struct device *dev,
229 audio_property_t property,
230 audio_channel_t channel,
232{
233 const struct audio_codec_api *api =
234 (const struct audio_codec_api *)dev->api;
235
236 return api->set_property(dev, property, channel, val);
237}
238
250static inline int audio_codec_apply_properties(const struct device *dev)
251{
252 const struct audio_codec_api *api =
253 (const struct audio_codec_api *)dev->api;
254
255 return api->apply_properties(dev);
256}
257
268static inline int audio_codec_clear_errors(const struct device *dev)
269{
270 const struct audio_codec_api *api =
271 (const struct audio_codec_api *)dev->api;
272
273 if (api->clear_errors == NULL) {
274 return -ENOSYS;
275 }
276
277 return api->clear_errors(dev);
278}
279
294static inline int audio_codec_register_error_callback(const struct device *dev,
296{
297 const struct audio_codec_api *api =
298 (const struct audio_codec_api *)dev->api;
299
300 if (api->register_error_callback == NULL) {
301 return -ENOSYS;
302 }
303
304 return api->register_error_callback(dev, cb);
305}
306
307#ifdef __cplusplus
308}
309#endif
310
315#endif /* ZEPHYR_INCLUDE_AUDIO_CODEC_H_ */
static int audio_codec_configure(const struct device *dev, struct audio_codec_cfg *cfg)
Configure the audio codec.
Definition: codec.h:177
audio_dai_type_t
Digital Audio Interface (DAI) type.
Definition: codec.h:58
static void audio_codec_start_output(const struct device *dev)
Set codec to start output audio playback.
Definition: codec.h:193
audio_pcm_width_t
PCM audio sample bit widths.
Definition: codec.h:48
audio_codec_error_type
Codec error type.
Definition: codec.h:117
audio_property_t
Codec properties that can be set by audio_codec_set_property().
Definition: codec.h:66
static int audio_codec_clear_errors(const struct device *dev)
Clear any codec errors.
Definition: codec.h:268
static int audio_codec_set_property(const struct device *dev, audio_property_t property, audio_channel_t channel, audio_property_value_t val)
Set a codec property defined by audio_property_t.
Definition: codec.h:228
static void audio_codec_stop_output(const struct device *dev)
Set codec to stop output audio playback.
Definition: codec.h:208
audio_pcm_rate_t
PCM audio sample rates.
Definition: codec.h:34
static int audio_codec_register_error_callback(const struct device *dev, audio_codec_error_callback_t cb)
Register a callback function for codec error.
Definition: codec.h:294
audio_channel_t
Audio channel identifiers to use in audio_codec_set_property().
Definition: codec.h:74
void(* audio_codec_error_callback_t)(const struct device *dev, uint32_t errors)
Callback for error interrupt.
Definition: codec.h:141
static int audio_codec_apply_properties(const struct device *dev)
Atomically apply any cached properties.
Definition: codec.h:250
@ AUDIO_DAI_TYPE_I2S
I2S Interface.
Definition: codec.h:59
@ AUDIO_DAI_TYPE_INVALID
Other interfaces can be added here.
Definition: codec.h:60
@ AUDIO_PCM_WIDTH_16_BITS
16-bit sample width
Definition: codec.h:49
@ AUDIO_PCM_WIDTH_32_BITS
32-bit sample width
Definition: codec.h:52
@ AUDIO_PCM_WIDTH_20_BITS
20-bit sample width
Definition: codec.h:50
@ AUDIO_PCM_WIDTH_24_BITS
24-bit sample width
Definition: codec.h:51
@ AUDIO_CODEC_ERROR_UNDERVOLTAGE
Power low voltage.
Definition: codec.h:125
@ AUDIO_CODEC_ERROR_OVERVOLTAGE
Power high voltage.
Definition: codec.h:128
@ AUDIO_CODEC_ERROR_OVERTEMPERATURE
Codec over-temperature.
Definition: codec.h:122
@ AUDIO_CODEC_ERROR_DC
Output direct-current.
Definition: codec.h:131
@ AUDIO_CODEC_ERROR_OVERCURRENT
Output over-current.
Definition: codec.h:119
@ AUDIO_PROPERTY_OUTPUT_VOLUME
Output volume.
Definition: codec.h:67
@ AUDIO_PROPERTY_OUTPUT_MUTE
Output mute/unmute.
Definition: codec.h:68
@ AUDIO_PCM_RATE_32K
32 kHz sample rate
Definition: codec.h:38
@ AUDIO_PCM_RATE_192K
192 kHz sample rate
Definition: codec.h:42
@ AUDIO_PCM_RATE_8K
8 kHz sample rate
Definition: codec.h:35
@ AUDIO_PCM_RATE_48K
48 kHz sample rate
Definition: codec.h:40
@ AUDIO_PCM_RATE_44P1K
44.1 kHz sample rate
Definition: codec.h:39
@ AUDIO_PCM_RATE_96K
96 kHz sample rate
Definition: codec.h:41
@ AUDIO_PCM_RATE_16K
16 kHz sample rate
Definition: codec.h:36
@ AUDIO_PCM_RATE_24K
24 kHz sample rate
Definition: codec.h:37
@ AUDIO_CHANNEL_FRONT_LEFT
Front left channel.
Definition: codec.h:75
@ AUDIO_CHANNEL_FRONT_RIGHT
Front right channel.
Definition: codec.h:76
@ AUDIO_CHANNEL_ALL
All channels.
Definition: codec.h:84
@ AUDIO_CHANNEL_REAR_RIGHT
Rear right channel.
Definition: codec.h:80
@ AUDIO_CHANNEL_REAR_LEFT
Rear left channel.
Definition: codec.h:79
@ AUDIO_CHANNEL_LFE
Low frequency effect channel.
Definition: codec.h:77
@ AUDIO_CHANNEL_SIDE_RIGHT
Side right channel.
Definition: codec.h:83
@ AUDIO_CHANNEL_FRONT_CENTER
Front center channel.
Definition: codec.h:78
@ AUDIO_CHANNEL_SIDE_LEFT
Side left channel.
Definition: codec.h:82
@ AUDIO_CHANNEL_REAR_CENTER
Rear center channel.
Definition: codec.h:81
#define BIT(n)
Unsigned integer with bit position n set (signed in assembly language).
Definition: util_macro.h:44
#define ENOSYS
Function not implemented.
Definition: errno.h:83
Public APIs for the I2S (Inter-IC Sound) bus drivers.
__UINT32_TYPE__ uint32_t
Definition: stdint.h:90
Codec configuration parameters.
Definition: codec.h:100
audio_dai_type_t dai_type
Digital interface type.
Definition: codec.h:102
uint32_t mclk_freq
MCLK input frequency in Hz.
Definition: codec.h:101
audio_dai_cfg_t dai_cfg
DAI configuration info.
Definition: codec.h:103
Runtime device structure (in ROM) per driver instance.
Definition: device.h:387
const void * api
Address of the API structure exposed by the device instance.
Definition: device.h:393
Interface configuration options.
Definition: i2s.h:293
Digital Audio Interface Configuration.
Definition: codec.h:92
Codec property values.
Definition: codec.h:109
bool mute
Mute if true, unmute if false.
Definition: codec.h:111
int vol
Volume level in 0.5dB resolution.
Definition: codec.h:110