FFmpeg在 Windows 环境编译(64位)支持h264,h265,和Intel QSV,Nvidia Cuda,AMD amf 硬件加速

本文主要是介绍FFmpeg在 Windows 环境编译(64位)支持h264,h265,和Intel QSV,Nvidia Cuda,AMD amf 硬件加速,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

目录

前言

一. 源码包下载

1. FFmpeg源码下载

2. MSYS2安装

  2.1 执行下面命令配置环境

  2.2 安装完成后将MSYS2安装路径下的mingw64/bin配置到windows环境变量中

  2.3 安装其他工具( 默认全部安装 ):

3. 安装CMake工具

  3.1 将CMake加入环境变量

4. 下载x264,x265

  4.1 x264源码下载:

  4.2 x265源码下载(直接git):

二. 开始编译

1. 编译x264

2. 编译x265

3. 编译FFmpeg

三. 功能验证

1. x264验证

2. x265验证

3. FFmpeg验证

四. FFmpeg支持 Intel,Nvidia,AMD 硬件加速

1. 支持Intel QSV硬件加速

2. 支持 Nvidia nvenc,cuda,cuvid 硬件加速

3. AMD amf 硬件加速支持

4. 完整的 build-ffmpeg.sh 脚本文件代码

五. 硬件加速功能测试

1. Intel QSV 硬件加速编解码测试

2. Nvidia 硬件加速测试

3. AMD 硬件加速测试

六. 可能存在的问题

1. 可能缺少某些依赖库

2. 如何查看我们编译好的 FFmpeg 依赖哪些库?

3. Nvidia 部分依赖库 libnpp 支持

