-
Notifications
You must be signed in to change notification settings - Fork 27
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
Port commits from android 14 #206
Conversation
Improper Commit Message |
1. Send consumer usage from framework, allocate system/video memory according to consumer usage. 2. If cpu read often, use minigbm allocate linear NV12 buffer, and C2 send this "system buffer" to OneVPL, OneVPL internally allocate NV12 buffer for decoding using vaapi and copy this internal buffer to linear surface internally Tracked-On: OAM-124103 Signed-off-by: Nana Zhang <[email protected]> (cherry picked from commit 7968852) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
Tracked-On: OAM-124578 Signed-off-by: Nana Zhang <[email protected]> (cherry picked from commit a071ad9) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
run ats -a x86_6 -m GtsExoPlayerTestCases -t com.google.android.exoplayer.gts.CommonEncryptionDrmTest#cencSchemeTypeV184 The root cause is that the resolution changed processing flow was triggered when decoding the last input bitstream with the same timestamp but different frame index. At this point, the input must be processed as an independent frame. Tracked-On: OAM-118988 Signed-off-by: Wan, Hao <[email protected]> (cherry picked from commit 769bcd1) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
This reverts commit 3542c39. As driver doesn't support decode 10bit bitsteam to 8 bit frames directly. Previous solution of changing frame info to 8-bit does not work. Revert the commit and use VPP to convert 10 bit frames to 8 bit. Tracked-On: OAM-122766 Signed-off-by: Lina Sun <[email protected]> (cherry picked from commit 9451408) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
For 10 bit bitstream decoder, if decode format is not specified, VPP convert 10 bit frames to 8 bit frames as output. Tracked-On: OAM-122766 Signed-off-by: Lina Sun <[email protected]> (cherry picked from commit 656fff2) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
std::make_shared will throw the std::bad_alloc exception rather than return nullptr. Here just remove the logically dead code for the coverity issue. Tracked-On: OAM-123225 Signed-off-by: Wan, Hao <[email protected]> (cherry picked from commit a2321db) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
CID/Type: 187157 Explicit null dereferenced 656172 Dereference after null check 602228 Dereference before null check Tracked-On: OAM-126078 Signed-off-by: Wan, Hao <[email protected]> (cherry picked from commit 1c6ccea) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
When `MFX_BUFFER_QUEUE` is enabled, `mediaskd_c2` will use a buffer queue implemented in `mediasdk_c2`(maybe framework doesn't support before). Now, we will use the buffer queue in Android media framework. Therefore, this part of the code is deprecated. Signed-off-by: Nana Zhang <[email protected]> Tracked-On: OAM-124733 (cherry picked from commit 5d67a88) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
CID 398855: 'Constant' variable guards dead code Refer to the implementation of ImportBuffer in minigbm: hardware/intel/external/minigbm-intel/cros_gralloc/gralloc1/cros_gralloc1_module.cc int32_t CrosGralloc1::importBuffer(const buffer_handle_t rawHandle, buffer_handle_t *outBuffer) Tracked-On: OAM-126428 Signed-off-by: Wan, Hao <[email protected]> (cherry picked from commit e87dd39) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
Will add dumping code in another way, input & output buffer dump for encoder & decoder will all be able to be configured by set property. Tracked-On: OAM-124732 Signed-off-by: Lina Sun <[email protected]> (cherry picked from commit d150b3b) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
Dump can be enabled by set property, detailed steps can be found in mfx_c2_encoder_component.cpp/mfx_c2_decoder_component.cpp, near InitDump(). Tracked-On: OAM-124732 Signed-off-by: Lina Sun <[email protected]> (cherry picked from commit cebb891) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
In widevine L3 stream play test, the timestamps between Load and Decode have gaps. Tracked-On: OAM-124689 Signed-off-by: Nana Zhang <[email protected]> (cherry picked from commit 5cb9ea7) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
Fix AV1 encode issue of "Encoder configure failed" and test be always waiting and can not run to end when running ffmpeg. "Encoder configure failed" is because in mfx_set_RateControlMethod function AV1 encoder case in not handled. Test always wait and can't run to end is because GopRefDist is not set when initializing AV1 encoder, default value of 8 from vpl is used, which caused mediasdk_c2 can't send work done notification to framework codec, so framework codec can't queue more works after queuing initial 4 works. Besides, use PROFILE_AV1_0 & LEVEL_AV1_5_3 as default AV1 encoder profile & level instead of PROFILE_AV1_0 & LEVEL_AV1_7_3, as the latter can not work. Tracked-On: OAM-124081 Signed-off-by: Lina Sun <[email protected]> (cherry picked from commit d48d495) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
In hybrid GPU case, video decoder could be iGPU and the coded images would be consumed by dGPU. Unfortunately, it's likely that we can hardly find a tiling format supported by both of them. To achieve best compatibility and make our life better, simply use linear buffers for decoded images. By setting CPU_READ and CPU_WRITE flags, we force OneVPL to allocate internal buffers and blit decoded content to external buffers. In this way we can work around hardware limitation that DG2 cannot decode to linear buffers. We will detect the GPU group type and decide whether to use linear buffers or not. Tracked-On: OAM-126399 Signed-off-by: Weifeng Liu <[email protected]> (cherry picked from commit bfcd81e) Tracked-On: OAM-128364 Signed-off-by: Lina Sun <[email protected]>
7697367
to
dd00ed4
Compare
Issue is when playing 4k or 1080p video with gallery, video get stuck on android 15. Cause is when c2 service change from hidl to aidl, block pool used in framework will change from buffer queue to IGBA, when allocating surface, surface metadata of igbp_id and igbp_slot will not be updated because they are buffer queue related concept. While in mediasdk_c2, it was checking igbp_id and igbp_slot during InitDecoder(), and caused IO pattern changed from video memory to system memory. Solution is removing checking of igbp_id and igbp_slot for now. This way will cause some vts test fail, which will need be fixed. Tracked-On: OAM-128397 Tracked-On: OAM-128324 Tracked-On: OAM-128315 Signed-off-by: Lina Sun <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
Android CI has started Engineering Build for this issue ,Please check the linked Tracked-On issue/Android CI Web for more details. |
1 similar comment
Android CI has started Engineering Build for this issue ,Please check the linked Tracked-On issue/Android CI Web for more details. |
SUCCESS: Android CI has completed Engineering Build for this issue.Please check the linked Tracked-On issue/Android CI Web for more details. |
SUCCESS: Android CI has completed Engineering Build for this issue.Please check the linked Tracked-On issue/Android CI Web for more details. |
Android CI has started MERGE Build for this pr ,Please check the linked Tracked-On issue/Android CI Web for more details. |
Android CI has completed MERGE Build for this pr, build is SUCCESS. Please check the linked Tracked-On issue/Android CI Web for more details. For Binaries: /cactus-absp-or-local/celadon-merge/910 |
Port commits from android 14