Loading...
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 | /*
* Copyright (c) 2018 Intel Corporation.
*
* SPDX-License-Identifier: Apache-2.0
*/
/**
* @file
* @brief Public API header file for Audio Codec
*
* This file contains the Audio Codec APIs
*/
#ifndef ZEPHYR_INCLUDE_AUDIO_CODEC_H_
#define ZEPHYR_INCLUDE_AUDIO_CODEC_H_
#include <drivers/i2s.h>
#ifdef __cplusplus
extern "C" {
#endif
/**
* PCM audio sample rates
*/
typedef enum {
AUDIO_PCM_RATE_8K = 8000,
AUDIO_PCM_RATE_16K = 16000,
AUDIO_PCM_RATE_24K = 24000,
AUDIO_PCM_RATE_32K = 32000,
AUDIO_PCM_RATE_44P1K = 44100,
AUDIO_PCM_RATE_48K = 48000,
AUDIO_PCM_RATE_96K = 96000,
AUDIO_PCM_RATE_192K = 192000,
} audio_pcm_rate_t;
/**
* PCM audio sample bit widths
*/
typedef enum {
AUDIO_PCM_WIDTH_16_BITS = 16,
AUDIO_PCM_WIDTH_20_BITS = 20,
AUDIO_PCM_WIDTH_24_BITS = 24,
AUDIO_PCM_WIDTH_32_BITS = 32,
} audio_pcm_width_t;
/**
* Digital Audio Interface (DAI) type
*/
typedef enum {
AUDIO_DAI_TYPE_I2S, /* I2S Interface */
AUDIO_DAI_TYPE_INVALID, /* Other interfaces can be added here */
} audio_dai_type_t;
/**
* Codec properties that can be set by audio_codec_set_property()
*/
typedef enum {
AUDIO_PROPERTY_OUTPUT_VOLUME,
AUDIO_PROPERTY_OUTPUT_MUTE,
} audio_property_t;
/**
* Audio channel identifiers to use in audio_codec_set_property()
*/
typedef enum {
AUDIO_CHANNEL_FRONT_LEFT,
AUDIO_CHANNEL_FRONT_RIGHT,
AUDIO_CHANNEL_LFE,
AUDIO_CHANNEL_FRONT_CENTER,
AUDIO_CHANNEL_REAR_LEFT,
AUDIO_CHANNEL_REAR_RIGHT,
AUDIO_CHANNEL_REAR_CENTER,
AUDIO_CHANNEL_SIDE_LEFT,
AUDIO_CHANNEL_SIDE_RIGHT,
AUDIO_CHANNEL_ALL,
} audio_channel_t;
/**
* Digital Audio Interface Configuration
* Configuration is dependent on DAI type
*/
typedef union {
struct i2s_config i2s; /* I2S configuration */
/* Other DAI types go here */
} audio_dai_cfg_t;
/**
* Codec configuration parameters
*/
struct audio_codec_cfg {
u32_t mclk_freq; /* MCLK input frequency in Hz */
audio_dai_type_t dai_type; /* Digital interface type */
audio_dai_cfg_t dai_cfg; /* DAI configuration info */
};
/**
* Codec property values
*/
typedef union {
int vol; /* Volume level in 0.5dB resolution */
bool mute; /* mute if true, unmute if false */
} audio_property_value_t;
/**
* @cond INTERNAL_HIDDEN
*
* For internal use only, skip these in public documentation.
*/
struct audio_codec_api {
int (*configure)(struct device *dev, struct audio_codec_cfg *cfg);
void (*start_output)(struct device *dev);
void (*stop_output)(struct device *dev);
int (*set_property)(struct device *dev, audio_property_t property,
audio_channel_t channel, audio_property_value_t val);
int (*apply_properties)(struct device *dev);
};
/**
* @endcond
*/
/**
* @brief Configure the audio codec
*
* Configure the audio codec device according to the configuration
* parameters provided as input
*
* @param dev Pointer to the device structure for codec driver instance.
* @param cfg Pointer to the structure containing the codec configuration.
*
* @return 0 on success, negative error code on failure
*/
static inline int audio_codec_configure(struct device *dev,
struct audio_codec_cfg *cfg)
{
const struct audio_codec_api *api = dev->driver_api;
return api->configure(dev, cfg);
}
/**
* @brief Set codec to start output audio playback
*
* Setup the audio codec device to start the audio playback
*
* @param dev Pointer to the device structure for codec driver instance.
*
* @return none
*/
static inline void audio_codec_start_output(struct device *dev)
{
const struct audio_codec_api *api = dev->driver_api;
api->start_output(dev);
}
/**
* @brief Set codec to stop output audio playback
*
* Setup the audio codec device to stop the audio playback
*
* @param dev Pointer to the device structure for codec driver instance.
*
* @return none
*/
static inline void audio_codec_stop_output(struct device *dev)
{
const struct audio_codec_api *api = dev->driver_api;
api->stop_output(dev);
}
/**
* @brief Set a codec property defined by audio_property_t
*
* Set a property such as volume level, clock configuration etc.
*
* @param dev Pointer to the device structure for codec driver instance.
* @param property The codec property to set
* @param channel The audio channel for which the property has to be set
* @param val pointer to a property value of type audio_codec_property_value_t
*
* @return 0 on success, negative error code on failure
*/
static inline int audio_codec_set_property(struct device *dev, audio_property_t property,
audio_channel_t channel, audio_property_value_t val)
{
const struct audio_codec_api *api = dev->driver_api;
return api->set_property(dev, property, channel, val);
}
/**
* @brief Atomically apply any cached properties
*
* Following one or more invocations of audio_codec_set_property, that may have
* been cached by the driver, audio_codec_apply_properties can be invoked to
* apply all the properties as atomic as possible
*
* @param dev Pointer to the device structure for codec driver instance.
*
* @return 0 on success, negative error code on failure
*/
static inline int audio_codec_apply_properties(struct device *dev)
{
const struct audio_codec_api *api = dev->driver_api;
return api->apply_properties(dev);
}
#ifdef __cplusplus
}
#endif
#endif /* ZEPHYR_INCLUDE_AUDIO_CODEC_H_ */
|