Refactor non-hwaccel decoders to use a single list of known codec names

This commit is contained in:
Cameron Gutman 2023-04-02 17:31:31 -05:00
parent fb39ad896e
commit 68daa90b7e

View file

@ -47,17 +47,30 @@
#define FAILED_DECODES_RESET_THRESHOLD 20 #define FAILED_DECODES_RESET_THRESHOLD 20
static const struct { typedef struct {
const char* codec; const char* codec;
int capabilities; int capabilities;
} k_NonHwaccelCodecInfo[] = { } codec_info_t;
static const QList<codec_info_t> k_NonHwaccelH264Codecs = {
#ifdef HAVE_MMAL
{"h264_mmal", 0}, {"h264_mmal", 0},
#endif
{"h264_rkmpp", 0}, {"h264_rkmpp", 0},
{"h264_nvv4l2", 0}, {"h264_nvv4l2", 0},
{"h264_nvmpi", 0}, {"h264_nvmpi", 0},
#ifndef HAVE_MMAL
// Only enable V4L2M2M by default on non-MMAL (RPi) builds. The performance
// of the V4L2M2M wrapper around MMAL is not enough for 1080p 60 FPS, so we
// would rather show the missing hardware acceleration warning when the user
// is in Full KMS mode rather than try to use a poorly performing hwaccel.
// See discussion on https://github.com/jc-kynesim/rpi-ffmpeg/pull/25
{"h264_v4l2m2m", 0}, {"h264_v4l2m2m", 0},
#endif
{"h264_omx", 0}, {"h264_omx", 0},
};
static const QList<codec_info_t> k_NonHwaccelHEVCCodecs = {
{"hevc_rkmpp", 0}, {"hevc_rkmpp", 0},
{"hevc_nvv4l2", CAPABILITY_REFERENCE_FRAME_INVALIDATION_HEVC}, {"hevc_nvv4l2", CAPABILITY_REFERENCE_FRAME_INVALIDATION_HEVC},
{"hevc_nvmpi", 0}, {"hevc_nvmpi", 0},
@ -115,11 +128,21 @@ int FFmpegVideoDecoder::getDecoderCapabilities()
// We have a non-hwaccel hardware decoder. This will always // We have a non-hwaccel hardware decoder. This will always
// be using SDLRenderer/DrmRenderer so we will pick decoder // be using SDLRenderer/DrmRenderer so we will pick decoder
// capabilities based on the decoder name. // capabilities based on the decoder name.
for (int i = 0; i < SDL_arraysize(k_NonHwaccelCodecInfo); i++) { for (const codec_info_t& codecInfo : k_NonHwaccelH264Codecs) {
if (strcmp(m_VideoDecoderCtx->codec->name, k_NonHwaccelCodecInfo[i].codec) == 0) { if (strcmp(m_VideoDecoderCtx->codec->name, codecInfo.codec) == 0) {
capabilities = k_NonHwaccelCodecInfo[i].capabilities; capabilities = codecInfo.capabilities;
SDL_LogInfo(SDL_LOG_CATEGORY_APPLICATION, SDL_LogInfo(SDL_LOG_CATEGORY_APPLICATION,
"Found capabilities for non-hwaccel decoder: %s -> %d", "Found capabilities for non-hwaccel H.264 decoder: %s -> %d",
m_VideoDecoderCtx->codec->name,
capabilities);
break;
}
}
for (const codec_info_t& codecInfo : k_NonHwaccelHEVCCodecs) {
if (strcmp(m_VideoDecoderCtx->codec->name, codecInfo.codec) == 0) {
capabilities = codecInfo.capabilities;
SDL_LogInfo(SDL_LOG_CATEGORY_APPLICATION,
"Found capabilities for non-hwaccel HEVC decoder: %s -> %d",
m_VideoDecoderCtx->codec->name, m_VideoDecoderCtx->codec->name,
capabilities); capabilities);
break; break;
@ -1013,32 +1036,15 @@ bool FFmpegVideoDecoder::initialize(PDECODER_PARAMETERS params)
// Continue with special non-hwaccel hardware decoders // Continue with special non-hwaccel hardware decoders
if (params->videoFormat & VIDEO_FORMAT_MASK_H264) { if (params->videoFormat & VIDEO_FORMAT_MASK_H264) {
QList<const char *> knownAvcCodecs = { for (const codec_info_t& codecInfo : k_NonHwaccelH264Codecs) {
#ifdef HAVE_MMAL if (tryInitializeRendererForDecoderByName(codecInfo.codec, params)) {
"h264_mmal",
#endif
"h264_rkmpp",
"h264_nvv4l2",
"h264_nvmpi",
#ifndef HAVE_MMAL
// Only enable V4L2M2M by default on non-MMAL (RPi) builds. The performance
// of the V4L2M2M wrapper around MMAL is not enough for 1080p 60 FPS, so we
// would rather show the missing hardware acceleration warning when the user
// is in Full KMS mode rather than try to use a poorly performing hwaccel.
// See discussion on https://github.com/jc-kynesim/rpi-ffmpeg/pull/25
"h264_v4l2m2m",
#endif
};
for (const char* codec : knownAvcCodecs) {
if (tryInitializeRendererForDecoderByName(codec, params)) {
return true; return true;
} }
} }
} }
else { else {
QList<const char *> knownHevcCodecs = { "hevc_rkmpp", "hevc_nvv4l2", "hevc_nvmpi", "hevc_v4l2m2m" }; for (const codec_info_t& codecInfo : k_NonHwaccelHEVCCodecs) {
for (const char* codec : knownHevcCodecs) { if (tryInitializeRendererForDecoderByName(codecInfo.codec, params)) {
if (tryInitializeRendererForDecoderByName(codec, params)) {
return true; return true;
} }
} }