4. Error: operand type mismatch for `shr'

参考博客链接


前言

        最近完成了 FFmpeg 在 Windows 环境下的编译工作,在查询了大量的官方文档和牛人博客,并且踩了N多坑后,总结出了比较完善的编译方式。

一. 源码包下载

1. FFmpeg源码下载

下载地址: FFmpeg

2. MSYS2安装

下载地址:MSYS2

  2.1 执行下面命令配置环境

pacman -Syu

输入y选择全部更新,更新完成后再次执行

pacman -Syu

安装基础工具(默认全部安装):

pacman -S base-devel

安装编译工具(默认全部安装):

pacman -S mingw-w64-x86_64-toolchain

如果是要编译32位的FFmpeg,则需要在MSYS的MinGW32里运行如下命令:

pacman -S mingw-w64-i686-toolchain

  2.2 安装完成后将MSYS2安装路径下的mingw64/bin配置到windows环境变量中

  2.3 安装其他工具( 默认全部安装 ):

pacman -S yasm
pacman -S nasm
pacman -S make

3. 安装CMake工具

CMake下载地址:Download | CMake

  3.1 将CMake加入环境变量

安装完成之后我们在 msys2 中是找不到 cmake 命令的,这里我们把 windows path 添加到 msys2 中。在 windows 环境变量中新建一个名为 MSYS2_PATH_TYPE 的环境变量,值改为 inherit,然后重启msys2就可以在msys2中使用安装的cmake了。

4. 下载x264,x265

  4.1 x264源码下载

  下载地址:x264

  4.2 x265源码下载(直接git):

  下载地址:

git clone https://bitbucket.org/multicoreware/x265_git.git

二. 开始编译

1. 编译x264

(1)把下载的x264源码包解压到msys64的home目录下,即 c/msys64/home/xxx (这里的xxx是用户名)

(2)进入x264源码目录中新建脚本 build-x264.sh ,脚本内容如下:

#!/bin/sh
basepath=$(cd `dirname $0`;pwd)echo ${basepath}
cd ${basepath}pwd
./configure --prefix=${basepath}/x264_install --enable-static --enable-shared \
--extra-ldflags=-Wl,--output-def=libx264.def
make -j8
make install

在msys2中执行脚本文件:

sh build-x264.sh

等待编译完成后,在x264_install下会生成动态库,头文件和静态库

bin 中存放的是动态库

include 中存放的是头文件

lib 中存放的是静态库,给后面 FFmpeg 链接使用

假如我们需要使用动态库的话,还缺少一个 .lib 文件

.lib 文件可以由 .dll 直接生成,也可以由 .def 生成,这里我们可以用 .def 文件生成,在x264源码目录下有生成 libx264.def 文件

把 libx264.def 拷贝到和 libx264-164.dll 同一级目录下

然后打开VS命令行工具:

进入 VC\Tools\MSVC\14.29.30133(这里根据实际情况来,按tab可自动填充)\bin\Hostx64\x64

执行命令:

lib.exe /out:输出.lib的路径加文件名 /machine:x64 /def:输入def文件的路径和文件名

如:

lib.exe /out:C:\msys64\home\Administrator\x264-master\x264_install\bin\libx264-164.lib /machine:x64 /def:C:\msys64\home\Administrator\x264-master\x264_install\bin\libx264.def

执行成功后,如下图所示:

执行完成后在 x264_install/bin 目录中就会生成 .lib 文件

2. 编译x265

 (1)在msys中进入 x265_git/build/msys 下,执行下面命令生成 makefile:

cd x265_git/build/msys

sh make-Makefiles.sh

在弹出的窗口中先修改安装路径,然后点击configure,再点 generate 生成 makefile,最后关闭窗口

(2)开始编译

make -j8

(3)安装

make install

编译和安装完成后,在 x265_git/x265_install/bin 目录中就可以看到生成的文件了

 

3. 编译FFmpeg

(1)把下载好的FFmpeg源码包解压到msys2中的 home/xxx 目录下

(2)进入FFmpeg源码包,新建脚本 build-ffmpeg.sh ,脚本内容如下:

#!/bin/sh
basepath=$(cd `dirname $0`;pwd)echo ${basepath}
cd ${basepath}#添加x264 x265的pkg路径
x264_pkg_path=/home/Administrator/x264-master/x264_install/lib/pkgconfig
x265_pkg_path=/home/Administrator/x265_git/x265_install/lib/pkgconfig
export PKG_CONFIG_PATH=$x264_pkg_path:$x265_pkg_path:$PKG_CONFIG_PATH./configure --prefix=${basepath}/ffmpeg_5.1.3_install --disable-static --enable-shared \
--enable-libx264 --enable-libx265 --enable-gpl
make -j8
make install

(3)然后在msys2中进入 FFmpeg 源码包目录下执行脚本:

sh build-ffmpeg.sh

等待编译完成后,就可以在 ffmpeg_5.1.3_install 中看到生成了以下目录:

三. 功能验证

1. x264验证

进入 x264-master/x264_install/bin 目录下,执行下面命令,如果能够输出版本信息,说明正常

./x264.exe --version

2. x265验证

进入 x265_git/x265_install/bin 目录下,执行下面命令,如果能够得到版本信息,说明正常

./x265.exe --version

3. FFmpeg验证

(1)需要把x264和x265生成的动态库bin目录中的文件全部拷贝到 FFmpeg 生成目录的bin中。(和ffmpeg.exe同一级目录,因为编译好的 FFmpeg 依赖于它们的 dll 库)

(2)msys2中进入 ffmpeg_5.1.3_install/bin 目录下,执行以下命令,如果能够输出版本信息,则说明正常

./ffmpeg.exe -version

四. FFmpeg支持 Intel,Nvidia,AMD 硬件加速

1. 支持Intel QSV硬件加速

(1)首先从 github 上下载 mfx_dispatch,通过这个生成 libmfx

mfx_dispatch 下载网址: mfx_dispatch

(2)进入下载好的 mfx_dispatch源码包中,用Notepad++打开Makefile.am文件,将下面四个 *.a 改为 *.la

修改完后记得保存并关闭 Makefile.am 文件

(3)打开msys, 执行以下命令

cd mfx_dispatch

pacman -S automake

然后再 autoupdate

autoupdate

这样就可以下载autoreconf 了

autoreconf --install

然后再执行下面的命令安装一些包:

pacman -S perl
pacman -S libtool
pacman -S pkg-config

接下来重命名 /usr/bin/link.exe , 避免冲突

cd /usr/bin
mv link.exe link.bak

如果提示如下信息,则不用理会,继续执行后面的操作

which cl link yasm cpp

执行上面命令后如果没有找到cl,link,则代表是VS

然后重新进入 mfx_dispatch 目录

执行以下命令生成 libmfx ,--prefix 是指定 libmfx 生成在哪个目录,--host 是指定用什么编译器

autoreconf -i
./configure --prefix=/c/msys64/home/Administrator/libmfx --host=x86_64-w64-mingw32
make -j
make install

PS:如果要编译32位的FFmpeg,则应该修改 --host 的值

--host=i686-w64-mingw32

安装完毕后,你就能看到生成的 libmfx 目录了

(4)接下来我们进入 FFmpeg 目录,将 build-ffmpeg.sh 脚本文件修改为支持 libmfx

然后在msys中进入 FFmpeg 源码包下执行脚本文件 build-ffmpeg.sh

等待编译完成后,我们在msys中进入 ffmpeg_5.1.3_install/bin 目录,执行以下命令就可以看到FFmpeg已经支持 Intel QSV 硬件加速了

./ffmpeg.exe -hwaccels

2. 支持 Nvidia nvenc,cuda,cuvid 硬件加速

(1)集成Nvidia硬件加速需要先下载 nv-codec-headers 和 CUDA Toolkit

        nv-codec-headers 历史版本下载地址:https://github.com/FFmpeg/nv-codec-headers/releases

        CUDA Toolkit 历史版本下载地址:CUDA Toolkit Archive | NVIDIA Developer

        本文选择的 nv-codec-headers 版本是:9.1.23.3

        本文选择的 CUDA Toolkit 版本是:10.1-update2

(2)下载完CUDA Toolkit后进行安装,安装选项选择自定义

安装完毕后,在CMD窗口输入 nvcc -V 显示如下信息则表示安装成功

(3)安装完成后,在 c/msys64/usr/local/include 下新建一个目录 nv_sdk_10.1 用来存放头文件。

把 C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v10.1\include 下面所有的头文件复制到 nv_sdk_10.1 目录

如下:

把 ​​ C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v10.1\lib\x64​​  里面所有的 lib 库全部复制到  c/msys64/​​usr/local/lib/x64 下

如下:

(4)下载好 nv-codec-headers 后,我们在msys中进入 nv-codec-headers ,执行命令

make && make install

如图所示:

执行完上述命令后,我们在 c/msys64/usr/local/include 中可以看到生成的 ffnvcodec 文件夹

(5)接下来我们修改 build-ffmpeg.sh 脚本文件,添加支持 nvenc,cuda和cuvid 的配置

修改完成后,我们在msys中进入 FFmpeg 源码目录,执行脚本文件

 

等待编译完成后,我们进入 ffmpeg_5.1.3_install/bin 目录下,执行命令

./ffmpeg.exe -hwaccels

可以看到 FFmpeg 已经支持 Nvidia 的硬件加速了

3. AMD amf 硬件加速支持

(1)AMF声明文件下载:AMF

下载完成后,在 c/msys64/usr/local/include 目录下新建 AMF文件夹,将下载文件的 AMF/amf/public/include 下的两个文件夹复制到刚才新建的AMF文件夹中,如图所示:

(2)接下来修改 build-ffmpeg.sh 脚本文件,添加支持 amf

修改完成后,在msys中进入 FFmpeg 源码目录,执行脚本

(3)等待编译完成后,可以看到 FFmpeg 已经支持 AMD 的 amf 硬件加速了

4. 完整的 build-ffmpeg.sh 脚本文件代码

#!/bin/sh
basepath=$(cd `dirname $0`;pwd)
echo ${basepath}
cd ${basepath}#添加x264 x265的pkg路径
x264_pkg_path=/home/Administrator/x264-master/x264_install/lib/pkgconfig
x265_pkg_path=/home/Administrator/x265_git/x265_install/lib/pkgconfig
mfx_pkg_path=/home/Administrator/libmfx/lib/pkgconfig
ffnvcodec_pkg_path=/usr/local/lib/pkgconfig
export PKG_CONFIG_PATH=$x264_pkg_path:$x265_pkg_path:$mfx_pkg_path:$ffnvcodec_pkg_path:$PKG_CONFIG_PATH#Intel
#Nvidia
#AMD  
./configure --prefix=${basepath}/ffmpeg_5.1.3_install --disable-static --enable-shared \
--enable-libx264 --enable-libx265 --enable-gpl \
--enable-libmfx --enable-encoder=h264_qsv --enable-decoder=h264_qsv \
--enable-nonfree --enable-ffnvcodec --enable-libnpp --arch=x86_64 --enable-postproc --enable-nvenc --enable-cuda --enable-cuvid --enable-encoder=h264_nvenc --enable-decoder=h264_cuvid \
--enable-amf \
--extra-cflags=-I/c/msys64/home/Administrator/libmfx/include --extra-ldflags=-L/c/msys64/home/Administrator/libmfx/lib \
--extra-cflags=-I/usr/local/include/ffnvcodec \
--extra-cflags=-I/usr/local/include/nv_sdk_10.1 --extra-ldflags=-L/usr/local/lib/x64 \
--extra-cflags=-I/usr/local/include --extra-ldflags=-L/usr/local/lib
make -j8
make install

五. 硬件加速功能测试

1. Intel QSV 硬件加速编解码测试

(1)准备一个命名为 input.mp4 的视频放到 ffmpeg_5.1.3_install/bin 目录下,如图:

(2)在msys中进入 ffmpeg_5.1.3_install/bin 目录下运行以下命令,可以看到在同目录下生成了相应的名为 h264_qsv_output.mp4 的视频

./ffmpeg.exe -i input.mp4 -b:v 2000k -c:v h264_qsv -c:a copy h264_qsv_output.mp4

若视频能正常打开,则说明Intel QSV硬件加速编解码成功

2. Nvidia 硬件加速测试

同理,运行以下命令,若生成的视频能正常打开,则说明编解码成功

./ffmpeg.exe -i input.mp4 -b:v 2000k -c:v h264_nvenc -c:a copy h264_nvenc_output.mp4

3. AMD 硬件加速测试

同理,运行以下命令,若生成的视频能正常打开,则说明编解码成功

./ffmpeg.exe -i input.mp4 -b:v 2000k -c:v h264_amf -c:a copy h264_amf_output.mp4

PS:特别注意!!!以上命令需要在各自硬件支持或驱动支持的情况下才能正常生成视频!

六. 可能存在的问题

1. 可能缺少某些依赖库

我们编译好的 FFmpeg 可能依赖某些dll库,如果我们打包的时候没有把这些dll库放到 ffmpeg_5.1.3_install/bin 目录下,在其他环境下运行 ffmpeg.exe 时可能会报类似于下面的错误:

一种解决办法是可以在FFmpeg源码的 configure 文件中看哪些库可以在脚本文件中disable,不过有三个基本的库是在 configure 里没有禁掉选项的,这时我们就需要把这几个库复制到ffmpeg_5.1.3_install/bin 目录下。

这几个dll库都可以在 C:\msys64\mingw64\bin 里面找到。

2. 如何查看我们编译好的 FFmpeg 依赖哪些库?

编译好的FFmpeg有两个最重要的dll库, avcodec-59.dll 和 avutil-57.dll  而这两个库可以在 dumpbin 里面查看它们依赖哪些库。

我们可以在VS命令行工具里面运行以下 dumpbin 命令查看依赖库

先 cd C:\msys64\home\Administrator\ffmpeg-5.1.3\ffmpeg_5.1.3_install\bin

然后执行以下命令:

dumpbin -imports avcodec-59.dll

查看avcodec-59.dll 依赖于哪些库后, 再查看一下 avutil-57.dll 依赖哪些库。把除了系统库之外一些能找到的 dll 库放到 ffmpeg_5.1.3_install/bin 中即可。

3. Nvidia 部分依赖库 libnpp 支持

如果我们编译脚本时,加入了 --enable-libnpp 选项,则可能还需要 libnpp 这几个库

而上面的这几个库在 C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v10.1\bin 下,我们把它们复制到 ffmpeg_5.1.3_install\bin 中就好了

总结就是,缺少哪些库,我们就把这些库放到 ffmpeg_5.1.3_install/bin 目录下,或者看看能不能直接在编译的时候就 disable

4. Error: operand type mismatch for `shr'

      在使用 13.2.0 或以上版本的gcc编译 FFmpeg 时可能会出现这个问题,这是汇编代码中存在类型不匹配的错误导致的,如下:

