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

相关文章

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

高并发环境中保持幂等性

在高并发环境中保持幂等性是一项重要的挑战。幂等性指的是无论操作执行多少次,其效果都是相同的。确保操作的幂等性可以避免重复执行带来的副作用。以下是一些保持幂等性的常用方法: 唯一标识符: 请求唯一标识:在每次请求中引入唯一标识符(如 UUID 或者生成的唯一 ID),在处理请求时,系统可以检查这个标识符是否已经处理过,如果是,则忽略重复请求。幂等键(Idempotency Key):客户端在每次

maven 编译构建可以执行的jar包

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」👈,「stormsha的知识库」👈持续学习,不断总结,共同进步,为了踏实,做好当下事儿~ 专栏导航 Python系列: Python面试题合集,剑指大厂Git系列: Git操作技巧GO

pico2 开发环境搭建-基于ubuntu

pico2 开发环境搭建-基于ubuntu 安装编译工具链下载sdk 和example编译example 安装编译工具链 sudo apt install cmake gcc-arm-none-eabi libnewlib-arm-none-eabi libstdc++-arm-none-eabi-newlib 注意cmake的版本,需要在3.17 以上 下载sdk 和ex

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

跨系统环境下LabVIEW程序稳定运行

在LabVIEW开发中,不同电脑的配置和操作系统(如Win11与Win7)可能对程序的稳定运行产生影响。为了确保程序在不同平台上都能正常且稳定运行,需要从兼容性、驱动、以及性能优化等多个方面入手。本文将详细介绍如何在不同系统环境下,使LabVIEW开发的程序保持稳定运行的有效策略。 LabVIEW版本兼容性 LabVIEW各版本对不同操作系统的支持存在差异。因此,在开发程序时,尽量使用

Go Playground 在线编程环境

For all examples in this and the next chapter, we will use Go Playground. Go Playground represents a web service that can run programs written in Go. It can be opened in a web browser using the follow

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom