123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291 |
- /*
- * Copyright (c) 2006-2025 RT-Thread Development Team
- *
- * SPDX-License-Identifier: Apache-2.0
- *
- * Change Logs:
- * Date Author Notes
- * 2017-05-09 Urey first version
- * 2019-07-09 Zero-Free improve device ops interface and data flows
- * 2025-03-04 wumingzi add doxygen comments.
- */
- #ifndef __DEV_AUDIO_H__
- #define __DEV_AUDIO_H__
- #include "dev_audio_pipe.h"
- /**
- * @defgroup group_Audio Audio
- * @brief Audio driver API.
- * @ingroup group_device_driver
- *
- * @{
- */
- /**
- * @defgroup group_audio_control AUDIO_CTL
- *
- * @brief Control audio device.
- *
- * @{
- */
- /**
- * @brief Generate audio command code with @a a
- *
- * @param[in] a offset of command.
- *
- * @return audio device control command code.
- */
- #define _AUDIO_CTL(a) (RT_DEVICE_CTRL_BASE(Sound) + a)
- #define AUDIO_CTL_GETCAPS _AUDIO_CTL(1) /**< Get audio device capabilities */
- #define AUDIO_CTL_CONFIGURE _AUDIO_CTL(2) /**< Get audio device configuration */
- #define AUDIO_CTL_START _AUDIO_CTL(3) /**< Start audio device */
- #define AUDIO_CTL_STOP _AUDIO_CTL(4) /**< Stop audio device */
- #define AUDIO_CTL_GETBUFFERINFO _AUDIO_CTL(5) /**< Get audio device buffer information */
- /** @} */ /* End of group_audio_control */
- /**
- * @defgroup group_audio_type AUDIO_TYPE
- *
- * @brief Audio Device Types
- *
- * @{
- */
- #define AUDIO_TYPE_QUERY 0x00 /**< Query audio device type */
- #define AUDIO_TYPE_INPUT 0x01 /**< Set audio device type to input type */
- #define AUDIO_TYPE_OUTPUT 0x02 /**< Set audio device type to output type */
- #define AUDIO_TYPE_MIXER 0x04 /**< Set audio device type to mixer type */
- /** @} */ /* End of group_audio_type */
- /**
- * @defgroup group_audio_samp_rates AUDIO_SAMP_RATES
- *
- * @brief Supported audio sample rates for the audio device.
- *
- * @{
- */
- #define AUDIO_SAMP_RATE_8K 0x0001 /**< Set audio device sample rate to 8K */
- #define AUDIO_SAMP_RATE_11K 0x0002 /**< Set audio device sample rate to 11K */
- #define AUDIO_SAMP_RATE_16K 0x0004 /**< Set audio device sample rate to 16K */
- #define AUDIO_SAMP_RATE_22K 0x0008 /**< Set audio device sample rate to 22K */
- #define AUDIO_SAMP_RATE_32K 0x0010 /**< Set audio device sample rate to 32K */
- #define AUDIO_SAMP_RATE_44K 0x0020 /**< Set audio device sample rate to 44K */
- #define AUDIO_SAMP_RATE_48K 0x0040 /**< Set audio device sample rate to 48K */
- #define AUDIO_SAMP_RATE_96K 0x0080 /**< Set audio device sample rate to 96K */
- #define AUDIO_SAMP_RATE_128K 0x0100 /**< Set audio device sample rate to 128K */
- #define AUDIO_SAMP_RATE_160K 0x0200 /**< Set audio device sample rate to 160K */
- #define AUDIO_SAMP_RATE_172K 0x0400 /**< Set audio device sample rate to 172K */
- #define AUDIO_SAMP_RATE_192K 0x0800 /**< Set audio device sample rate to 192K */
- /** @} */ /* End of group_audio_samp_rates */
- /**
- * @defgroup group_audio_bit_rates AUDIO_BIT_RATES
- *
- * @brief Supported bit rates for the audio device.
- *
- * @{
- */
- #define AUDIO_BIT_RATE_22K 0x01 /**< Set audio device bit rates to 22K */
- #define AUDIO_BIT_RATE_44K 0x02 /**< Set audio device bit rates to 44K */
- #define AUDIO_BIT_RATE_48K 0x04 /**< Set audio device bit rates to 48K */
- #define AUDIO_BIT_RATE_96K 0x08 /**< Set audio device bit rates to 96K */
- #define AUDIO_BIT_RATE_128K 0x10 /**< Set audio device bit rates to 128K */
- #define AUDIO_BIT_RATE_160K 0x20 /**< Set audio device bit rates to 160K */
- #define AUDIO_BIT_RATE_172K 0x40 /**< Set audio device bit rates to 172K */
- #define AUDIO_BIT_RATE_192K 0x80 /**< Set audio device bit rates to 192K */
- /** @} */ /* End of group_audio_bit_rates */
- /**
- * @defgroup group_audio_dsp AUDIO_DSP
- *
- * @brief Support Dsp(input/output) Units controls. The macro group from application level, can
- * set audio mixer parameters including samplerate, channels etc.
- *
- * @{
- */
- #define AUDIO_DSP_PARAM 0 /**< get/set all params */
- #define AUDIO_DSP_SAMPLERATE 1 /**< samplerate */
- #define AUDIO_DSP_CHANNELS 2 /**< channels */
- #define AUDIO_DSP_SAMPLEBITS 3 /**< sample bits width */
- /** @} */ /* End of group_audio_dsp */
- /**
- * @defgroup group_audio_mixer AUDIO_MIXER
- *
- * @brief Supported Mixer Units controls. The macro group from driver level, can set audio mixer
- * parameters including volume, frequence db, microphone etc.
- *
- * @{
- */
- #define AUDIO_MIXER_QUERY 0x0000 /**< Query mixer capabilities */
- #define AUDIO_MIXER_MUTE 0x0001 /**< Mute audio device */
- #define AUDIO_MIXER_VOLUME 0x0002 /**< Set mixer volume */
- #define AUDIO_MIXER_BASS 0x0004 /**< Set the low-frequency section of the mixer */
- #define AUDIO_MIXER_MID 0x0008 /**< Set the mid-frequency section of the mixer */
- #define AUDIO_MIXER_TREBLE 0x0010 /**< Set the high-frequency section of the mixer */
- #define AUDIO_MIXER_EQUALIZER 0x0020 /**< Set equalizer option */
- #define AUDIO_MIXER_LINE 0x0040 /**< Set line control option */
- #define AUDIO_MIXER_DIGITAL 0x0080 /**< Set digital source */
- #define AUDIO_MIXER_MIC 0x0100 /**< Set microphone option */
- #define AUDIO_MIXER_VITURAL 0x0200 /**< Set virtual audio option */
- #define AUDIO_MIXER_EXTEND 0x8000 /**< Extend mixer command */
- /** @} */ /* End of group_audio_mixer */
- #define AUDIO_VOLUME_MAX (100)
- #define AUDIO_VOLUME_MIN (0)
- #define CFG_AUDIO_REPLAY_QUEUE_COUNT 4
- /**
- * @enum audio_stream
- *
- * @brief Audio stream control command
- */
- enum audio_stream
- {
- AUDIO_STREAM_REPLAY = 0,
- AUDIO_STREAM_RECORD,
- AUDIO_STREAM_LAST = AUDIO_STREAM_RECORD,
- };
- /**
- * @brief Audio buffer info
- *
- * The preferred number and size of audio pipeline buffer for the audio device, it
- * will be used in rt_audio_replay struct.
- *
- */
- struct rt_audio_buf_info
- {
- rt_uint8_t *buffer; /**< Audio buffer information */
- rt_uint16_t block_size; /**< Audio block_size information for replay function */
- rt_uint16_t block_count; /**< Audio block_count information for replay function */
- rt_uint32_t total_size; /**< Audio total_size which is equal to block_size multiplying
- * block_count information for replay function */
- };
- struct rt_audio_device;
- struct rt_audio_caps;
- struct rt_audio_configure;
- /**
- * @brief Aduio device operators
- */
- struct rt_audio_ops
- {
- /** Get audio capabilities information */
- rt_err_t (*getcaps)(struct rt_audio_device *audio, struct rt_audio_caps *caps);
- /** Configure audio devices */
- rt_err_t (*configure)(struct rt_audio_device *audio, struct rt_audio_caps *caps);
- /** Initialize audio device */
- rt_err_t (*init)(struct rt_audio_device *audio);
- /** Turn on the audio device */
- rt_err_t (*start)(struct rt_audio_device *audio, int stream);
- /** Turn off the audio device */
- rt_err_t (*stop)(struct rt_audio_device *audio, int stream);
- /** Transmit data between application and device */
- rt_ssize_t (*transmit)(struct rt_audio_device *audio, const void *writeBuf, void *readBuf, rt_size_t size);
- /** Get page size of codec or private buffer's info */
- void (*buffer_info)(struct rt_audio_device *audio, struct rt_audio_buf_info *info);
- };
- /**
- * @brief Audio configuration
- *
- * The preferred number and size of audio pipeline buffer for the audio device, it
- * will be used in rt_audio_caps struct.
- *
- */
- struct rt_audio_configure
- {
- rt_uint32_t samplerate; /**< Audio samplerate information */
- rt_uint16_t channels; /**< Audio channels information */
- rt_uint16_t samplebits; /**< Audio samplebits information */
- };
- /**
- * @brief Audio capabilities
- */
- struct rt_audio_caps
- {
- int main_type; /**< Audio main type, one value of @ref group_audio_type */
- int sub_type; /**< Audio sub type, one value of @ref group_audio_dsp or @ref group_audio_mixer */
- union
- {
- rt_uint32_t mask; /**< Capabilities mask */
- int value; /**< Capabilities value */
- struct rt_audio_configure config; /**< Audio samplebits information */
- } udata; /**< User data */
- };
- /**
- * @brief Audio replay
- */
- struct rt_audio_replay
- {
- struct rt_mempool *mp; /**< Memory pool for audio replay */
- struct rt_data_queue queue; /**< Replay data queue */
- struct rt_mutex lock; /**< Replay mutex lock */
- struct rt_completion cmp; /**< Replay completion, it will be */
- struct rt_audio_buf_info buf_info; /**< Replay buffer information */
- rt_uint8_t *write_data; /**< Pointer to the data to be written into data queue */
- rt_uint16_t write_index; /**< Index of pointer write_data.It records how much data
- * has been written in currently being played block */
- rt_uint16_t read_index; /**< Index of replaying data for audio device, it indicates index
- * of replay in the blocks which is currently being played */
- rt_uint32_t pos; /**< Global position of audio replay */
- rt_uint8_t event; /**< Event flag */
- rt_bool_t activated; /**< Activaty flag */
- };
- /**
- * @brief Audio record, the audio device pipe container of ringbuffer
- */
- struct rt_audio_record
- {
- struct rt_audio_pipe pipe;
- rt_bool_t activated;
- };
- /**
- * @brief Audio device
- */
- struct rt_audio_device
- {
- struct rt_device parent; /**< Audio device parents */
- struct rt_audio_ops *ops; /**< Audio device operator */
- struct rt_audio_replay *replay; /**< Pointer to audio replay structure */
- struct rt_audio_record *record; /**< Pointer to audio record structure */
- };
- rt_err_t rt_audio_register(struct rt_audio_device *audio, const char *name, rt_uint32_t flag, void *data);
- void rt_audio_tx_complete(struct rt_audio_device *audio);
- void rt_audio_rx_done(struct rt_audio_device *audio, rt_uint8_t *pbuf, rt_size_t len);
- /**
- * @defgroup group_audio_codec_cmd CODEC_CMD
- *
- * @brief Device Control Commands. The macro group from hardware level, can set codec
- * parametes including volume, EQ and 3D etc.
- *
- * @{
- */
- #define CODEC_CMD_RESET 0 /**< Reset audio device by codec */
- #define CODEC_CMD_SET_VOLUME 1 /**< Set volume by codec */
- #define CODEC_CMD_GET_VOLUME 2 /**< Get volume by codec */
- #define CODEC_CMD_SAMPLERATE 3 /**< Set sample rate by codec */
- #define CODEC_CMD_EQ 4 /**< Set equalizer by codec */
- #define CODEC_CMD_3D 5 /**< Set 3D effect by codec */
- #define CODEC_VOLUME_MAX (63)
- /** @} */ /* End of group_audio_codec_cmd */
- /** @} group_Audio */
- #endif /* __DEV_AUDIO_H__ */
|