C:\msys64\tmp\ccUxvBjQ.s: Assembler messages:
C:\msys64\tmp\ccUxvBjQ.s:345: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:410: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:470: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:645: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:713: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:781: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:866: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:951: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:1036: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:1133: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:1405: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:1514: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:1638: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:1797: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:2137: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:2242: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:2368: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:2553: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:2703: Error: operand type mismatch for `shr'
make: *** [ffbuild/common.mak:60: libavformat/adtsenc.o] Error 1
make 编译过程中的出现上面错误

我这里之前使用13.1.0 版本的gcc时没有这个问题,更新到13.2.0后编译就报这个错误了,但是msys2的gcc版本又不能回退,所以我们现在编译FFmpeg时需要修改FFmpeg的源码:

首先,找到FFmpeg源码中的mathops.h文件,具体路径如下:

我这里是在  ffmpeg-5.0.3/libavcodec/x86/mathops.h

然后修改mathops.h中以下几个函数的定义(将 ci 改为 c):

#define MULL MULL
static av_always_inline av_const int MULL(int a, int b, unsigned shift)
{int rt, dummy;__asm__ ("imull %3               \n\t""shrdl %4, %%edx, %%eax \n\t":"=a"(rt), "=d"(dummy)//:"a"(a), "rm"(b), "ci"((uint8_t)shift):"a"(a), "rm"(b), "c"((uint8_t)shift));return rt;
}
#define NEG_SSR32 NEG_SSR32
static inline  int32_t NEG_SSR32( int32_t a, int8_t s){__asm__ ("sarl %1, %0\n\t": "+r" (a)//: "ci" ((uint8_t)(-s)): "c" ((uint8_t)(-s)));return a;
}
#define NEG_USR32 NEG_USR32
static inline uint32_t NEG_USR32(uint32_t a, int8_t s){__asm__ ("shrl %1, %0\n\t": "+r" (a)//: "ci" ((uint8_t)(-s)): "c" ((uint8_t)(-s)));return a;
}

修改完成后保存并关闭文件,然后重新编译FFmpeg应该就能解决上述问题了

参考博客链接

1. ffmpeg5.0+h264+h265 windows下编译ffmpeg-5.0.1支持x265编解码_老吕丶的博客-CSDN博客​​​​​

2. windows下编译FFMPEG开启硬件加速(INTEL,NVIDIA,AMD)selivert的博客-CSDN博客

3. FFmpeg引入NVIDIA硬件编解码扩展_mb628cd5266c9eb的技术博客_51CTO博客

4. 音视频开源基础学习 – 编译ffmpeg(音视频开发进阶) | 半码博客

5. ffmpeg编译 Error: operand type mismatch for `shr‘

