Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

RDKEMW-2731 : Bring Aamp changes for March sprint #15

Merged
merged 52 commits into from
Mar 26, 2025

Conversation

shripadbpersonal
Copy link
Contributor

No description provided.

asasik397 and others added 30 commits March 6, 2025 06:53
Reason for change: TO display aamp branch in devices
Test Procedure: Updated in ticket
Risks: Medium
Priority: P1

Signed-off-by: Abhijith_Sasikumar <[email protected]>
Reason for change: remove temp code associated with lldash behaviors
Test Procedure:
Risks: medium

Change-Id: I4903dda3bea606f70da6958b7a2c8aa161fe9d1b
Reason for change: Having AAMP TSB enabled breaks VOD.

Changes: Restrict the enabling of AAMP TSB to live (ContentType_LINEAR) content only.

Test Procedure: Confirm VOD behaves the same on FS regardless of if AAMP
TSB is enabled in aamp.cfg

Risks: Low

Change-Id: I6f5911b61cd509132ca35a905669d20241d8b4ad
Signed-off-by: Dominic Holden<[email protected]>
Reason for change: fix regression where install-aamp.sh (on osx) ends up trying to play bogus url
Test Procedure: run install-aamp.sh; now just launches xcode without attempting to play an example.com locator
Risks: Low

Change-Id: I1f5717b5e8a9470064f8f7e74e9468122bf748f4
…n VOD DAI test stream

Reason for change:

Period end time also needs to be updated according to the PTO if PTO is greater than the start time.

Test Procedure: Test case updated in the ticket
Risks: low
Change-Id: I0a551909d9984348cdb54d7935f7f9922b5bb4b4
Signed-off-by: [email protected]
Reason for change: No subtitles when playing SLD content from AAMP TSB
Changes:
* When reading from TSB, set the position to the PTS restamped value
* Recalculate PTS for subtitle segments when writing to TSB
* Add INFO to CacheFragment() with the position after restamp
* Remove setting the position to absolute value when writing to TSB
  since AddFragment() is already setting it to absPosition.
* Modify L1 AampTsbSessionManager tests to use AampUtils mocks.
* Verify in L1 tests that the position read from TSB is restamped.

Test Procedure: Verify subtitles for SLD linear content from TSB

Risks: Low

Change-Id: Id18b32c7e537a6c2a40dd6b14a80f8c82556d17e
Signed-off-by: Jose Fagundez <[email protected]>
Reason for change: more predicable cdai sim in aampcli
Test Procedure: refer ticket
Risks: Low

Change-Id: Ib7e4182c2c51dbf6771874ebf58d021a6bea97d6
Reason for change: avoid assertion if retuning to this type of HLS content
Test Procedure: see ticket
Risks: Low

Change-Id: I25a09d7afeffde836a597fa62281d5d1fe9d0132
…and share notes with aamp team

Reason for change: recommended changes for UVE doc from JSPP lead
Test Procedure: eyes on doc - resolve final diff
Risks: Low

Change-Id: I631cf3ebed85878f0ffda6603788d44f915752c3
Reason for change: Cleanup member variables in class TsbFragmentData
Test Procedure: Run L1 and L2 Test
Risks: Low

Change-Id: I85e61d83285ec4c1931abad7f913c781eea8d5df
Signed-off-by: Vijendra Nagori <[email protected]>
Reason for change: AAMP fails to create TSB dir inside container
Changes:
* Create directories recursively and set the permission of the created
  directory to 777
* Create the Flush directory before locking the TSB Location;
  it makes the code simpler
* Create files in Local TSB with 666 permissions
* Add std::filesystem permissions and perms to the TSB FS interface and
  remove create_directories
* Verify the changes in TSB L1 mocked tests
* Verify permissions in TSB L1 real fs tests

Test Procedure: Run AAMP L1 tests

Risks: Medium

Change-Id: I34c7c7ec069c43e19eb4b0c585f86f61c92949af
Signed-off-by: Jose Fagundez <[email protected]>
Reason for change: fix regression  from debouncing changes
Test Procedure: see original ticket
Risks: Low

Change-Id: I27b012c566d72926eab8907ba0e0d6c2df5ff603
Reason for change: code simplifications
Test Procedure: basic regression tests (HLS)
Risks: Low

Change-Id: Ib7e7f4fcd3eadb5d2378f825a2b4987679f103d5
Reason for change: support for playback of muxed hls/ts w/ pts restamping
Test Procedure: refer ticket
Risks: Low

