Skip to content

Commit 22c9e3d

Browse files
jdelapladisa6302niyatim23ela34northteam
authored
Release 1 7 0 (#1354)
* Log ice candidate protocol appropriately (#1230) * Log ice candidate protocol appropriately * Add develop to travis CI * Address comments * Realign branches during transition (#1257) * create data channel sample (#1203) * create data channel sample * moved variables to Samples.h, encapsulated with ENABLE_DATA_CHANNEL directive * removed unused variables, moved variable declarations to the top of a block * create data channel sample * moved variables to Samples.h, encapsulated with ENABLE_DATA_CHANNEL directive * Cancel the thread once mediaThreadStarted flag is set to false (#1227) * Initial stale PR template (#1226) * Update stale issue template * Testing every minute * Fix stale issue PR template (#1234) No code changed. Just a template change. So merging * Add bug and question label * Switch stale PR action to daily cadence * [FIX] When protocol in DCEP header of data channel open command is not empty, there is a check preventing the data channel to be opened. Now protocol length is correctly handled to avoid check failing. (#1228) Co-authored-by: Niyati Maheshwari <niyatim23@gmail.com> Co-authored-by: Divya Sampath Kumar <disa6302@colorado.edu> Co-authored-by: ela34 <8700736+ela34@users.noreply.github.com> * set protocol value following the spec (#1259) Co-authored-by: liyufang <liyufang@xiaomi.com> * filter out invalid candidate in sdp (#1260) Co-authored-by: liyufang <liyufang@xiaomi.com> * Added targets for cmake clean (#1253) * added targets for cmake clean * added new line, updated readme * added missing new line * updated readme to include folder details * updated readme to include folder details * viewer sample: wrap datachannel callback with `ENABLE_DATA_CHANNEL` (#1261) * create data channel sample (#1203) * create data channel sample * moved variables to Samples.h, encapsulated with ENABLE_DATA_CHANNEL directive * removed unused variables, moved variable declarations to the top of a block * create data channel sample * moved variables to Samples.h, encapsulated with ENABLE_DATA_CHANNEL directive * Cancel the thread once mediaThreadStarted flag is set to false (#1227) * Initial stale PR template (#1226) * Update stale issue template * Testing every minute * Fix stale issue PR template (#1234) No code changed. Just a template change. So merging * Add bug and question label * Switch stale PR action to daily cadence * [FIX] When protocol in DCEP header of data channel open command is not empty, there is a check preventing the data channel to be opened. Now protocol length is correctly handled to avoid check failing. (#1228) * viewer sample: wrap datachannel callback with `ENABLE_DATA_CHANNEL` Signed-off-by: zhiqinli@amazon.com <zhiqinli@amazon.com> Co-authored-by: Niyati Maheshwari <niyatim23@gmail.com> Co-authored-by: Divya Sampath Kumar <disa6302@colorado.edu> Co-authored-by: ela34 <8700736+ela34@users.noreply.github.com> * libwebsockets: add patch to fix pipe fd leak issue (#1264) Signed-off-by: Alex.Li <zhiqinli@amazon.com> * Fix scripts/pare_status.py for non-status #defines (#1268) (#1274) Co-authored-by: Kevin Allen <kallen@aurora.tech> * fix a few bugs * Revert "fix a few bugs" This reverts commit 0939024. * fix some bugs (#1277) * Fix bugs (#1279) * fix edge case try to unlock a mutex which is not locked in teh acse the sample config was NULL (#1286) * cmake: allow user to specify OPEN_SRC_INSTALL_PREFIX (#1293) Signed-off-by: Alex.Li <zhiqinli@amazon.com> * Fix inconsistent log priority (#1309) Patch reduces priority of a few info level log messages to verbose level to be consistent with other functions in file and rest of code base. * Modify protocol loggin design in develop (#1311) * typo: typo fix (#1317) Signed-off-by: Alex.Li <zhiqinli@amazon.com> * Signaling state machine rework (#1323) * replaced recursive calls to stepSignalingStateMachine with loops * removed recursive calls to stepSignalingStateMachine * replaced stepSignalingstatemachine with signalingStateMachineIterator * removed stepUntil, continueOnReady; removed status from iterator signature; set signalingclient version; added a lock in refreshIceConfiguration * changed the declaration for i from int to UINT32 * added signaling version; removed unnecessary comment * removed redeclaration; changed value in an existing macro * Fix issue with API call failures being treated as success (#1328) * return proper error, do not reset call result value * for non retriable failures, set the terminal exit status for state in… (#1320) * for non retriable failures, set the terminal exit status for state in state machine * address comments * adjust tests set retry max to 1 * Update LwsApiCalls.c trigger travis ci * Incorporating PIC state machine level retry changes into webrtc signaling state machine (#1326) * Incorporating PIC state machine level retry changes into webrtc signaling state machine * Signaling state machine rework (#1323) * replaced recursive calls to stepSignalingStateMachine with loops * removed recursive calls to stepSignalingStateMachine * replaced stepSignalingstatemachine with signalingStateMachineIterator * removed stepUntil, continueOnReady; removed status from iterator signature; set signalingclient version; added a lock in refreshIceConfiguration * changed the declaration for i from int to UINT32 * added signaling version; removed unnecessary comment * removed redeclaration; changed value in an existing macro * Fix issue with API call failures being treated as success (#1328) * return proper error, do not reset call result value * for non retriable failures, set the terminal exit status for state in… (#1320) * for non retriable failures, set the terminal exit status for state in state machine * address comments * adjust tests set retry max to 1 * Update LwsApiCalls.c trigger travis ci * Add retry strategy to client info to avoiud changing create signaling channel API signature * Incorporating PIC state machine level retry changes into webrtc signaling state machine * Add retry strategy to client info to avoiud changing create signaling channel API signature * Adding more debug logs in the code * fix merge conflicts * PR feedback Co-authored-by: Niyati Maheshwari <niyatim23@gmail.com> Co-authored-by: Hassan Sahibzada <hsahibza@amazon.com> * Revert " Incorporating PIC state machine level retry changes into webrtc signaling state machine (#1326)" (#1339) This reverts commit 06bffce. * Incorporating PIC state machine level retry changes into webrtc signaling state machine (#1341) * Incorporating PIC state machine level retry changes into webrtc signaling state machine * Add a n optional check for free retry strategy * Remove unused goto label * add missing sleep in get token state machine execute API * update log line * Update Producer hash * Adding a high level retry strategy while creating signaling client * Add Retry count retrieval in hook (#1335) * Add Retry count retrieval in hook * Fix compile issue on travis * Pull in latest changes in retry structures * Rebasing off develop with successful travis run for retry * Log git hash (#1345) * Log git hash * Update CMakeLists.txt white space change to trigger travis Co-authored-by: Hassan Sahibzada <hsahibza@amazon.com> * Fix retry count to indicate count only after a retry has occured (#1348) Fix retry count to indicate count only after a retry has occurred * add support for automatic clock skew detection and correction (#1344) * add support for automatic clock skew detection and correction * auto fix clock skew and add tests * enable test to check clock recovery * remove stuff left over from debugging, reset logging default to WARN * remove unused variable * get rid of verbose logging in unit tests causes static build to fail due to excessive log output * simplify code get rid of extra call to length because the lws_hdr_copy returns the same value * handle null stream track in case of recvonly (#1346) * handle null stream track in case of recvonly * a test with null stream track for revconly * Fix a comment * whitespace change * State machine preparation is decoupled from the constructor (#1343) * Merge master into develop (#1352) * Missing the public API switch in the other samples (#1356) * Fix Fetch error retry cases (#1359) * Fix Fetch error retry cases * update comment Co-authored-by: Divya Sampath Kumar <disa6302@colorado.edu> Co-authored-by: Niyati Maheshwari <niyatim23@gmail.com> Co-authored-by: ela34 <8700736+ela34@users.noreply.github.com> Co-authored-by: northteam <northteam@users.noreply.github.com> Co-authored-by: liyufang <liyufang@xiaomi.com> Co-authored-by: Alex.D.Scofield <zhiqinli@amazon.com> Co-authored-by: Kevin Allen <kallen@aurora.tech> Co-authored-by: Hassan Sahibzada <hsahibza@amazon.com> Co-authored-by: Chris Hiszpanski <chris@hiszpanski.name> Co-authored-by: Anurag Katey <kateyanurag@users.noreply.github.com>
1 parent 4127014 commit 22c9e3d

32 files changed

+1807
-388
lines changed

.travis.yml

+1
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,7 @@ sudo: true
44
branches:
55
only:
66
- master
7+
- develop
78

89
cache:
910
- directories:

CMake/Dependencies/libkvsCommonLws-CMakeLists.txt

+1-1
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@ include(ExternalProject)
66

77
ExternalProject_Add(libkvsCommonLws-download
88
GIT_REPOSITORY https://github.com/awslabs/amazon-kinesis-video-streams-producer-c.git
9-
GIT_TAG 99c1a8cd8cec88f99c9c4ce3944b53ae341d1491
9+
GIT_TAG c7fce9e06021452ff3c42dc70c8360606b22ad53
1010
PREFIX ${CMAKE_CURRENT_BINARY_DIR}/build
1111
CMAKE_ARGS
1212
-DCMAKE_INSTALL_PREFIX=${OPEN_SRC_INSTALL_PREFIX}

CMake/Dependencies/libwebsockets-CMakeLists.txt

+2-2
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@ cmake_minimum_required(VERSION 2.8)
22

33
project(libwebsocket-download NONE)
44

5-
SET(PATCH_COMMAND git apply --ignore-whitespace ${CMAKE_CURRENT_LIST_DIR}/libwebsockets-old-gcc-fix-cast-cmakelists.patch)
5+
SET(PATCH_COMMAND git apply --ignore-whitespace ${CMAKE_CURRENT_LIST_DIR}/libwebsockets-old-gcc-fix-cast-cmakelists.patch ${CMAKE_CURRENT_LIST_DIR}/libwebsockets-leak-pipe-fix.patch)
66

77
include(ExternalProject)
88

@@ -25,7 +25,7 @@ endif()
2525

2626
ExternalProject_Add(project_libwebsockets
2727
GIT_REPOSITORY https://github.com/warmcat/libwebsockets.git
28-
GIT_TAG v4.2.1
28+
GIT_TAG v4.2.2
2929
PATCH_COMMAND ${PATCH_COMMAND}
3030
PREFIX ${CMAKE_CURRENT_BINARY_DIR}/build
3131
CMAKE_ARGS
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,36 @@
1+
Author: Andy Green <andy@warmcat.com>
2+
Date: Wed Sep 08 12:25:47 2021 +0200
3+
4+
cancel pipe: make sure we closed it on destroy with no EVENTFD case
5+
6+
7+
diff --git a/lib/core/context.c b/lib/core/context.c
8+
index 6194801..4f3bb45 100644
9+
--- a/lib/core/context.c
10+
+++ b/lib/core/context.c
11+
@@ -1625,11 +1625,25 @@ lws_pt_destroy(struct lws_context_per_thread *pt)
12+
vpt->foreign_pfd_list = NULL;
13+
14+
lws_pt_lock(pt, __func__);
15+
+
16+
if (pt->pipe_wsi) {
17+
lws_destroy_event_pipe(pt->pipe_wsi);
18+
pt->pipe_wsi = NULL;
19+
}
20+
21+
+ if (pt->dummy_pipe_fds[0]
22+
+#if !defined(WIN32)
23+
+ && (int)pt->dummy_pipe_fds[0] != -1
24+
+#endif
25+
+ ) {
26+
+ struct lws wsi;
27+
+
28+
+ memset(&wsi, 0, sizeof(wsi));
29+
+ wsi.a.context = pt->context;
30+
+ wsi.tsi = (char)pt->tid;
31+
+ lws_plat_pipe_close(&wsi);
32+
+ }
33+
+
34+
#if defined(LWS_WITH_SECURE_STREAMS)
35+
lws_dll2_foreach_safe(&pt->ss_owner, NULL, lws_ss_destroy_dll);
36+

CMake/Dependencies/libwebsockets-old-gcc-fix-cast-cmakelists.patch

-16
Original file line numberDiff line numberDiff line change
@@ -1,19 +1,3 @@
1-
diff --git a/lib/misc/base64-decode.c b/lib/misc/base64-decode.c
2-
index f8e8e49a..9d18b33f 100644
3-
--- a/lib/misc/base64-decode.c
4-
+++ b/lib/misc/base64-decode.c
5-
@@ -72,9 +72,9 @@ _lws_b64_encode_string(const char *encode, const char *in, int in_len,
6-
*out++ = encode[triple[0] >> 2];
7-
*out++ = encode[(((triple[0] & 0x03) << 4) & 0x30) |
8-
(((triple[1] & 0xf0) >> 4) & 0x0f)];
9-
- *out++ = (len > 1 ? encode[(((triple[1] & 0x0f) << 2) & 0x3c) |
10-
+ *out++ = (char)(len > 1 ? encode[(((triple[1] & 0x0f) << 2) & 0x3c) |
11-
(((triple[2] & 0xc0) >> 6) & 3)] : '=');
12-
- *out++ = (len > 2 ? encode[triple[2] & 0x3f] : '=');
13-
+ *out++ = (char)(len > 2 ? encode[triple[2] & 0x3f] : '=');
14-
15-
done += 4;
16-
}
171
diff --git a/lib/roles/h2/hpack.c b/lib/roles/h2/hpack.c
182
index 68629e6f..6ef628b8 100644
193
--- a/lib/roles/h2/hpack.c

CMakeLists.txt

+20-1
Original file line numberDiff line numberDiff line change
@@ -30,7 +30,20 @@ option(THREAD_SANITIZER "Build with ThreadSanitizer." OFF)
3030
option(UNDEFINED_BEHAVIOR_SANITIZER "Build with UndefinedBehaviorSanitizer." OFF)
3131
option(LINK_PROFILER "Link gperftools profiler" OFF)
3232

33-
set(OPEN_SRC_INSTALL_PREFIX "${CMAKE_CURRENT_SOURCE_DIR}/open-source" CACHE PATH "Libraries will be downloaded and built in this directory.")
33+
execute_process(
34+
COMMAND git rev-parse HEAD
35+
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
36+
OUTPUT_VARIABLE GIT_COMMIT_HASH
37+
OUTPUT_STRIP_TRAILING_WHITESPACE)
38+
39+
add_definitions(-DSDK_VERSION=\"${GIT_COMMIT_HASH}\")
40+
add_definitions(-DDETECTED_GIT_HASH)
41+
42+
if(NOT OPEN_SRC_INSTALL_PREFIX OR OPEN_SRC_INSTALL_PREFIX STREQUAL "")
43+
set(OPEN_SRC_INSTALL_PREFIX "${CMAKE_CURRENT_SOURCE_DIR}/open-source" CACHE PATH "Libraries will be downloaded and built in this directory.")
44+
else()
45+
set(OPEN_SRC_INSTALL_PREFIX ${OPEN_SRC_INSTALL_PREFIX} CACHE PATH "Libraries will be downloaded and built in this directory.")
46+
endif()
3447

3548
if(NOT WIN32)
3649
CHECK_INCLUDE_FILES(ifaddrs.h KVSWEBRTC_HAVE_IFADDRS_H)
@@ -342,3 +355,9 @@ endif()
342355
if(BUILD_BENCHMARK)
343356
add_subdirectory(bench)
344357
endif()
358+
359+
get_directory_property(clean_files ADDITIONAL_CLEAN_FILES)
360+
list(APPEND clean_files "${OPEN_SRC_INSTALL_PREFIX}")
361+
list(APPEND clean_files "${CMAKE_CURRENT_SOURCE_DIR}/build")
362+
set_directory_properties(PROPERTIES ADDITIONAL_CLEAN_FILES "${clean_files}")
363+

README.md

+2
Original file line numberDiff line numberDiff line change
@@ -97,6 +97,8 @@ You can pass the following options to `cmake ..`.
9797
* `-DUNDEFINED_BEHAVIOR_SANITIZER` -- Build with UndefinedBehaviorSanitizer
9898
* `-DLINK_PROFILER` -- Link with gperftools (available profiler options are listed [here](https://github.com/gperftools/gperftools))
9999

100+
To clean up the `open-source` and `build` folders from previous build, use `cmake --build . --target clean` from the `build` folder
101+
100102
For windows builds, you will have to include additional flags for libwebsockets CMake. Add the following flags to your cmake command, or edit the CMake file in ./CMake/Dependencies/libwebsockets-CMakeLists.txt with the following:
101103

102104
```

samples/Common.c

+33-40
Original file line numberDiff line numberDiff line change
@@ -24,7 +24,7 @@ VOID onDataChannelMessage(UINT64 customData, PRtcDataChannel pDataChannel, BOOL
2424
// Send a response to the message sent by the viewer
2525
STATUS retStatus = STATUS_SUCCESS;
2626
retStatus = dataChannelSend(pDataChannel, FALSE, (PBYTE) MASTER_DATA_CHANNEL_MESSAGE, STRLEN(MASTER_DATA_CHANNEL_MESSAGE));
27-
if(retStatus != STATUS_SUCCESS) {
27+
if (retStatus != STATUS_SUCCESS) {
2828
DLOGI("[KVS Master] dataChannelSend(): operation returned status code: 0x%08x \n", retStatus);
2929
}
3030
}
@@ -493,7 +493,7 @@ STATUS createSampleStreamingSession(PSampleConfiguration pSampleConfiguration, P
493493
CHK_STATUS(transceiverOnBandwidthEstimation(pSampleStreamingSession->pVideoRtcRtpTransceiver, (UINT64) pSampleStreamingSession,
494494
sampleBandwidthEstimationHandler));
495495

496-
// Add a SendRecv Transceiver of type video
496+
// Add a SendRecv Transceiver of type audio
497497
audioTrack.kind = MEDIA_STREAM_TRACK_KIND_AUDIO;
498498
audioTrack.codec = RTC_CODEC_OPUS;
499499
audioRtpTransceiverInit.direction = RTC_RTP_TRANSCEIVER_DIRECTION_SENDRECV;
@@ -551,7 +551,7 @@ STATUS freeSampleStreamingSession(PSampleStreamingSession* ppSampleStreamingSess
551551
// the running thread but it's OK as it's re-entrant
552552
MUTEX_LOCK(pSampleConfiguration->sampleConfigurationObjLock);
553553
if (pSampleConfiguration->iceCandidatePairStatsTimerId != MAX_UINT32 && pSampleConfiguration->streamingSessionCount == 0 &&
554-
pSampleConfiguration->iceCandidatePairStatsTimerId != MAX_UINT32) {
554+
pSampleConfiguration->iceCandidatePairStatsTimerId != MAX_UINT32 && IS_VALID_TIMER_QUEUE_HANDLE(pSampleConfiguration->timerQueueHandle)) {
555555
CHK_LOG_ERR(timerQueueCancelTimer(pSampleConfiguration->timerQueueHandle, pSampleConfiguration->iceCandidatePairStatsTimerId,
556556
(UINT64) pSampleConfiguration));
557557
pSampleConfiguration->iceCandidatePairStatsTimerId = MAX_UINT32;
@@ -596,10 +596,10 @@ VOID sampleFrameHandler(UINT64 customData, PFrame pFrame)
596596
}
597597
}
598598

599-
VOID sampleBandwidthEstimationHandler(UINT64 customData, DOUBLE maxiumBitrate)
599+
VOID sampleBandwidthEstimationHandler(UINT64 customData, DOUBLE maximumBitrate)
600600
{
601601
UNUSED_PARAM(customData);
602-
DLOGV("received bitrate suggestion: %f", maxiumBitrate);
602+
DLOGV("received bitrate suggestion: %f", maximumBitrate);
603603
}
604604

605605
VOID sampleSenderBandwidthEstimationHandler(UINT64 customData, UINT32 txBytes, UINT32 rxBytes, UINT32 txPacketsCnt, UINT32 rxPacketsCnt,
@@ -782,6 +782,7 @@ STATUS createSampleConfiguration(PCHAR channelName, SIGNALING_CHANNEL_ROLE_TYPE
782782
pSampleConfiguration->clientInfo.version = SIGNALING_CLIENT_INFO_CURRENT_VERSION;
783783
pSampleConfiguration->clientInfo.loggingLevel = logLevel;
784784
pSampleConfiguration->clientInfo.cacheFilePath = NULL; // Use the default path
785+
pSampleConfiguration->clientInfo.signalingClientCreationMaxRetryAttempts = CREATE_SIGNALING_CLIENT_RETRY_ATTEMPTS_SENTINEL_VALUE;
785786
pSampleConfiguration->iceCandidatePairStatsTimerId = MAX_UINT32;
786787
pSampleConfiguration->pregenerateCertTimerId = MAX_UINT32;
787788

@@ -838,6 +839,7 @@ STATUS logSignalingClientStats(PSignalingClientMetrics pSignalingClientMetrics)
838839
// This gives the EMA of the getIceConfig() call.
839840
DLOGD("Data Plane API call latency: %" PRIu64 " ms",
840841
(pSignalingClientMetrics->signalingClientStats.dpApiCallLatency / HUNDREDS_OF_NANOS_IN_A_MILLISECOND));
842+
DLOGD("API call retry count: %d", pSignalingClientMetrics->signalingClientStats.apiCallRetryCount);
841843
CleanUp:
842844
LEAVES();
843845
return retStatus;
@@ -1004,6 +1006,28 @@ STATUS freeSampleConfiguration(PSampleConfiguration* ppSampleConfiguration)
10041006

10051007
CHK(pSampleConfiguration != NULL, retStatus);
10061008

1009+
if (IS_VALID_TIMER_QUEUE_HANDLE(pSampleConfiguration->timerQueueHandle)) {
1010+
if (pSampleConfiguration->iceCandidatePairStatsTimerId != MAX_UINT32) {
1011+
retStatus = timerQueueCancelTimer(pSampleConfiguration->timerQueueHandle, pSampleConfiguration->iceCandidatePairStatsTimerId,
1012+
(UINT64) pSampleConfiguration);
1013+
if (STATUS_FAILED(retStatus)) {
1014+
DLOGE("Failed to cancel stats timer with: 0x%08x", retStatus);
1015+
}
1016+
pSampleConfiguration->iceCandidatePairStatsTimerId = MAX_UINT32;
1017+
}
1018+
1019+
if (pSampleConfiguration->pregenerateCertTimerId != MAX_UINT32) {
1020+
retStatus = timerQueueCancelTimer(pSampleConfiguration->timerQueueHandle, pSampleConfiguration->pregenerateCertTimerId,
1021+
(UINT64) pSampleConfiguration);
1022+
if (STATUS_FAILED(retStatus)) {
1023+
DLOGE("Failed to cancel certificate pre-generation timer with: 0x%08x", retStatus);
1024+
}
1025+
pSampleConfiguration->pregenerateCertTimerId = MAX_UINT32;
1026+
}
1027+
1028+
timerQueueFree(&pSampleConfiguration->timerQueueHandle);
1029+
}
1030+
10071031
if (pSampleConfiguration->pPendingSignalingMessageForRemoteClient != NULL) {
10081032
// Iterate and free all the pending queues
10091033
stackQueueGetIterator(pSampleConfiguration->pPendingSignalingMessageForRemoteClient, &iterator);
@@ -1025,12 +1049,7 @@ STATUS freeSampleConfiguration(PSampleConfiguration* ppSampleConfiguration)
10251049
MUTEX_LOCK(pSampleConfiguration->sampleConfigurationObjLock);
10261050
locked = TRUE;
10271051
}
1028-
// Cancel the media thread
1029-
if(!(pSampleConfiguration->mediaThreadStarted)) {
1030-
DLOGD("Canceling media thread");
1031-
THREAD_CANCEL(pSampleConfiguration->mediaSenderTid);
1032-
}
1033-
1052+
10341053
for (i = 0; i < pSampleConfiguration->streamingSessionCount; ++i) {
10351054
retStatus = gatherIceServerStats(pSampleConfiguration->sampleStreamingSessionList[i]);
10361055
if (STATUS_FAILED(retStatus)) {
@@ -1074,28 +1093,6 @@ STATUS freeSampleConfiguration(PSampleConfiguration* ppSampleConfiguration)
10741093
freeStaticCredentialProvider(&pSampleConfiguration->pCredentialProvider);
10751094
#endif
10761095

1077-
if (IS_VALID_TIMER_QUEUE_HANDLE(pSampleConfiguration->timerQueueHandle)) {
1078-
if (pSampleConfiguration->iceCandidatePairStatsTimerId != MAX_UINT32) {
1079-
retStatus = timerQueueCancelTimer(pSampleConfiguration->timerQueueHandle, pSampleConfiguration->iceCandidatePairStatsTimerId,
1080-
(UINT64) pSampleConfiguration);
1081-
if (STATUS_FAILED(retStatus)) {
1082-
DLOGE("Failed to cancel stats timer with: 0x%08x", retStatus);
1083-
}
1084-
pSampleConfiguration->iceCandidatePairStatsTimerId = MAX_UINT32;
1085-
}
1086-
1087-
if (pSampleConfiguration->pregenerateCertTimerId != MAX_UINT32) {
1088-
retStatus = timerQueueCancelTimer(pSampleConfiguration->timerQueueHandle, pSampleConfiguration->pregenerateCertTimerId,
1089-
(UINT64) pSampleConfiguration);
1090-
if (STATUS_FAILED(retStatus)) {
1091-
DLOGE("Failed to cancel certificate pre-generation timer with: 0x%08x", retStatus);
1092-
}
1093-
pSampleConfiguration->pregenerateCertTimerId = MAX_UINT32;
1094-
}
1095-
1096-
timerQueueFree(&pSampleConfiguration->timerQueueHandle);
1097-
}
1098-
10991096
if (pSampleConfiguration->pregeneratedCertificates != NULL) {
11001097
stackQueueGetIterator(pSampleConfiguration->pregeneratedCertificates, &iterator);
11011098
while (IS_VALID_ITERATOR(iterator)) {
@@ -1109,8 +1106,7 @@ STATUS freeSampleConfiguration(PSampleConfiguration* ppSampleConfiguration)
11091106
pSampleConfiguration->pregeneratedCertificates = NULL;
11101107
}
11111108

1112-
MEMFREE(*ppSampleConfiguration);
1113-
*ppSampleConfiguration = NULL;
1109+
SAFE_MEMFREE(*ppSampleConfiguration);
11141110

11151111
CleanUp:
11161112

@@ -1161,10 +1157,7 @@ STATUS sessionCleanupWait(PSampleConfiguration pSampleConfiguration)
11611157

11621158
// Check if we need to re-create the signaling client on-the-fly
11631159
if (ATOMIC_LOAD_BOOL(&pSampleConfiguration->recreateSignalingClient) &&
1164-
STATUS_SUCCEEDED(freeSignalingClient(&pSampleConfiguration->signalingClientHandle)) &&
1165-
STATUS_SUCCEEDED(createSignalingClientSync(&pSampleConfiguration->clientInfo, &pSampleConfiguration->channelInfo,
1166-
&pSampleConfiguration->signalingClientCallbacks, pSampleConfiguration->pCredentialProvider,
1167-
&pSampleConfiguration->signalingClientHandle))) {
1160+
STATUS_SUCCEEDED(signalingClientFetchSync(pSampleConfiguration->signalingClientHandle))) {
11681161
// Re-set the variable again
11691162
ATOMIC_STORE_BOOL(&pSampleConfiguration->recreateSignalingClient, FALSE);
11701163
}
@@ -1234,7 +1227,7 @@ STATUS signalingMessageReceived(UINT64 customData, PReceivedSignalingMessage pRe
12341227
{
12351228
STATUS retStatus = STATUS_SUCCESS;
12361229
PSampleConfiguration pSampleConfiguration = (PSampleConfiguration) customData;
1237-
BOOL peerConnectionFound = FALSE, locked = TRUE, startStats = FALSE;
1230+
BOOL peerConnectionFound = FALSE, locked = FALSE, startStats = FALSE;
12381231
UINT32 clientIdHash;
12391232
UINT64 hashValue = 0;
12401233
PPendingMessageQueue pPendingMessageQueue = NULL;

samples/kvsWebRTCClientMaster.c

+26-6
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,7 @@ INT32 main(INT32 argc, CHAR* argv[])
1111
PSampleConfiguration pSampleConfiguration = NULL;
1212
SignalingClientMetrics signalingClientMetrics;
1313
PCHAR pChannelName;
14-
signalingClientMetrics.version = 0;
14+
signalingClientMetrics.version = SIGNALING_CLIENT_METRICS_CURRENT_VERSION;
1515

1616
SET_INSTRUMENTED_ALLOCATORS();
1717

@@ -91,6 +91,12 @@ INT32 main(INT32 argc, CHAR* argv[])
9191
printf("[KVS Master] Signaling client created successfully\n");
9292

9393
// Enable the processing of the messages
94+
retStatus = signalingClientFetchSync(pSampleConfiguration->signalingClientHandle);
95+
if (retStatus != STATUS_SUCCESS) {
96+
printf("[KVS Master] signalingClientFetchSync(): operation returned status code: 0x%08x \n", retStatus);
97+
goto CleanUp;
98+
}
99+
94100
retStatus = signalingClientConnectSync(pSampleConfiguration->signalingClientHandle);
95101
if (retStatus != STATUS_SUCCESS) {
96102
printf("[KVS Master] signalingClientConnectSync(): operation returned status code: 0x%08x \n", retStatus);
@@ -114,14 +120,28 @@ INT32 main(INT32 argc, CHAR* argv[])
114120
CleanUp:
115121

116122
if (retStatus != STATUS_SUCCESS) {
117-
printf("[KVS Master] Terminated with status code 0x%08x", retStatus);
123+
printf("[KVS Master] Terminated with status code 0x%08x\n", retStatus);
118124
}
119125

120126
printf("[KVS Master] Cleaning up....\n");
121127
if (pSampleConfiguration != NULL) {
122128
// Kick of the termination sequence
123129
ATOMIC_STORE_BOOL(&pSampleConfiguration->appTerminateFlag, TRUE);
124130

131+
if (IS_VALID_MUTEX_VALUE(pSampleConfiguration->sampleConfigurationObjLock)) {
132+
MUTEX_LOCK(pSampleConfiguration->sampleConfigurationObjLock);
133+
}
134+
135+
// Cancel the media thread
136+
if (pSampleConfiguration->mediaThreadStarted) {
137+
DLOGD("Canceling media thread");
138+
THREAD_CANCEL(pSampleConfiguration->mediaSenderTid);
139+
}
140+
141+
if (IS_VALID_MUTEX_VALUE(pSampleConfiguration->sampleConfigurationObjLock)) {
142+
MUTEX_UNLOCK(pSampleConfiguration->sampleConfigurationObjLock);
143+
}
144+
125145
if (pSampleConfiguration->mediaSenderTid != INVALID_TID_VALUE) {
126146
THREAD_JOIN(pSampleConfiguration->mediaSenderTid, NULL);
127147
}
@@ -133,7 +153,7 @@ INT32 main(INT32 argc, CHAR* argv[])
133153
if (retStatus == STATUS_SUCCESS) {
134154
logSignalingClientStats(&signalingClientMetrics);
135155
} else {
136-
printf("[KVS Master] signalingClientGetMetrics() operation returned status code: 0x%08x", retStatus);
156+
printf("[KVS Master] signalingClientGetMetrics() operation returned status code: 0x%08x\n", retStatus);
137157
}
138158
retStatus = freeSignalingClient(&pSampleConfiguration->signalingClientHandle);
139159
if (retStatus != STATUS_SUCCESS) {
@@ -272,7 +292,7 @@ PVOID sendVideoPackets(PVOID args)
272292

273293
CHK_LOG_ERR(retStatus);
274294

275-
return (PVOID) (ULONG_PTR) retStatus;
295+
return (PVOID)(ULONG_PTR) retStatus;
276296
}
277297

278298
PVOID sendAudioPackets(PVOID args)
@@ -340,7 +360,7 @@ PVOID sendAudioPackets(PVOID args)
340360

341361
CleanUp:
342362

343-
return (PVOID) (ULONG_PTR) retStatus;
363+
return (PVOID)(ULONG_PTR) retStatus;
344364
}
345365

346366
PVOID sampleReceiveVideoFrame(PVOID args)
@@ -360,5 +380,5 @@ PVOID sampleReceiveVideoFrame(PVOID args)
360380

361381
CleanUp:
362382

363-
return (PVOID) (ULONG_PTR) retStatus;
383+
return (PVOID)(ULONG_PTR) retStatus;
364384
}

samples/kvsWebRTCClientMasterGstreamerSample.c

+6
Original file line numberDiff line numberDiff line change
@@ -430,6 +430,12 @@ INT32 main(INT32 argc, CHAR* argv[])
430430
printf("[KVS GStreamer Master] Signaling client created successfully\n");
431431

432432
// Enable the processing of the messages
433+
retStatus = signalingClientFetchSync(pSampleConfiguration->signalingClientHandle);
434+
if (retStatus != STATUS_SUCCESS) {
435+
printf("[KVS Master] signalingClientFetchSync(): operation returned status code: 0x%08x \n", retStatus);
436+
goto CleanUp;
437+
}
438+
433439
retStatus = signalingClientConnectSync(pSampleConfiguration->signalingClientHandle);
434440
if (retStatus != STATUS_SUCCESS) {
435441
printf("[KVS GStreamer Master] signalingClientConnectSync(): operation returned status code: 0x%08x \n", retStatus);

0 commit comments

Comments
 (0)