这篇关于FFmpeg在 Windows 环境编译(64位)支持h264,h265,和Intel QSV,Nvidia Cuda,AMD amf 硬件加速的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/719036

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

Windows Server服务器上配置FileZilla后,FTP连接不上?

《WindowsServer服务器上配置FileZilla后,FTP连接不上?》WindowsServer服务器上配置FileZilla后,FTP连接错误和操作超时的问题,应该如何解决?首先,通过... 目录在Windohttp://www.chinasem.cnws防火墙开启的情况下,遇到的错误如下:无法与

Centos环境下Tomcat虚拟主机配置详细教程

《Centos环境下Tomcat虚拟主机配置详细教程》这篇文章主要讲的是在CentOS系统上,如何一步步配置Tomcat的虚拟主机,内容很简单,从目录准备到配置文件修改,再到重启和测试,手把手带你搞定... 目录1. 准备虚拟主机的目录和内容创建目录添加测试文件2. 修改 Tomcat 的 server.X

Python解析器安装指南分享(Mac/Windows/Linux)

《Python解析器安装指南分享(Mac/Windows/Linux)》:本文主要介绍Python解析器安装指南(Mac/Windows/Linux),具有很好的参考价值,希望对大家有所帮助,如有... 目NMNkN录1js. 安装包下载1.1 python 下载官网2.核心安装方式3. MACOS 系统安

VSCode配置Anaconda Python环境的实现

《VSCode配置AnacondaPython环境的实现》VisualStudioCode中可以使用Anaconda环境进行Python开发,本文主要介绍了VSCode配置AnacondaPytho... 目录前言一、安装 Visual Studio Code 和 Anaconda二、创建或激活 conda

pytorch+torchvision+python版本对应及环境安装

《pytorch+torchvision+python版本对应及环境安装》本文主要介绍了pytorch+torchvision+python版本对应及环境安装,安装过程中需要注意Numpy版本的降级,... 目录一、版本对应二、安装命令(pip)1. 版本2. 安装全过程3. 命令相关解释参考文章一、版本对

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想

Windows命令之tasklist命令用法详解(Windows查看进程)

《Windows命令之tasklist命令用法详解(Windows查看进程)》tasklist命令显示本地计算机或远程计算机上当前正在运行的进程列表,命令结合筛选器一起使用,可以按照我们的需求进行过滤... 目录命令帮助1、基本使用2、执行原理2.1、tasklist命令无法使用3、筛选器3.1、根据PID