Change-Id: If8acb510e07385f8b44d4229f915e49b46c1be76
Reason for Change : pts-offset , GST_EVENT_CUSTOM_DOWNSTREAM Event is sentto the Rialto module from AAMP subtitlesource only after the pipeline state is changed to PLAYING (~after 5 sec)

Test Procedure: Tune to FAST channel from the list 1001 - 1006, 1025, 1026,1031 - 1036 and monitor subtitle display
Risks: Medium

Change-Id: Ieed3bdfef791fa51f39784832fe346c34f6d1458
Signed-off-by: haripriya_molakalapalli <[email protected]>
Reason for change: If low bw timeout is done in fog, do not do it in aamp

Test Procedure: See ticket

Risks: Low

Change-Id: I035ae1dbad79fb9b8ec498404375fa3bf92b4d51
Signed-off-by: <[email protected]>
Reason for change: Clarify the code and help further development
Changes:
* Set LocalAAMPTsbInjection flag at the beginning of TuneHelper()
  instead of the end, so this flag is true only when playing from TSB
* Simplify conditions by checking a single flag
* Add and improve comments
* Use a single flag to check when playing from TSB to identify EOS
* Refactor StreamAbstractionAAMP_MPD::Start() to make it simpler
* Add L1 tests to verify the TSB flags with SLD and VOD content

Test Procedure: Run AAMP L1 and L2 tests

Risks: Medium

Change-Id: Idd10973488eff62d97c91dd39ede6f072699dfcd
Signed-off-by: Jose Fagundez <[email protected]>
Reason for change: Disable use of IARM inside containers
Test Procedure:
Priority: P2
Risks: Low
Change-Id: Iddc246677aeeaa99063104d80fb00f147a200bec
Signed-off-by: shripad bankar <[email protected]>
This reverts commit 0300ef14c9484014661bff7e7566aede8f6e934f.

Reason for revert: Caused a regression when AAMP Local TSB is not enabled, making multiple L2 tests fail.

Change-Id: Ic4b81e61ffe68fc5dff799ee0750ec730791353f
Reason for change: Clarify the code and help further development
Changes:
* Set LocalAAMPTsbInjection flag at the beginning of TuneHelper()
  instead of the end, so this flag is true only when playing from TSB
* Simplify conditions by checking a single flag
* Add and improve comments
* Use a single flag to check when playing from TSB to identify EOS
* Refactor StreamAbstractionAAMP_MPD::Start() to make it simpler
* Add L1 tests to verify the TSB flags with SLD and VOD content

Test Procedure: Run AAMP L1 and L2 tests

Risks: Medium

Change-Id: Icf369331b9f11200ce01cd36d7945414fd661587
Signed-off-by: Jose Fagundez <[email protected]>
…unreliable

Reason For Change: When playing from TSB. On a period boundary the
audio track is getting disabled. This manifests as an intermittent
L2 test failure. A block of code is not needed.

Test Proceedure: Verify tests 5001, 5001 are passing consistently

Risk: Low

Change-Id: I4f8bf62ee2e8c060e27374579f74c9296294efd4
Reason for change: CDAI code cleanup and enhancing L2 tests
related to CDAI
Test Procedure: Make sure all CDAI L2 80xx passes and there are
no regressions with CDAI playback
Risks: Low

Change-Id: I09df69942371be20a1d3f9fd2cb8b96a596289bb
Signed-off-by: Vinish K B <[email protected]>
Reason for change: remove bad spellings from whitelist
Test Procedure: review whitelist (and corresponding aamp code) to further improve
Risks: Low

Change-Id: Ie0486b3de804eba2e505b71f1fc4205b011bd5e0
Reason for change: Fixing a crash in RemoveProbe, probes were not removed while
changing the rate, causing crash while stopping the playback at trickplay
Risks: Low
Test Procedure: Test with 8003 test cases
Priority: P1

Change-Id: I9519950b670dee9f3163985cc2ed3d943a00729a
Signed-off-by: Nandakishor Udiyannur<[email protected]>
Reason for change: remove clutter with not needed ifdef WIN32
Test Procedure: light regression
Risks: Low

Change-Id: Iab15c8faf4b241844026273a1e97afd40edeee1f
Reason for change: Test the logging.
Test Procedure: IP Playbacks.
Risks: None
Change-Id: Ia6344f282c518977d4ff5063c17b1a3ccf054f5a
Signed-off-by: Paulpandian Mariappan <[email protected]>
Reason for change: In some of the AampTsb files, few
  milestone logs are previously added as warnings;
  convert them to milestone logs

