|
|
|
@ -78,8 +78,7 @@ namespace MediaBrowser.Controller.MediaEncoding
|
|
|
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(hwType)
|
|
|
|
|
&& encodingOptions.EnableHardwareEncoding
|
|
|
|
|
&& codecMap.ContainsKey(hwType)
|
|
|
|
|
&& CheckVaapi(state, hwType, encodingOptions))
|
|
|
|
|
&& codecMap.ContainsKey(hwType))
|
|
|
|
|
{
|
|
|
|
|
var preferredEncoder = codecMap[hwType];
|
|
|
|
|
|
|
|
|
@ -93,23 +92,6 @@ namespace MediaBrowser.Controller.MediaEncoding
|
|
|
|
|
return defaultEncoder;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private bool CheckVaapi(EncodingJobInfo state, string hwType, EncodingOptions encodingOptions)
|
|
|
|
|
{
|
|
|
|
|
if (!string.Equals(hwType, "vaapi", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
{
|
|
|
|
|
// No vaapi requested, return OK.
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (string.IsNullOrEmpty(encodingOptions.VaapiDevice))
|
|
|
|
|
{
|
|
|
|
|
// No device specified, return OK.
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return IsVaapiSupported(state);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private bool IsVaapiSupported(EncodingJobInfo state)
|
|
|
|
|
{
|
|
|
|
|
var videoStream = state.VideoStream;
|
|
|
|
@ -1605,7 +1587,7 @@ namespace MediaBrowser.Controller.MediaEncoding
|
|
|
|
|
// For VAAPI and CUVID decoder
|
|
|
|
|
// these encoders cannot automatically adjust the size of graphical subtitles to fit the output video,
|
|
|
|
|
// thus needs to be manually adjusted.
|
|
|
|
|
if (string.Equals(options.HardwareAccelerationType, "vaapi", StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
if ((IsVaapiSupported(state) && string.Equals(options.HardwareAccelerationType, "vaapi", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|| (videoDecoder ?? string.Empty).IndexOf("cuvid", StringComparison.OrdinalIgnoreCase) != -1)
|
|
|
|
|
{
|
|
|
|
|
var videoStream = state.VideoStream;
|
|
|
|
@ -1648,7 +1630,7 @@ namespace MediaBrowser.Controller.MediaEncoding
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// If we're hardware VAAPI decoding and software encoding, download frames from the decoder first
|
|
|
|
|
else if (string.Equals(options.HardwareAccelerationType, "vaapi", StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
else if (IsVaapiSupported(state) && string.Equals(options.HardwareAccelerationType, "vaapi", StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
&& string.Equals(outputVideoCodec, "libx264", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
{
|
|
|
|
|
/*
|
|
|
|
@ -2014,19 +1996,29 @@ namespace MediaBrowser.Controller.MediaEncoding
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// If we're hardware VAAPI decoding and software encoding, download frames from the decoder first
|
|
|
|
|
else if (string.Equals(options.HardwareAccelerationType, "vaapi", StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
else if (IsVaapiSupported(state) && string.Equals(options.HardwareAccelerationType, "vaapi", StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
&& string.Equals(outputVideoCodec, "libx264", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
{
|
|
|
|
|
var codec = videoStream.Codec.ToLowerInvariant();
|
|
|
|
|
var pixelFormat = videoStream.PixelFormat.ToLowerInvariant();
|
|
|
|
|
|
|
|
|
|
// Assert hardware VAAPI decodable (Except h264 10-bit and higher color depth)
|
|
|
|
|
// TODO: a propery way to detect hardware capabilities and falling back when transcoding is failed
|
|
|
|
|
if ((pixelFormat ?? string.Empty).IndexOf("p10", StringComparison.OrdinalIgnoreCase) == -1
|
|
|
|
|
|| ((pixelFormat ?? string.Empty).IndexOf("p10", StringComparison.OrdinalIgnoreCase) != -1
|
|
|
|
|
&& (string.Equals(codec, "hevc", StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
|| string.Equals(codec, "h265", StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
|| string.Equals(codec, "vp9", StringComparison.OrdinalIgnoreCase))))
|
|
|
|
|
var isColorDepth10 = !string.IsNullOrEmpty(videoStream.Profile) && (videoStream.Profile.Contains("Main 10", StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
|| videoStream.Profile.Contains("High 10", StringComparison.OrdinalIgnoreCase));
|
|
|
|
|
|
|
|
|
|
// Assert 10-bit hardware VAAPI decodable
|
|
|
|
|
if (isColorDepth10 && (string.Equals(codec, "hevc", StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
|| string.Equals(codec, "h265", StringComparison.OrdinalIgnoreCase)
|
|
|
|
|
|| string.Equals(codec, "vp9", StringComparison.OrdinalIgnoreCase)))
|
|
|
|
|
{
|
|
|
|
|
/*
|
|
|
|
|
Download data from GPU to CPU as p010le format.
|
|
|
|
|
Colorspace conversion is unnecessary here as libx264 will handle it.
|
|
|
|
|
If this step is missing, it will fail on AMD but not on intel.
|
|
|
|
|
*/
|
|
|
|
|
filters.Add("hwdownload");
|
|
|
|
|
filters.Add("format=p010le");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Assert 8-bit hardware VAAPI decodable
|
|
|
|
|
else if (!isColorDepth10)
|
|
|
|
|
{
|
|
|
|
|
filters.Add("hwdownload");
|
|
|
|
|
filters.Add("format=nv12");
|
|
|
|
|