Add workaround for wrong PerformancePoints on some devices.
Some devices were reported to have wrong PerformancePoint sets that cause 60 fps to be marked as unsupported even though they are supported. Issue: google/ExoPlayer#10898 #minor-release PiperOrigin-RevId: 512580395
This commit is contained in:
parent
7ffcc6f7ea
commit
d0cbf0fce8
@ -27,6 +27,10 @@
|
|||||||
* Video:
|
* Video:
|
||||||
* Map HEVC HDR10 format to `HEVCProfileMain10HDR10` instead of
|
* Map HEVC HDR10 format to `HEVCProfileMain10HDR10` instead of
|
||||||
`HEVCProfileMain10`.
|
`HEVCProfileMain10`.
|
||||||
|
* Add workaround for a device issue on Chromecast with Google TV and
|
||||||
|
Lenovo M10 FHD Plus that causes 60fps AVC streams to be marked as
|
||||||
|
unsupported
|
||||||
|
([#10898](https://github.com/google/ExoPlayer/issues/10898)).
|
||||||
* DASH:
|
* DASH:
|
||||||
* Add full parsing for image adaptation sets, including tile counts
|
* Add full parsing for image adaptation sets, including tile counts
|
||||||
([#3752](https://github.com/google/ExoPlayer/issues/3752)).
|
([#3752](https://github.com/google/ExoPlayer/issues/3752)).
|
||||||
|
@ -857,7 +857,7 @@ public final class MediaCodecInfo {
|
|||||||
* @param name The name of the codec.
|
* @param name The name of the codec.
|
||||||
* @return Whether to enable the workaround.
|
* @return Whether to enable the workaround.
|
||||||
*/
|
*/
|
||||||
private static final boolean needsRotatedVerticalResolutionWorkaround(String name) {
|
private static boolean needsRotatedVerticalResolutionWorkaround(String name) {
|
||||||
if ("OMX.MTK.VIDEO.DECODER.HEVC".equals(name) && "mcv5a".equals(Util.DEVICE)) {
|
if ("OMX.MTK.VIDEO.DECODER.HEVC".equals(name) && "mcv5a".equals(Util.DEVICE)) {
|
||||||
// See https://github.com/google/ExoPlayer/issues/6612.
|
// See https://github.com/google/ExoPlayer/issues/6612.
|
||||||
return false;
|
return false;
|
||||||
@ -876,6 +876,17 @@ public final class MediaCodecInfo {
|
|||||||
&& ("sailfish".equals(Util.DEVICE) || "marlin".equals(Util.DEVICE));
|
&& ("sailfish".equals(Util.DEVICE) || "marlin".equals(Util.DEVICE));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Whether the device is known to have wrong {@link PerformancePoint} declarations. */
|
||||||
|
private static boolean needsIgnorePerformancePointsWorkaround() {
|
||||||
|
// See https://github.com/google/ExoPlayer/issues/10898 and [internal ref: b/267324685].
|
||||||
|
return /* Chromecast with Google TV */ Util.DEVICE.equals("sabrina")
|
||||||
|
|| Util.DEVICE.equals("boreal")
|
||||||
|
/* Lenovo Tablet M10 FHD Plus */
|
||||||
|
|| Util.MODEL.startsWith("Lenovo TB-X605")
|
||||||
|
|| Util.MODEL.startsWith("Lenovo TB-X606")
|
||||||
|
|| Util.MODEL.startsWith("Lenovo TB-X616");
|
||||||
|
}
|
||||||
|
|
||||||
/** Possible outcomes of evaluating PerformancePoint coverage */
|
/** Possible outcomes of evaluating PerformancePoint coverage */
|
||||||
@Documented
|
@Documented
|
||||||
@Retention(RetentionPolicy.SOURCE)
|
@Retention(RetentionPolicy.SOURCE)
|
||||||
@ -900,7 +911,9 @@ public final class MediaCodecInfo {
|
|||||||
VideoCapabilities videoCapabilities, int width, int height, double frameRate) {
|
VideoCapabilities videoCapabilities, int width, int height, double frameRate) {
|
||||||
List<PerformancePoint> performancePointList =
|
List<PerformancePoint> performancePointList =
|
||||||
videoCapabilities.getSupportedPerformancePoints();
|
videoCapabilities.getSupportedPerformancePoints();
|
||||||
if (performancePointList == null || performancePointList.isEmpty()) {
|
if (performancePointList == null
|
||||||
|
|| performancePointList.isEmpty()
|
||||||
|
|| needsIgnorePerformancePointsWorkaround()) {
|
||||||
return COVERAGE_RESULT_NO_EMPTY_LIST;
|
return COVERAGE_RESULT_NO_EMPTY_LIST;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user