Changes:
* Changed some of the warning logs to milestone logs in
  AampTsbDataManager.cpp, AampTsbReader.cpp and
  fragmentcollector_mpd.cpp

Test Procedure: Run AAMP L2 tests 5001 and 5002 and verify that the
                required logs are changed to milestones

Risks: Low

Change-Id: I1e05c27368e82e58dba7ef84dab89cf3267cb781
Signed-off-by: Anjali Jacob <[email protected]>
Reason for change:
With local TSB enabled, pause was always performing a seek into the TSB buffer.
Changed so that:
    - Pausing pauses the gstreamer pipeline
    - Resume from already within the TSB just resumes the pipeline to playing
    - Resume from Live performs a seek to the nearest fragment in the TSB (which can still result in a jump forward/backwards of a partial fragment)

Test Procedure:
Run AAMP L1 and L2 test 5001 & 5002
Tested at full stack

Risks: Low

Signed-off-by: Andrew Shepherd<[email protected]>

Change-Id: I0f933fa137441b91718f4ebcfe29e45800bc3c9c
Reason for Change : Trick Mode(2xFF),only video stream is available but due to faulty configuration of Rialto audio stream context, pipeline/Video Sink struck at Ready/Paused state resulting in L3 test failure.

Test Procedure: Test with L3

Risks: Medium

Change-Id: I32fb3fdd0213b5436e3f58ba26dfdc1325da6cc1
Signed-off-by: haripriya_molakalapalli <[email protected]>
Reason for Change : In case of Rialto Sink Subtitle switch is not working

Test Procedure: Test with L3 Rialto test widget
Risks: Medium

Change-Id: I0f8a780946d74b32b45c455932e66a25f791ebb4
Signed-off-by: haripriya_molakalapalli <[email protected]>
@rdkcmf-jenkins
Copy link

Coverity Issue - Data race condition

A wait is performed without a loop. If there is a spurious wakeup, the condition may not be satisfied.

Medium Impact, CWE-none
BAD_CHECK_OF_WAIT_COND

How to fix

Check the wait condition in a loop, with the lock held. The lock must not be released between the condition and the wait.

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
streamabstraction.cpp:673

@rdkcmf-jenkins
Copy link

Coverity Issue - Variable copied when it could be moved

"manifestUrl" is passed-by-value as parameter to "std::__cxx11::basic_string<char, std::char_traits, std::allocator >::basic_string(std::__cxx11::basic_string<char, std::char_traits, std::allocator > const &)", when it could be moved instead.

Low Impact, CWE-none
COPY_INSTEAD_OF_MOVE

How to fix

Use "std::move(""manifestUrl"")" instead of "manifestUrl".

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
middleware/InterfacePlayerRDK.cpp:5109

@rdkcmf-jenkins
Copy link

Coverity Issue - Variable copied when it could be moved

"debugLevel" is passed-by-value as parameter to "std::__cxx11::basic_string<char, std::char_traits, std::allocator >::basic_string(std::__cxx11::basic_string<char, std::char_traits, std::allocator > const &)", when it could be moved instead.

Low Impact, CWE-none
COPY_INSTEAD_OF_MOVE

How to fix

Use "std::move(""debugLevel"")" instead of "debugLevel".

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
aampgstplayer.cpp:410

@rdkcmf-jenkins
Copy link

Coverity Issue - Data race condition

A wait is performed without a loop. If there is a spurious wakeup, the condition may not be satisfied.

Medium Impact, CWE-none
BAD_CHECK_OF_WAIT_COND

How to fix

Check the wait condition in a loop, with the lock held. The lock must not be released between the condition and the wait.

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
streamabstraction.cpp:622

@rdkcmf-jenkins
Copy link

Coverity Issue - Data race condition

A wait is performed without a loop. If there is a spurious wakeup, the condition may not be satisfied. [Note: The source code implementation of the function has been overridden by a builtin model.]

Medium Impact, CWE-none
BAD_CHECK_OF_WAIT_COND

How to fix

Check the wait condition in a loop, with the lock held. The lock must not be released between the condition and the wait.

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
streamabstraction.cpp:614

@rdkcmf-jenkins
Copy link

Coverity Issue - Variable copied when it could be moved

"callback" is copied in call to copy assignment for class "std::function<void (GstMediaType, bool, bool, bool &, bool &)>", when it could be moved instead.

Low Impact, CWE-none
COPY_INSTEAD_OF_MOVE

How to fix

