summaryrefslogtreecommitdiff
path: root/indra/newview/llvoicewebrtc.h
diff options
context:
space:
mode:
authorRoxanne Skelly <roxie@lindenlab.com>2024-03-19 22:47:44 -0700
committerGitHub <noreply@github.com>2024-03-19 22:47:44 -0700
commit6047b61b2afc7eea0292e76920699aa7973bc33d (patch)
treea1e0973bb30f86a528d0ac07f14b0f10f899a462 /indra/newview/llvoicewebrtc.h
parent410be3b2d0ebbf6746140712430e54270541aecd (diff)
parent0e2fc4d35ea1fdef0028a5132602985da2e1c463 (diff)
Merge pull request #1021 from secondlife/roxie/webrtc-voice-workqueue
WebRTC: Make callbacks from webrtc-proper launch workqueue jobs to run code on the main thread, instead of relying on mutexes and such.
Diffstat (limited to 'indra/newview/llvoicewebrtc.h')
-rw-r--r--indra/newview/llvoicewebrtc.h31
1 files changed, 13 insertions, 18 deletions
diff --git a/indra/newview/llvoicewebrtc.h b/indra/newview/llvoicewebrtc.h
index b26bea27ce..21fc79420b 100644
--- a/indra/newview/llvoicewebrtc.h
+++ b/indra/newview/llvoicewebrtc.h
@@ -225,7 +225,8 @@ public:
void OnDevicesChanged(const llwebrtc::LLWebRTCVoiceDeviceList &render_devices,
const llwebrtc::LLWebRTCVoiceDeviceList &capture_devices) override;
//@}
-
+ void OnDevicesChangedImpl(const llwebrtc::LLWebRTCVoiceDeviceList &render_devices,
+ const llwebrtc::LLWebRTCVoiceDeviceList &capture_devices);
struct participantState
{
@@ -445,6 +446,8 @@ private:
/// Clean up objects created during a voice session.
void cleanUp();
+ LL::WorkQueue::weak_t mMainQueue;
+
bool mTuningMode;
F32 mTuningMicGain;
int mTuningSpeakerVolume;
@@ -585,7 +588,6 @@ class LLVoiceWebRTCConnection :
void OnOfferAvailable(const std::string &sdp) override;
void OnRenegotiationNeeded() override;
void OnAudioEstablished(llwebrtc::LLWebRTCAudioInterface *audio_interface) override;
- void OnPeerConnectionShutdown() override;
//@}
/////////////////////////
@@ -596,6 +598,8 @@ class LLVoiceWebRTCConnection :
void OnDataChannelReady(llwebrtc::LLWebRTCDataInterface *data_interface) override;
//@}
+ void OnDataReceivedImpl(const std::string &data, bool binary);
+
void sendJoin();
void sendData(const std::string &data);
@@ -618,12 +622,10 @@ class LLVoiceWebRTCConnection :
void shutDown()
{
- LLMutexLock lock(&mVoiceStateMutex);
mShutDown = true;
}
void OnVoiceConnectionRequestSuccess(const LLSD &body);
- void OnVoiceConnectionRequestFailure(std::string url, int retries, LLSD body, const LLSD &result);
protected:
typedef enum e_voice_connection_state
@@ -644,11 +646,10 @@ class LLVoiceWebRTCConnection :
} EVoiceConnectionState;
EVoiceConnectionState mVoiceConnectionState;
- LLMutex mVoiceStateMutex;
+ LL::WorkQueue::weak_t mMainQueue;
+
void setVoiceConnectionState(EVoiceConnectionState new_voice_connection_state)
{
- LLMutexLock lock(&mVoiceStateMutex);
-
if (new_voice_connection_state & VOICE_STATE_SESSION_STOPPING)
{
// the new state is shutdown or restart.
@@ -666,19 +667,13 @@ class LLVoiceWebRTCConnection :
}
EVoiceConnectionState getVoiceConnectionState()
{
- if (mVoiceStateMutex.isLocked())
- {
- LL_WARNS("Voice") << "LOCKED." << LL_ENDL;
- }
- LLMutexLock lock(&mVoiceStateMutex);
return mVoiceConnectionState;
}
- virtual bool requestVoiceConnection() = 0;
+ virtual void requestVoiceConnection() = 0;
+ void requestVoiceConnectionCoro() { requestVoiceConnection(); }
- bool breakVoiceConnection(bool wait);
- void OnVoiceDisconnectionRequestSuccess(const LLSD &body);
- void OnVoiceDisconnectionRequestFailure(std::string url, int retries, LLSD body, const LLSD &result);
+ void breakVoiceConnection();
LLUUID mRegionID;
LLUUID mViewerSession;
@@ -725,7 +720,7 @@ class LLVoiceWebRTCSpatialConnection :
protected:
- bool requestVoiceConnection() override;
+ void requestVoiceConnection() override;
S32 mParcelLocalID;
};
@@ -740,7 +735,7 @@ class LLVoiceWebRTCAdHocConnection : public LLVoiceWebRTCConnection
bool isSpatial() override { return false; }
protected:
- bool requestVoiceConnection() override;
+ void requestVoiceConnection() override;
std::string mCredentials;
};