Skip to content

Commit

Permalink
Add important logs related to freezing
Browse files Browse the repository at this point in the history
  • Loading branch information
peaBerberian committed Nov 6, 2024
1 parent 88f1581 commit b81dfd5
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 0 deletions.
9 changes: 9 additions & 0 deletions src/core/main/common/FreezeResolver.ts
Original file line number Diff line number Diff line change
Expand Up @@ -306,11 +306,15 @@ export default class FreezeResolver {
} else if (rebuffering !== null) {
freezingTs = rebuffering.timestamp;
}

log.info("FR: Freeze detected", freezingTs, now - (freezingTs ?? now));

if (freezingTs !== null && now - freezingTs > UNFREEZING_SEEK_DELAY) {
this._lastFlushAttempt = {
timestamp: now,
position: freezingPosition + UNFREEZING_DELTA_POSITION,
};
log.debug("FR: trying to flush to un-freeze");

this._decipherabilityFreezeStartingTimestamp = null;
this._ignoreFreezeUntil = now + 6000;
Expand All @@ -326,6 +330,7 @@ export default class FreezeResolver {
}

if (this._decipherabilityFreezeStartingTimestamp === null) {
log.debug("FR: Start of a potential decipherability freeze detected");
this._decipherabilityFreezeStartingTimestamp = now;
}
const rebufferingForTooLong =
Expand All @@ -336,6 +341,10 @@ export default class FreezeResolver {
(rebufferingForTooLong || frozenForTooLong) &&
getMonotonicTimeStamp() - this._decipherabilityFreezeStartingTimestamp > 4000
) {
log.debug(
"FR: Investigating long potential decipherability freeze",
this._decipherabilityFreezeStartingTimestamp,
);
let hasOnlyDecipherableSegments = true;
let isClear = true;
for (const ttype of ["audio", "video"] as const) {
Expand Down
9 changes: 9 additions & 0 deletions src/core/main/worker/worker_main.ts
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,7 @@ export default function initializeWorkerMain() {
currentLoadedContentTaskCanceller.signal.register(() => {
currentContentObservationRef.finish();
});
log.debug("WP: Loading new pepared content.");
loadOrReloadPreparedContent(
msg.value,
contentPreparer,
Expand Down Expand Up @@ -487,6 +488,7 @@ function loadOrReloadPreparedContent(
playbackObservationRef: IReadOnlySharedReference<IWorkerPlaybackObservation>,
parentCancelSignal: CancellationSignal,
) {
log.debug("WP: Loading prepared content");
const currentLoadCanceller = new TaskCanceller();
currentLoadCanceller.linkToSignal(parentCancelSignal);

Expand Down Expand Up @@ -917,8 +919,15 @@ function loadOrReloadPreparedContent(
if (currentLoadCanceller !== null) {
currentLoadCanceller.cancel();
}
log.debug(
"WP: Reloading MediaSource",
payload.timeOffset,
payload.minimumPosition,
payload.maximumPosition,
);
contentPreparer.reloadMediaSource(payload).then(
() => {
log.info("WP: MediaSource Reloaded, loading...");
loadOrReloadPreparedContent(
{
initialTime: newInitialTime,
Expand Down

0 comments on commit b81dfd5

Please sign in to comment.