2014-08-25 17:26:09 +04:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* vim:set ts=2 sw=2 sts=2 et cindent: */
|
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
|
|
|
|
#if !defined(CubebUtils_h_)
|
|
|
|
# define CubebUtils_h_
|
|
|
|
|
|
|
|
# include "cubeb/cubeb.h"
|
2022-04-18 21:45:35 +03:00
|
|
|
|
|
|
|
# include "AudioSampleFormat.h"
|
2018-07-18 11:38:34 +03:00
|
|
|
# include "nsString.h"
|
2014-08-25 17:26:09 +04:00
|
|
|
|
2018-07-18 11:38:34 +03:00
|
|
|
class AudioDeviceInfo;
|
|
|
|
|
2019-04-16 18:42:42 +03:00
|
|
|
MOZ_MAKE_ENUM_CLASS_BITWISE_OPERATORS(cubeb_stream_prefs)
|
|
|
|
|
2014-08-25 17:26:09 +04:00
|
|
|
namespace mozilla {
|
2020-06-23 19:43:22 +03:00
|
|
|
|
|
|
|
class AudioThreadRegistry;
|
|
|
|
|
2014-09-15 10:09:00 +04:00
|
|
|
namespace CubebUtils {
|
|
|
|
|
2016-01-21 19:51:36 +03:00
|
|
|
typedef cubeb_devid AudioDeviceID;
|
|
|
|
|
2022-04-18 21:45:35 +03:00
|
|
|
template <AudioSampleFormat N>
|
|
|
|
struct ToCubebFormat {
|
|
|
|
static const cubeb_sample_format value = CUBEB_SAMPLE_FLOAT32NE;
|
|
|
|
};
|
|
|
|
|
|
|
|
template <>
|
|
|
|
struct ToCubebFormat<AUDIO_FORMAT_S16> {
|
|
|
|
static const cubeb_sample_format value = CUBEB_SAMPLE_S16NE;
|
|
|
|
};
|
|
|
|
|
2014-09-15 10:09:00 +04:00
|
|
|
// Initialize Audio Library. Some Audio backends require initializing the
|
|
|
|
// library before using it.
|
|
|
|
void InitLibrary();
|
|
|
|
|
|
|
|
// Shutdown Audio Library. Some Audio backends require shutting down the
|
|
|
|
// library after using it.
|
|
|
|
void ShutdownLibrary();
|
|
|
|
|
2020-06-12 16:33:04 +03:00
|
|
|
bool SandboxEnabled();
|
|
|
|
|
2020-06-23 19:43:22 +03:00
|
|
|
// Returns the global instance of AudioThreadRegistry. Initialized and
|
|
|
|
// destroying in Init/ShutdownLibrary(), and safe from all threads.
|
|
|
|
AudioThreadRegistry* GetAudioThreadRegistry();
|
|
|
|
|
2014-09-15 10:09:00 +04:00
|
|
|
// Returns the maximum number of channels supported by the audio hardware.
|
2014-09-15 10:10:00 +04:00
|
|
|
uint32_t MaxNumberOfChannels();
|
2014-09-15 10:09:00 +04:00
|
|
|
|
2016-09-18 07:32:22 +03:00
|
|
|
// Get the sample rate the hardware/mixer runs at. Thread safe.
|
2014-09-15 10:10:00 +04:00
|
|
|
uint32_t PreferredSampleRate();
|
2014-09-15 10:09:00 +04:00
|
|
|
|
2022-05-24 14:41:07 +03:00
|
|
|
// Initialize a cubeb stream. A pass through wrapper for cubeb_stream_init,
|
|
|
|
// that can simulate streams that are very slow to start, by setting the pref
|
|
|
|
// media.cubeb.slow_stream_init_ms.
|
|
|
|
int CubebStreamInit(cubeb * context, cubeb_stream ** stream,
|
|
|
|
char const * stream_name, cubeb_devid input_device,
|
|
|
|
cubeb_stream_params * input_stream_params,
|
|
|
|
cubeb_devid output_device,
|
|
|
|
cubeb_stream_params * output_stream_params,
|
|
|
|
uint32_t latency_frames, cubeb_data_callback data_callback,
|
|
|
|
cubeb_state_callback state_callback, void * user_ptr);
|
|
|
|
|
2017-07-18 11:09:10 +03:00
|
|
|
enum Side { Input, Output };
|
|
|
|
|
2014-09-15 10:09:00 +04:00
|
|
|
double GetVolumeScale();
|
|
|
|
bool GetFirstStream();
|
|
|
|
cubeb* GetCubebContext();
|
2016-06-23 18:50:52 +03:00
|
|
|
void ReportCubebStreamInitFailure(bool aIsFirstStream);
|
|
|
|
void ReportCubebBackendUsed();
|
2016-09-09 16:21:50 +03:00
|
|
|
uint32_t GetCubebPlaybackLatencyInMilliseconds();
|
2019-10-02 13:23:02 +03:00
|
|
|
uint32_t GetCubebMTGLatencyInFrames(cubeb_stream_params* params);
|
2014-09-15 10:09:00 +04:00
|
|
|
bool CubebLatencyPrefSet();
|
2016-07-26 01:50:14 +03:00
|
|
|
void GetCurrentBackend(nsAString& aBackend);
|
2020-10-20 23:03:26 +03:00
|
|
|
cubeb_stream_prefs GetDefaultStreamPrefs(cubeb_device_type aType);
|
2018-08-01 15:16:30 +03:00
|
|
|
char* GetForcedOutputDevice();
|
2019-04-16 18:42:33 +03:00
|
|
|
// No-op on all platforms but Android, where it tells the device's AudioManager
|
|
|
|
// to switch to "communication mode", which might change audio routing,
|
|
|
|
// bluetooth communication type, etc.
|
|
|
|
void SetInCommunication(bool aInCommunication);
|
2020-05-12 11:31:58 +03:00
|
|
|
// Returns true if the output streams should be routed like a stream containing
|
|
|
|
// voice data, and not generic audio. This can influence audio processing and
|
|
|
|
// device selection.
|
|
|
|
bool RouteOutputAsVoice();
|
2020-05-28 12:50:55 +03:00
|
|
|
// Returns, in seconds, the roundtrip latency Gecko thinks there is between the
|
|
|
|
// default input and output devices. This is for diagnosing purposes, the
|
|
|
|
// latency figures are best used directly from the cubeb streams themselves, as
|
|
|
|
// the devices being used matter. This is blocking.
|
|
|
|
bool EstimatedRoundTripLatencyDefaultDevices(double* aMean, double* aStdDev);
|
2018-02-20 16:37:07 +03:00
|
|
|
|
|
|
|
# ifdef MOZ_WIDGET_ANDROID
|
|
|
|
uint32_t AndroidGetAudioOutputSampleRate();
|
|
|
|
uint32_t AndroidGetAudioOutputFramesPerBuffer();
|
|
|
|
# endif
|
2018-06-22 12:45:31 +03:00
|
|
|
|
|
|
|
# ifdef ENABLE_SET_CUBEB_BACKEND
|
|
|
|
void ForceSetCubebContext(cubeb* aCubebContext);
|
|
|
|
# endif
|
2014-09-15 10:09:00 +04:00
|
|
|
} // namespace CubebUtils
|
|
|
|
} // namespace mozilla
|
2014-08-25 17:26:09 +04:00
|
|
|
|
|
|
|
#endif // CubebUtils_h_
|