在编译cuda有关的代码的时候,遇到大量类似的问题:
error: identifier "__builtin_ia32_rndscalesd_round" is undefined
先说我的解决办法
遇到的问题跟
这个小哥的issue
是一样的,根据
这个小哥的做法
,他注释掉了
#include <x86intrin.h>
,这个头文件是跟指令有关,可以参考
这篇文章
。
我的代码没有
#include <x86intrin.h>
,但是在报错的cpp文件中有include类似的与指令有关的头文件
#include <immintrin.h>
,注释掉之后,这个error就消失了。
实际上解决这个问题的过程相当曲折
-
一开始查资料后怀疑是ANSI的问题(
什么是ANSI?
),例如
这里的讨论
,但是在检查自己的代码发现CMakelist中已经有
set( CMAKE_CXX_STANDARD 14 )
,相当于设置了
-std=c++14
,根据
这个博主
的说法,设好后相当于默认定义了
__STRICT_ANSI__
,所以大概率不是这个问题了。 -
然后怀疑是cuda不同版本都对gcc有不同版本的要求,如
这里
提到的cuda11.4+ubuntu20.04对应的default gcc版本是7.5.0(最开始就是在7.5.0上编译运行的,没有任何问题),cuda官网也有这个表(只找到
cuda11.7
的表)。不过看到有一栏GCC[2,3],怀疑这个应该是max_gcc supported。
-
另外也有一些人遇到这个问题,直接把gcc版本降低,不过我这里就是想支持更高版本,所以降低版本不能解决问题(实际上在gcc7.5和gcc9.3确实编译没有问题):
例如这个人:
This problem directly led me to give up gcc-9.4.0 The main reason is . Because of these builtin We can’t define functions ourselves , You can’t find them outside the compiler , Plus I don’t know anything about compilers , So I didn’t dare to modify the source code , Finally, it was directly replaced by gcc-8.4.0 To compile successfully .
How to replace it gcc For the compiled version, please refer to here ,
Linux How to install specific gcc edition _ High precision computer vision blog -CSDN Blog
-
另外还有这个人也遇到的
类似的问题
,不过他的解决办法没看懂…
结束语
实际上我的解决办法简单粗暴,但是个人认为并没有从根本上解决此问题,希望有相关经验的人一起分享讨论~