Use "std::move(""callback"")" instead of "callback".

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
middleware/InterfacePlayerRDK.cpp:3552

@rdkcmf-jenkins
Copy link

Coverity Issue - Data race condition

Accessing "this->bufferStatus" without holding lock "MediaTrack.mutex". Elsewhere, "MediaTrack.bufferStatus" is written to with "MediaTrack.mutex" held 1 out of 1 times.

Medium Impact, CWE-366
MISSING_LOCK

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
streamabstraction.cpp:197

@rdkcmf-jenkins
Copy link

Coverity Issue - Unchecked return value

Calling "wait_for" without checking return value (as is done elsewhere 6 out of 6 times).

Medium Impact, CWE-252
CHECKED_RETURN

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
middleware/InterfacePlayerRDK.cpp:2819

@rdkcmf-jenkins
Copy link

Coverity Issue - Dereference before null check

Null-checking "pInterfacePlayerRDK" suggests that it may be null, but it has already been dereferenced on all paths leading to the check.

Medium Impact, CWE-476
REVERSE_INULL

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
middleware/InterfacePlayerRDK.cpp:4596

@rdkcmf-jenkins
Copy link

Coverity Issue - Variable copied when it could be moved

"callback" is copied in call to copy assignment for class "std::function<void (bool, int)>", when it could be moved instead.

Low Impact, CWE-none
COPY_INSTEAD_OF_MOVE

How to fix

Use "std::move(""callback"")" instead of "callback".

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
middleware/InterfacePlayerRDK.cpp:3561

@rdkcmf-jenkins
Copy link

Coverity Issue - Double unlock

"~unique_lock" unlocks "lock" while it is unlocked. [Note: The source code implementation of the function has been overridden by a builtin model.]

Medium Impact, CWE-765
LOCK

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
streamabstraction.cpp:763

@rdkcmf-jenkins
Copy link

Coverity Issue - Double unlock

"PushNextFragment" unlocks "pMediaStreamContext->mutex" while it is unlocked.

Medium Impact, CWE-765
LOCK

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
fragmentcollector_mpd.cpp:6906

@rdkcmf-jenkins
Copy link

Coverity Issue - Data race condition

Accessing "this->m_enabled" without holding lock "TSProcessor.m_mutex". Elsewhere, "TSProcessor.m_enabled" is written to with "TSProcessor.m_mutex" held 2 out of 3 times.

Medium Impact, CWE-366
MISSING_LOCK

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
tsprocessor.cpp:2716

@rdkcmf-jenkins
Copy link

Coverity Issue - Double unlock

"FetchFragment" unlocks "pMediaStreamContext->mutex" while it is unlocked.

Medium Impact, CWE-765
LOCK

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
fragmentcollector_mpd.cpp:5439

@rdkcmf-jenkins
Copy link

Coverity Issue - Variable copied when it could be moved

"busEvent" is passed-by-value as parameter to "BusEventData::BusEventData(BusEventData const &) /implicit =default/", when it could be moved instead.

Low Impact, CWE-none
COPY_INSTEAD_OF_MOVE

How to fix

Use "std::move(""busEvent"")" instead of "busEvent".

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
middleware/InterfacePlayerRDK.cpp:4322

@rdkcmf-jenkins
Copy link

Coverity Issue - Check of thread-shared field evades lock acquisition

Thread1 sets "format" to a new value. Now the two threads have an inconsistent view of "format" and updates to fields correlated with "format" may be lost.

High Impact, CWE-543
LOCK_EVASION

How to fix

Guard the modification of "format" and the read used to decide whether to modify "format" with the same set of locks.

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
middleware/InterfacePlayerRDK.cpp:1267

@rdkcmf-jenkins
Copy link

Coverity Issue - Data race condition

A wait is performed without a loop. If there is a spurious wakeup, the condition may not be satisfied.

Medium Impact, CWE-none
BAD_CHECK_OF_WAIT_COND

How to fix

Check the wait condition in a loop, with the lock held. The lock must not be released between the condition and the wait.

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
priv_aamp.cpp:7564

@rdkcmf-jenkins
Copy link

Coverity Issue - Variable copied when it could be moved

"_name" is passed-by-value as parameter to "std::__cxx11::basic_string<char, std::char_traits, std::allocator >::basic_string(std::__cxx11::basic_string<char, std::char_traits, std::allocator > const &)", when it could be moved instead.

Low Impact, CWE-none
COPY_INSTEAD_OF_MOVE

How to fix

Use "std::move(""_name"")" instead of "_name".

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
middleware/InterfacePlayerRDK.h:350

