/* Copyright (c) 2014 The Chromium OS Authors. All rights reserved. * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #ifndef CRAS_AUDIO_AREA_H_ #define CRAS_AUDIO_AREA_H_ #include <stdint.h> #include "cras_audio_format.h" /* * Descriptor of the memory area holding a channel of audio. * Members: * ch_set - Bit set of channels this channel area could map to. * step_bytes - The number of bytes between adjacent samples. * buf - A pointer to the start address of this area. */ struct cras_channel_area { unsigned int ch_set; unsigned int step_bytes; uint8_t *buf; }; /* * Descriptor of the memory area that provides various access to audio channels. * Members: * frames - The size of the audio buffer in frames. * num_channels - The number of channels in the audio area. * channels - array of channel areas. */ struct cras_audio_area { unsigned int frames; unsigned int num_channels; struct cras_channel_area channels[]; }; /* * Sets the channel bit for a channel area. * Args: * ca - the channel area to set channel bit set. * channel - the channel bit to add to the channel area. */ static inline void channel_area_set_channel(struct cras_channel_area *ca, enum CRAS_CHANNEL channel) { ca->ch_set |= (1 << channel); } /* * Creates a cras_audio_area. * Args: * num_channels - The number of channels in the audio area. */ struct cras_audio_area *cras_audio_area_create(int num_channels); /* * Copies a cras_audio_area to another cras_audio_area with given offset. * Args: * dst - The destination audio area. * dst_offset - The offset of dst audio area in frames. * format - The format of dst area. * src - The source audio area. * src_offset - The offset of src audio area in frames. * software_gain_scaler - The software gain scaler needed. * Returns the number of frames copied. */ unsigned int cras_audio_area_copy(const struct cras_audio_area *dst, unsigned int dst_offset, const struct cras_audio_format *dst_fmt, const struct cras_audio_area *src, unsigned int src_offset, float software_gain_scaler); /* * Destroys a cras_audio_area. * Args: * area - the audio area to destroy */ void cras_audio_area_destroy(struct cras_audio_area *area); /* * Configures the channel types based on the audio format. * Args: * area - The audio area created with cras_audio_area_create. * fmt - The format to use to configure the channels. */ void cras_audio_area_config_channels(struct cras_audio_area *area, const struct cras_audio_format *fmt); /* * Sets the buffer pointers for each channel. */ void cras_audio_area_config_buf_pointers(struct cras_audio_area *area, const struct cras_audio_format *fmt, uint8_t *base_buffer); #endif /* CRAS_AUDIO_AREA_H_ */