Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(899)

Unified Diff: media/base/audio_bus.h

Issue 10824304: Upgrade AudioBus to support wrapping, interleaving. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase. Created 8 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: media/base/audio_bus.h
diff --git a/media/base/audio_bus.h b/media/base/audio_bus.h
index 0dff19576dde5c5129b206daa2076b689918647b..acf64919c716221c50861c733cde3cfe42fadb0f 100644
--- a/media/base/audio_bus.h
+++ b/media/base/audio_bus.h
@@ -15,28 +15,47 @@ namespace media {
class AudioParameters;
// Scoped container for "busing" audio channel data around. Each channel is
-// stored in planar format and guaranteed to have a 16-byte alignment. AudioBus
-// objects can be created normally or via wrapping. Normally, AudioBus will
-// dice up a contiguous memory block for channel data. When wrapped, AudioBus
-// instead routes requests for channel data to the wrapped object.
+// stored in planar format and guaranteed to be aligned by kChannelAlignment.
+// AudioBus objects can be created normally or via wrapping. Normally, AudioBus
+// will dice up a contiguous memory block for channel data. When wrapped,
+// AudioBus instead routes requests for channel data to the wrapped object.
class MEDIA_EXPORT AudioBus {
public:
+ // Guaranteed alignment of each channel's data; use 16-byte alignment for easy
+ // SSE optimizations.
+ enum { kChannelAlignment = 16 };
+
// Creates a new AudioBus and allocates |channels| of length |frames|. Uses
- // channels() and frames_per_buffer() if given an AudioParameters object.
+ // channels() and frames_per_buffer() from AudioParameters if given.
static scoped_ptr<AudioBus> Create(int channels, int frames);
static scoped_ptr<AudioBus> Create(const AudioParameters& params);
// Creates a new AudioBus from an existing channel vector. Does not transfer
// ownership of |channel_data| to AudioBus; i.e., |channel_data| must outlive
- // the returned AudioBus. Each channel pointer must be 16-byte aligned.
+ // the returned AudioBus. Each channel must be aligned by kChannelAlignment.
static scoped_ptr<AudioBus> WrapVector(
int frames, const std::vector<float*>& channel_data);
- // Returns a raw pointer to internal channel data. Useful for copying state
- // between two AudioBus objects created with the same parameters. data_size()
- // is in bytes. Can not be used with an AudioBus constructed via wrapping.
- void* data();
- int data_size() const;
+ // Creates a new AudioBus by wrapping an existing block of memory. Block must
+ // be at least CalculateMemorySize() bytes in size. |data| must outlive the
+ // returned AudioBus. |data| must be aligned by kChannelAlignment.
+ static scoped_ptr<AudioBus> WrapMemory(int channels, int frames, void* data);
+ static scoped_ptr<AudioBus> WrapMemory(const AudioParameters& params,
+ void* data);
Chris Rogers 2012/08/21 00:14:10 nit: my preference would be to have the void* para
+ // Returns the required memory size to use the WrapMemory() method.
+ static int CalculateMemorySize(const AudioParameters& params);
+
+ // Helper methods for converting an AudioBus from and to interleaved integer
+ // data. Expects interleaving to be [ch0, ch1, ..., chN, ch0, ch1, ...] with
+ // |bytes_per_sample| per value. Values are scaled and bias corrected during
+ // conversion. ToInterleaved() will also clip values to format range.
+ // Handles uint8, int16, and int32 currently.
+ void FromInterleaved(const void* source, int frames, int bytes_per_sample);
+ void ToInterleaved(int frames, int bytes_per_sample, void* dest) const;
Chris Rogers 2012/08/21 00:14:10 nit: it would be nice to have the pointer |dest| b
+
+ // Helper method for copying channel data from one AudioBus to another. Both
+ // AudioBus object must have the same frames() and channels().
+ void CopyTo(AudioBus* dest) const;
// Returns a raw pointer to the requested channel. Pointer is guaranteed to
// have a 16-byte alignment.
@@ -55,11 +74,15 @@ class MEDIA_EXPORT AudioBus {
~AudioBus();
AudioBus(int channels, int frames);
+ AudioBus(int channels, int frames, float* data);
Chris Rogers 2012/08/21 00:14:10 nit: |data| looks better as 1st argument
AudioBus(int frames, const std::vector<float*>& channel_data);
+ // Helper method for building |channel_data_| from a block of memory. |data|
+ // must be at least BlockSize() bytes in size.
+ void BuildChannelData(int channels, int aligned_frame, float* data);
Chris Rogers 2012/08/21 00:14:10 nit: |data| looks better as 1st argument
+
// Contiguous block of channel memory.
scoped_ptr_malloc<float, base::ScopedPtrAlignedFree> data_;
- int data_size_;
std::vector<float*> channel_data_;
int frames_;
« no previous file with comments | « media/audio/audio_util.cc ('k') | media/base/audio_bus.cc » ('j') | media/base/audio_bus.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698