@rdkcmf-jenkins
Copy link

Coverity Issue - Data race condition

A wait is performed without a loop. If there is a spurious wakeup, the condition may not be satisfied.

Medium Impact, CWE-none
BAD_CHECK_OF_WAIT_COND

How to fix

Check the wait condition in a loop, with the lock held. The lock must not be released between the condition and the wait.

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
streamabstraction.cpp:3187

@rdkcmf-jenkins
Copy link

Coverity Issue - Data race condition

A wait is performed without a loop. If there is a spurious wakeup, the condition may not be satisfied. [Note: The source code implementation of the function has been overridden by a builtin model.]

Medium Impact, CWE-none
BAD_CHECK_OF_WAIT_COND

How to fix

Check the wait condition in a loop, with the lock held. The lock must not be released between the condition and the wait.

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
tsprocessor.cpp:855

@rdkcmf-jenkins
Copy link

Coverity Issue - Data race condition

A wait is performed without a loop. If there is a spurious wakeup, the condition may not be satisfied. [Note: The source code implementation of the function has been overridden by a builtin model.]

Medium Impact, CWE-none
BAD_CHECK_OF_WAIT_COND

How to fix

Check the wait condition in a loop, with the lock held. The lock must not be released between the condition and the wait.

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
streamabstraction.cpp:601

@rdkcmf-jenkins
Copy link

Coverity Issue - Use of auto that causes a copy

Using the "auto" keyword without an "&" causes the copy of an object of type "GstPlayerPriv::CallbackData".

Low Impact, CWE-none
AUTO_CAUSES_COPY

How to fix

Use "const auto &" instead of "auto".

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
middleware/InterfacePlayerRDK.cpp:894

@rdkcmf-jenkins
Copy link

Coverity Issue - Indefinite wait

A wait is performed without ensuring that the condition is not already satisfied while holding lock "MediaTrack.subtitleMutex". This can cause a deadlock if the notification happens before the lock is acquired.

High Impact, CWE-none
BAD_CHECK_OF_WAIT_COND

How to fix

Acquire the lock, then check the wait condition in a loop, without releasing with the lock before the wait. This will prevent deadlocks and failed conditions from spurious wakeups.

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
streamabstraction.cpp:1467

@rdkcmf-jenkins
Copy link

Coverity Issue - Variable copied when it could be moved

"busEvent" is passed-by-value as parameter to "BusEventData::BusEventData(BusEventData const &) /implicit =default/", when it could be moved instead.

Low Impact, CWE-none
COPY_INSTEAD_OF_MOVE

How to fix

Use "std::move(""busEvent"")" instead of "busEvent".

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
middleware/InterfacePlayerRDK.cpp:4309

@rdkcmf-jenkins
Copy link

Coverity Issue - Resource leak in object

Allocating memory by calling "new Configs".

High Impact, CWE-401
CTOR_DTOR_LEAK

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
middleware/InterfacePlayerRDK.cpp:69

@rdkcmf-jenkins
Copy link

Coverity Issue - Data race condition

A wait is performed without a loop. If there is a spurious wakeup, the condition may not be satisfied.

Medium Impact, CWE-none
BAD_CHECK_OF_WAIT_COND

How to fix

Check the wait condition in a loop, with the lock held. The lock must not be released between the condition and the wait.

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
streamabstraction.cpp:642

@rdkcmf-jenkins
Copy link

Coverity Issue - Data race condition

A wait is performed without a loop. If there is a spurious wakeup, the condition may not be satisfied.

Medium Impact, CWE-none
BAD_CHECK_OF_WAIT_COND

How to fix

Check the wait condition in a loop, with the lock held. The lock must not be released between the condition and the wait.

Issue location

This issue was discovered outside the diff for this Pull Request. You can find it at:
tsprocessor.cpp:1882

std::string prId, std::shared_ptr<TsbInitData> initData, uint32_t timeScale, double PTSOffsetSec)
: TsbSegment(url, media, prId), position(position), duration(duration), mPTS(pts), isDiscontinuous(disc), initFragData(initData),
relativePosition(relativePos), timeScale(timeScale), PTSOffsetSec(PTSOffsetSec)
: TsbSegment(url, media, prId), absolutePositionS(absolutePositionS), duration(duration), mPTS(pts), isDiscontinuous(disc), initFragData(initData),

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Coverity Issue - Variable copied when it could be moved

"initData" is passed-by-value as parameter to "std::shared_ptr::shared_ptr(std::shared_ptr const &) /explicit =default/", when it could be moved instead.

