mirror of
https://github.com/moonlight-stream/moonlight-qt
synced 2025-01-10 02:08:43 +00:00
Use BT.709 in DrmRenderer only on Starfive devices
This commit is contained in:
parent
6fa53691aa
commit
5974980aff
2 changed files with 28 additions and 8 deletions
|
@ -81,6 +81,7 @@ DrmRenderer::DrmRenderer(bool hwaccel, IFFmpegRenderer *backendRenderer)
|
||||||
m_ColorRangeProp(nullptr),
|
m_ColorRangeProp(nullptr),
|
||||||
m_HdrOutputMetadataProp(nullptr),
|
m_HdrOutputMetadataProp(nullptr),
|
||||||
m_ColorspaceProp(nullptr),
|
m_ColorspaceProp(nullptr),
|
||||||
|
m_Version(nullptr),
|
||||||
m_HdrOutputMetadataBlobId(0),
|
m_HdrOutputMetadataBlobId(0),
|
||||||
m_SwFrameMapper(this),
|
m_SwFrameMapper(this),
|
||||||
m_CurrentSwFrameIdx(0)
|
m_CurrentSwFrameIdx(0)
|
||||||
|
@ -140,6 +141,10 @@ DrmRenderer::~DrmRenderer()
|
||||||
drmModeFreePlane(m_Plane);
|
drmModeFreePlane(m_Plane);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (m_Version != nullptr) {
|
||||||
|
drmFreeVersion(m_Version);
|
||||||
|
}
|
||||||
|
|
||||||
if (m_HwContext != nullptr) {
|
if (m_HwContext != nullptr) {
|
||||||
av_buffer_unref(&m_HwContext);
|
av_buffer_unref(&m_HwContext);
|
||||||
}
|
}
|
||||||
|
@ -252,6 +257,18 @@ bool DrmRenderer::initialize(PDECODER_PARAMETERS params)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Fetch version details about the DRM driver to use later
|
||||||
|
m_Version = drmGetVersion(m_DrmFd);
|
||||||
|
if (m_Version == nullptr) {
|
||||||
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,
|
||||||
|
"drmGetVersion() failed: %d",
|
||||||
|
errno);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
SDL_LogInfo(SDL_LOG_CATEGORY_APPLICATION,
|
||||||
|
"GPU driver: %s", m_Version->name);
|
||||||
|
|
||||||
// Create the device context first because it is needed whether we can
|
// Create the device context first because it is needed whether we can
|
||||||
// actually use direct rendering or not.
|
// actually use direct rendering or not.
|
||||||
m_HwContext = av_hwdevice_ctx_alloc(AV_HWDEVICE_TYPE_DRM);
|
m_HwContext = av_hwdevice_ctx_alloc(AV_HWDEVICE_TYPE_DRM);
|
||||||
|
@ -1143,14 +1160,16 @@ bool DrmRenderer::isDirectRenderingSupported()
|
||||||
|
|
||||||
int DrmRenderer::getDecoderColorspace()
|
int DrmRenderer::getDecoderColorspace()
|
||||||
{
|
{
|
||||||
// Some DRM implementations (VisionFive) don't support BT.601 color encoding,
|
// The starfive driver used on the VisionFive 2 doesn't support BT.601,
|
||||||
// so let's default to BT.709, which all drivers that support COLOR_ENCODING
|
// so we will use BT.709 instead. Rockchip doesn't support BT.709, even
|
||||||
// seem to support.
|
// in some cases where it exposes COLOR_ENCODING properties, so we stick
|
||||||
//
|
// to BT.601 which seems to be the default for YUV planes on Linux.
|
||||||
// If COLOR_ENCODING is not supported, we'll use BT.601 which appears to be
|
if (strcmp(m_Version->name, "starfive") == 0) {
|
||||||
// the default on drivers that don't support COLOR_ENCODING, such as Rockchip
|
return COLORSPACE_REC_709;
|
||||||
// per https://github.com/torvalds/linux/commit/1c21aa8f2b687cebfeff9736d60303a14bf32768
|
}
|
||||||
return m_ColorEncodingProp ? COLORSPACE_REC_709 : COLORSPACE_REC_601;
|
else {
|
||||||
|
return COLORSPACE_REC_601;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* DrmRenderer::getDrmColorEncodingValue(AVFrame* frame)
|
const char* DrmRenderer::getDrmColorEncodingValue(AVFrame* frame)
|
||||||
|
|
|
@ -95,6 +95,7 @@ private:
|
||||||
drmModePropertyPtr m_ColorRangeProp;
|
drmModePropertyPtr m_ColorRangeProp;
|
||||||
drmModePropertyPtr m_HdrOutputMetadataProp;
|
drmModePropertyPtr m_HdrOutputMetadataProp;
|
||||||
drmModePropertyPtr m_ColorspaceProp;
|
drmModePropertyPtr m_ColorspaceProp;
|
||||||
|
drmVersionPtr m_Version;
|
||||||
uint32_t m_HdrOutputMetadataBlobId;
|
uint32_t m_HdrOutputMetadataBlobId;
|
||||||
SDL_Rect m_OutputRect;
|
SDL_Rect m_OutputRect;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue