@@ -5819,14 +5819,17 @@ elif enabled mips; then
enabled mipsfpu && check_inline_asm_flags mipsfpu '"cvt.d.l $f0, $f2"' '-mhard-float'
enabled mipsfpu && (enabled mips32r5 || enabled mips32r6 || enabled mips64r6) && check_inline_asm_flags mipsfpu '"cvt.d.l $f0, $f1"' '-mfp64'
- enabled mipsfpu && enabled msa && check_inline_asm_flags msa '"addvi.b $w0, $w1, 1"' '-mmsa' && check_headers msa.h || disable msa
+ enabled mipsfpu && enabled msa && check_inline_asm msa '"addvi.b $w0, $w1, 1"' '-mmsa' && check_headers msa.h || disable msa
enabled mipsdsp && check_inline_asm_flags mipsdsp '"addu.qb $t0, $t1, $t2"' '-mdsp'
enabled mipsdspr2 && check_inline_asm_flags mipsdspr2 '"absq_s.qb $t0, $t1"' '-mdspr2'
- enabled msa && enabled msa2 && check_inline_asm_flags msa2 '"nxbits.any.b $w0, $w0"' '-mmsa2' && check_headers msa2.h || disable msa2
+ enabled msa && enabled msa2 && check_inline_asm msa2 '"nxbits.any.b $w0, $w0"' '-mmsa2' && check_headers msa2.h || disable msa2
if enabled bigendian && enabled msa; then
disable msa
+ disable msa2
fi
+ enabled msa && append MSAFLAGS "-mmsa"
+ enabled msa2 && append MSAFLAGS "-mmsa2"
elif enabled parisc; then
@@ -7362,6 +7365,7 @@ OBJCFLAGS=$OBJCFLAGS
ASFLAGS=$ASFLAGS
NVCCFLAGS=$nvccflags
MMIFLAGS=$MMIFLAGS
+MSAFLAGS=$MSAFLAGS
AS_C=$AS_C
AS_O=$AS_O
OBJCC_C=$OBJCC_C
@@ -60,10 +60,14 @@ COMPILE_X86ASM = $(call COMPILE,X86ASM)
COMPILE_HOSTC = $(call COMPILE,HOSTCC)
COMPILE_NVCC = $(call COMPILE,NVCC)
COMPILE_MMI = $(call COMPILE_WITH_FLAG,CC,MMIFLAGS)
+COMPILE_MSA = $(call COMPILE_WITH_FLAG,CC,MSAFLAGS)
%_mmi.o: %_mmi.c
$(COMPILE_MMI)
+%_msa.o: %_msa.c
+ $(COMPILE_MSA)
+
%.o: %.c
$(COMPILE_C)
@@ -52,6 +52,7 @@ void ff_blockdsp_init_mips(BlockDSPContext *c)
blockdsp_init_mmi(c);
#endif /* HAVE_MMI */
#if HAVE_MSA
- blockdsp_init_msa(c);
+ if (MIPS_MSA(cpu_flags))
+ blockdsp_init_msa(c);
#endif // #if HAVE_MSA
}
@@ -19,6 +19,7 @@
*/
#include "h263dsp_mips.h"
+#include "libavutil/mips/cpu.h"
#if HAVE_MSA
static av_cold void h263dsp_init_msa(H263DSPContext *c)
@@ -30,7 +31,9 @@ static av_cold void h263dsp_init_msa(H263DSPContext *c)
av_cold void ff_h263dsp_init_mips(H263DSPContext *c)
{
+ int cpu_flags = av_get_cpu_flags();
#if HAVE_MSA
- h263dsp_init_msa(c);
+ if (MIPS_MSA(cpu_flags))
+ h263dsp_init_msa(c);
#endif // #if HAVE_MSA
}
@@ -61,6 +61,7 @@ av_cold void ff_h264chroma_init_mips(H264ChromaContext *c, int bit_depth)
h264chroma_init_mmi(c, bit_depth);
#endif /* HAVE_MMI */
#if HAVE_MSA
- h264chroma_init_msa(c, bit_depth);
+ if (MIPS_MSA(cpu_flags))
+ h264chroma_init_msa(c, bit_depth);
#endif // #if HAVE_MSA
}
@@ -145,6 +145,7 @@ av_cold void ff_h264dsp_init_mips(H264DSPContext *c, const int bit_depth,
h264dsp_init_mmi(c, bit_depth, chroma_format_idc);
#endif /* HAVE_MMI */
#if HAVE_MSA
- h264dsp_init_msa(c, bit_depth, chroma_format_idc);
+ if (MIPS_MSA(cpu_flags))
+ h264dsp_init_msa(c, bit_depth, chroma_format_idc);
#endif // #if HAVE_MSA
}
@@ -150,6 +150,7 @@ av_cold void ff_h264_pred_init_mips(H264PredContext *h, int codec_id,
h264_pred_init_mmi(h, codec_id, bit_depth, chroma_format_idc);
#endif /* HAVE_MMI */
#if HAVE_MSA
- h264_pred_init_msa(h, codec_id, bit_depth, chroma_format_idc);
+ if (MIPS_MSA(cpu_flags))
+ h264_pred_init_msa(h, codec_id, bit_depth, chroma_format_idc);
#endif // #if HAVE_MSA
}
@@ -247,6 +247,7 @@ av_cold void ff_h264qpel_init_mips(H264QpelContext *c, int bit_depth)
h264qpel_init_mmi(c, bit_depth);
#endif /* HAVE_MMI */
#if HAVE_MSA
- h264qpel_init_msa(c, bit_depth);
+ if (MIPS_MSA(cpu_flags))
+ h264qpel_init_msa(c, bit_depth);
#endif // #if HAVE_MSA
}
@@ -527,6 +527,7 @@ void ff_hevc_dsp_init_mips(HEVCDSPContext *c, const int bit_depth)
hevc_dsp_init_mmi(c, bit_depth);
#endif // #if HAVE_MMI
#if HAVE_MSA
- hevc_dsp_init_msa(c, bit_depth);
+ if (MIPS_MSA(cpu_flags))
+ hevc_dsp_init_msa(c, bit_depth);
#endif // #if HAVE_MSA
}
@@ -21,6 +21,7 @@
#include "config.h"
#include "libavutil/attributes.h"
#include "libavcodec/mips/hevcpred_mips.h"
+#include "libavutil/mips/cpu.h"
#if HAVE_MSA
static av_cold void hevc_pred_init_msa(HEVCPredContext *c, const int bit_depth)
@@ -43,7 +44,9 @@ static av_cold void hevc_pred_init_msa(HEVCPredContext *c, const int bit_depth)
void ff_hevc_pred_init_mips(HEVCPredContext *c, const int bit_depth)
{
+ int cpu_flags = av_get_cpu_flags();
#if HAVE_MSA
- hevc_pred_init_msa(c, bit_depth);
+ if (MIPS_MSA(cpu_flags))
+ hevc_pred_init_msa(c, bit_depth);
#endif // #if HAVE_MSA
}
@@ -120,6 +120,7 @@ void ff_hpeldsp_init_mips(HpelDSPContext *c, int flags)
ff_hpeldsp_init_mmi(c, flags);
#endif // #if HAVE_MMI
#if HAVE_MSA
- ff_hpeldsp_init_msa(c, flags);
+ if (MIPS_MSA(cpu_flags))
+ ff_hpeldsp_init_msa(c, flags);
#endif // #if HAVE_MSA
}
@@ -72,6 +72,7 @@ av_cold void ff_idctdsp_init_mips(IDCTDSPContext *c, AVCodecContext *avctx,
idctdsp_init_mmi(c, avctx, high_bit_depth);
#endif /* HAVE_MMI */
#if HAVE_MSA
- idctdsp_init_msa(c, avctx, high_bit_depth);
+ if (MIPS_MSA(cpu_flags))
+ idctdsp_init_msa(c, avctx, high_bit_depth);
#endif // #if HAVE_MSA
}
@@ -19,6 +19,7 @@
*/
#include "me_cmp_mips.h"
+#include "libavutil/mips/cpu.h"
#if HAVE_MSA
static av_cold void me_cmp_msa(MECmpContext *c, AVCodecContext *avctx)
@@ -50,7 +51,9 @@ static av_cold void me_cmp_msa(MECmpContext *c, AVCodecContext *avctx)
av_cold void ff_me_cmp_init_mips(MECmpContext *c, AVCodecContext *avctx)
{
+ int cpu_flags = av_get_cpu_flags();
#if HAVE_MSA
- me_cmp_msa(c, avctx);
+ if (MIPS_MSA(cpu_flags))
+ me_cmp_msa(c, avctx);
#endif // #if HAVE_MSA
}
@@ -56,6 +56,7 @@ av_cold void ff_mpv_common_init_mips(MpegEncContext *s)
dct_unquantize_init_mmi(s);
#endif /* HAVE_MMI */
#if HAVE_MSA
- dct_unquantize_init_msa(s);
+ if (MIPS_MSA(cpu_flags))
+ dct_unquantize_init_msa(s);
#endif // #if HAVE_MSA
}
@@ -20,6 +20,7 @@
#include "libavcodec/bit_depth_template.c"
#include "h263dsp_mips.h"
+#include "libavutil/mips/cpu.h"
#if HAVE_MSA
static av_cold void mpegvideoencdsp_init_msa(MpegvideoEncDSPContext *c,
@@ -34,7 +35,9 @@ static av_cold void mpegvideoencdsp_init_msa(MpegvideoEncDSPContext *c,
av_cold void ff_mpegvideoencdsp_init_mips(MpegvideoEncDSPContext *c,
AVCodecContext *avctx)
{
+ int cpu_flags = av_get_cpu_flags();
#if HAVE_MSA
- mpegvideoencdsp_init_msa(c, avctx);
+ if (MIPS_MSA(cpu_flags))
+ mpegvideoencdsp_init_msa(c, avctx);
#endif // #if HAVE_MSA
}
@@ -67,6 +67,7 @@ void ff_pixblockdsp_init_mips(PixblockDSPContext *c, AVCodecContext *avctx,
pixblockdsp_init_mmi(c, avctx, high_bit_depth);
#endif /* HAVE_MMI */
#if HAVE_MSA
- pixblockdsp_init_msa(c, avctx, high_bit_depth);
+ if (MIPS_MSA(cpu_flags))
+ pixblockdsp_init_msa(c, avctx, high_bit_depth);
#endif // #if HAVE_MSA
}
@@ -19,6 +19,7 @@
*/
#include "qpeldsp_mips.h"
+#include "libavutil/mips/cpu.h"
#if HAVE_MSA
static av_cold void qpeldsp_init_msa(QpelDSPContext *c)
@@ -161,7 +162,9 @@ static av_cold void qpeldsp_init_msa(QpelDSPContext *c)
void ff_qpeldsp_init_mips(QpelDSPContext *c)
{
+ int cpu_flags = av_get_cpu_flags();
#if HAVE_MSA
- qpeldsp_init_msa(c);
+ if (MIPS_MSA(cpu_flags))
+ qpeldsp_init_msa(c);
#endif // #if HAVE_MSA
}
@@ -128,6 +128,7 @@ av_cold void ff_vc1dsp_init_mips(VC1DSPContext *dsp)
vc1dsp_init_mmi(dsp);
#endif /* HAVE_MMI */
#if HAVE_MSA
- vc1dsp_init_msa(dsp);
+ if (MIPS_MSA(cpu_flags))
+ vc1dsp_init_msa(dsp);
#endif /* HAVE_MSA */
}
@@ -22,6 +22,7 @@
#include "libavutil/attributes.h"
#include "libavutil/mips/asmdefs.h"
#include "libavcodec/videodsp.h"
+#include "libavutil/mips/cpu.h"
#if HAVE_MSA
static void prefetch_mips(uint8_t *mem, ptrdiff_t stride, int h)
@@ -45,7 +46,9 @@ static void prefetch_mips(uint8_t *mem, ptrdiff_t stride, int h)
av_cold void ff_videodsp_init_mips(VideoDSPContext *ctx, int bpc)
{
+ int cpu_flags = av_get_cpu_flags();
#if HAVE_MSA
- ctx->prefetch = prefetch_mips;
+ if (MIPS_MSA(cpu_flags))
+ ctx->prefetch = prefetch_mips;
#endif // #if HAVE_MSA
}
@@ -58,6 +58,7 @@ av_cold void ff_vp3dsp_init_mips(VP3DSPContext *c, int flags)
vp3dsp_init_mmi(c, flags);
#endif /* HAVE_MMI */
#if HAVE_MSA
- vp3dsp_init_msa(c, flags);
+ if (MIPS_MSA(cpu_flags))
+ vp3dsp_init_msa(c, flags);
#endif /* HAVE_MSA */
}
@@ -200,6 +200,7 @@ av_cold void ff_vp8dsp_init_mips(VP8DSPContext *dsp)
vp8dsp_init_mmi(dsp);
#endif /* HAVE_MMI */
#if HAVE_MSA
- vp8dsp_init_msa(dsp);
+ if (MIPS_MSA(cpu_flags))
+ vp8dsp_init_msa(dsp);
#endif // #if HAVE_MSA
}
@@ -216,6 +216,7 @@ av_cold void ff_vp9dsp_init_mips(VP9DSPContext *dsp, int bpp)
vp9dsp_init_mmi(dsp, bpp);
#endif // #if HAVE_MMI
#if HAVE_MSA
- vp9dsp_init_msa(dsp, bpp);
+ if (MIPS_MSA(cpu_flags))
+ vp9dsp_init_msa(dsp, bpp);
#endif // #if HAVE_MSA
}
@@ -173,6 +173,7 @@ int av_parse_cpu_flags(const char *s)
{ "vfp", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_VFP }, .unit = "flags" },
#elif ARCH_MIPS
{ "mmi", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_MMI }, .unit = "flags" },
+ { "msa", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_MSA }, .unit = "flags" },
#endif
{ NULL },
};
@@ -256,6 +257,7 @@ int av_parse_cpu_caps(unsigned *flags, const char *s)
{ "vfp", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_VFP }, .unit = "flags" },
#elif ARCH_MIPS
{ "mmi", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_MMI }, .unit = "flags" },
+ { "msa", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = AV_CPU_FLAG_MSA }, .unit = "flags" },
#endif
{ NULL },
};
@@ -71,6 +71,7 @@
#define AV_CPU_FLAG_VFP_VM (1 << 7) ///< VFPv2 vector mode, deprecated in ARMv7-A and unavailable in various CPUs implementations
#define AV_CPU_FLAG_MMI (1 << 0)
+#define AV_CPU_FLAG_MSA (1 << 1)
#define AV_CPU_FLAG_SETEND (1 <<16)
/**
@@ -36,6 +36,7 @@
static int get_cpu_flags_from_cpuinfo(void)
{
int flags = 0;
+ int model_name_flag = 0;
char buf[1024];
# ifdef __linux__
@@ -45,15 +46,29 @@ static int get_cpu_flags_from_cpuinfo(void)
memset(buf, 0, sizeof(buf));
while (fgets(buf, sizeof(buf), fp)) {
- if (!strncmp(buf, "model name", strlen("model name"))) {
- if (strstr(buf, "Loongson-3")) {
+ if(model_name_flag && !strncmp(buf, "ASEs implemented", strlen("ASEs implemented"))) {
+ if (strstr(buf, "loongson-mmi") || strstr(buf, "loongson-ext")) {
flags |= AV_CPU_FLAG_MMI;
- } else if (strstr(buf, "Loongson-2K") || strstr(buf, "2K1000")) {
+ }
+ if (strstr(buf, "msa")) {
+ flags |= AV_CPU_FLAG_MSA;
+ }
+ } else if (!strncmp(buf, "model name", strlen("model name"))) {
+ /* In case of some kernel havn't add loongson extention in ASEs implemented,
+ * analysis model name is still needed.
+ */
+ if (strstr(buf, "3A4000")) {
+ flags |= AV_CPU_FLAG_MSA | AV_CPU_FLAG_MMI;
+ } else if (strstr(buf, "Loongson-3")) {
flags |= AV_CPU_FLAG_MMI;
+ } else if (strstr(buf, "Loongson-2K") || strstr(buf, "2K1000")) {
+ flags |= AV_CPU_FLAG_MSA | AV_CPU_FLAG_MMI;
}
- break;
+ model_name_flag = 1;
}
+ break;
}
+
fclose(fp);
# endif
return flags;
@@ -27,5 +27,6 @@
#include "libavutil/cpu_internal.h"
#define MIPS_MMI(flags) CPUEXT(flags, MMI)
+#define MIPS_MSA(flags) CPUEXT(flags, MSA)
#endif /* AVUTIL_MIPS_CPU_H */
@@ -76,6 +76,7 @@ static const struct {
{ AV_CPU_FLAG_AVX512, "avx512" },
#elif ARCH_MIPS
{ AV_CPU_FLAG_MMI, "mmi" },
+ { AV_CPU_FLAG_MSA, "msa" },
#endif
{ 0 }
};