Low Impact, CWE-none
COPY_INSTEAD_OF_MOVE

How to fix

Use "std::move(""initData"")" instead of "initData".

{
if (videoDiscontinuityIndex[i].position < audioDiscontinuityIndex[i].position)
for( DiscontinuityIndexNode &audioDiscontinuity : audio->mDiscontinuityIndex )

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Coverity Issue - Structurally dead code

Since the loop increment "++;" is unreachable, the loop body will never execute more than once.

Medium Impact, CWE-561
UNREACHABLE

std::string prId, std::shared_ptr<TsbInitData> initData, uint32_t timeScale, double PTSOffsetSec)
: TsbSegment(url, media, prId), position(position), duration(duration), mPTS(pts), isDiscontinuous(disc), initFragData(initData),
relativePosition(relativePos), timeScale(timeScale), PTSOffsetSec(PTSOffsetSec)
: TsbSegment(url, media, prId), absolutePositionS(absolutePositionS), duration(duration), mPTS(pts), isDiscontinuous(disc), initFragData(initData),

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Coverity Issue - Variable copied when it could be moved

"prId" is passed-by-value as parameter to "std::__cxx11::basic_string<char, std::char_traits, std::allocator >::basic_string(std::__cxx11::basic_string<char, std::char_traits, std::allocator > const &)", when it could be moved instead.

Low Impact, CWE-none
COPY_INSTEAD_OF_MOVE

How to fix

Use "std::move(""prId"")" instead of "prId".

if(!mAdtoInsertInNextBreakVec.empty())
{
mPlacementObj = setPlacementObj(mPlacementObj.pendingAdbrkId,abObj.endPeriodId);
// Remove the placement object that was placed completely
RemovePlacementObj(adBreakIdToRemove);

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Coverity Issue - Variable copied when it could be moved

"adBreakIdToRemove" is passed-by-value as parameter to "std::__cxx11::basic_string<char, std::char_traits, std::allocator >::basic_string(std::__cxx11::basic_string<char, std::char_traits, std::allocator > const &)", when it could be moved instead.

Low Impact, CWE-none
COPY_INSTEAD_OF_MOVE

How to fix

Use "std::move(""adBreakIdToRemove"")" instead of "adBreakIdToRemove".

std::string prId, std::shared_ptr<TsbInitData> initData, uint32_t timeScale, double PTSOffsetSec)
: TsbSegment(url, media, prId), position(position), duration(duration), mPTS(pts), isDiscontinuous(disc), initFragData(initData),
relativePosition(relativePos), timeScale(timeScale), PTSOffsetSec(PTSOffsetSec)
: TsbSegment(url, media, prId), absolutePositionS(absolutePositionS), duration(duration), mPTS(pts), isDiscontinuous(disc), initFragData(initData),

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Coverity Issue - Variable copied when it could be moved

"url" is passed-by-value as parameter to "std::__cxx11::basic_string<char, std::char_traits, std::allocator >::basic_string(std::__cxx11::basic_string<char, std::char_traits, std::allocator > const &)", when it could be moved instead.

Low Impact, CWE-none
COPY_INSTEAD_OF_MOVE

How to fix

Use "std::move(""url"")" instead of "url".


Flush( 1.0/*rate*/, 0/*start*/, -1/*stop*/, 0/*baseTime*/ );

for( auto segmentInfo : segmentList )

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Coverity Issue - Use of auto that causes a copy

Using the "auto" keyword without an "&" causes the copy of an object of type "AppContext::LoadHLS(char const *, unsigned long, std::__cxx11::basic_string<char, std::char_traits, std::allocator > const &)::SegmentInfo".

Low Impact, CWE-none
AUTO_CAUSES_COPY

How to fix

Use "const auto &" instead of "auto".

@@ -8144,7 +8134,7 @@ void PrivateInstanceAAMP::ScheduleRetune(PlaybackErrorType errorType, AampMediaT
gLock.lock();
if (this->mIsRetuneInProgress)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Coverity Issue - Data race condition

Accessing "this->mIsRetuneInProgress" without holding lock "gMutex". Elsewhere, "PrivateInstanceAAMP.mIsRetuneInProgress" is written to with "gMutex" held 2 out of 2 times (1 of these accesses strongly imply that it is necessary).

Medium Impact, CWE-366
MISSING_LOCK

@shripadbpersonal shripadbpersonal merged commit 40aaddb into develop Mar 26, 2025
2 of 5 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.