// Copyright 2018 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. module media.mojom; import "mojo/public/mojom/base/shared_memory.mojom"; // Used by audio streams for realtime-ish data transfer. ReadWriteAudioDataPipe // is used for output streams and ReadOnlyAudioDataPipe is used for input // streams, see AudioDeviceThread, AudioSyncReader, and AudioInputSyncWriter. // |socket| is a base::SyncSocket used for signaling and |shared_memory| is used // for the actual audio data. // // When using a pull model, the code pulling the data writes |n| (an unsigned // 32 bit sequence number) to the socket, and the source from which data is // pulled writes a buffer to |shared_memory| and writes |n| back to signal that // it finished writing. Then the process continues with |n+1|. This model is // used to get data for playout. // // When using a push model, the code pushing data writes a buffer to // |shared_memory| and writes |n| to the socket. When the other side finished // reading the buffer, it writes |n| to the socket to signal that the memory is // safe to write to again. |shared_memory| may have room for several buffers, // in which case the next buffer can be pushed without waiting for the previous // one to be consumed. This model used is to deliver microphone data to a // consumer. struct ReadWriteAudioDataPipe { mojo_base.mojom.UnsafeSharedMemoryRegion shared_memory; handle socket; }; struct ReadOnlyAudioDataPipe { mojo_base.mojom.ReadOnlySharedMemoryRegion shared_memory; handle socket; };