草庐IT

gcc-plugin

全部标签

c++ - 为什么简单的内联汇编函数不能在 GCC 中正常工作?

我有一个简单的内联汇编函数,它在MSVC中运行良好,但由于某种原因拒绝在AppleGCC4.2.1下运行(i386arch,强制32位模式)。幸运的是,更复杂的汇编函数可以正常工作,但是我不明白为什么这个函数不起作用...不幸的是,我无法调试它-从外观上看,XCode中没有寄存器窗口4.0.2(它是3.2版本)。我很肯定这个问题与英特尔风格的汇编无关。intConvert(doublevalue){_asm{fldvaluepusheaxfistpdwordptr[esp]popeax}//Thereturnedvalueisinsane} 最佳答案

c++ - GCC 汇编代码生成错误和解决方法

GCC4.5.2(在Ubuntu11.10x64上,但编译为32位)生成无效的汇编代码,我很好奇是否可以在不更改代码的情况下修复,只需应用选项或类似的东西。请注意,优化已经是-O0。我有两个功能:inlinelongClass::Get(){longv=*(long*)(m_p);m_p+=4;returnv;}inlinevoidClass::Command(){m_p+=Get();}GCC4.5.2生成此汇编代码:9840m_p+=Get();f689eff5:mov0x8(%ebp),%eaxf689eff8:mov0xd4(%eax),%eaxf689effe:mov%eax

c++ - GCC 中 cmath 的 pow() 的正确性

代码[GCC,使用-O2标志编译]intmain(){vector>matrixa(8);intff=5;ints=pow(ff,matrixa.size());intss=pow(double(ff),int(matrixa.size()));vector>comb(s);cout输出5^8=390624390625我想知道为什么s=390624而它应该是390625。如果我在没有-O2标志的情况下编译代码,则s=390625。此外,ss的转换似乎可以解决此问题。这是怎么回事?我的操作系统是Windows7Ultimatex64。不确定GCC版本,它带有Code::Blocks10.

c++ - 程序员的错误或 gcc-5.1.0 的错误?

我尝试使用带有优化标志-O1/-O2/-O3/-Og的gcc-5.1.0编译一个大型软件。它给了我警告-Wmaybe-uninitialized或-Wuninitialized并在运行时失败。调试后我找到了导致它的代码,但我无法理解为什么。我减少了重现失败的代码:#include#includetemplatestructfoo{templatecharbar(constU&x){//returnid(x)[0];constT&y=id(x);returny[0];}constT&id(constT&elem){returnelem;}};intmain(void){foof;char

c++ - 将 GCC 内联汇编 CMOV 转换为 Visual Studio 汇编器

文章中Linearvs.BinarySearch,有一个使用CMOV指令的二进制搜索的快速实现。我想在VC++中实现它,因为我正在处理的应用程序依赖于二进制搜索的性能。该实现有一些GCC内联汇编器,声明如下:staticintbinary_cmov(constint*arr,intn,intkey){intmin=0,max=n;while(min>1;asm("cmpl%3,%2\n\tcmovg%4,%0\n\tcmovle%5,%1":"+r"(min),"+r"(max):"r"(key),"g"(arr[middle]),"g"(middle+1),"g"(middle));

c++ - 哪些标志将改善 gcc/clang 编译时间?

gcc或clang的哪些标志可以缩短编译时间?我需要启用调试功能,但可以自由禁用任何其他功能,如果它们会导致更快的编译。我知道还有很多其他方法可以缩短编译时间,但我只对这个领域感兴趣。 最佳答案 通过消除编译器完成的大部分工作(通常是优化),可以找到编译时间的最大yield。因此,不要启用优化(-O)标志。 关于c++-哪些标志将改善gcc/clang编译时间?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow

c++ - 帮助 GCC 进行自动矢量化

我有一个需要优化的着色器(有很多vector操作),我正在试验SSE指令以便更好地理解这个问题。我有一些非常简单的示例代码。通过USE_SSE定义,它使用显式SSE内在函数;没有它,我希望GCC会为我完成这项工作。自动矢量化感觉有点挑剔,但我希望它能帮我省点事。编译器和平台是:gcc4.7.1(tdm64),目标x86_64-w64-mingw32和IvyBridge上的Windows7。测试代码如下:/*IncludealltheSIMDintrinsics.*/#ifdefUSE_SSE#include#endif#include#ifdefined(__GNUG__)||defi

c++ - 使用自定义构建的 gcc 时程序链接失败

我正在运行一个fedora21发行版,其中默认的gcc是4.9。我在/usr/local/gcc48中有一个自定义构建的gcc/g++4.8(例如,cuda需要gcc=现在,我获得了使用vtk库和其他库的源代码。如果我使用默认的gcc4.9,cmake和make可以正常工作。但是,当使用gcc48时,我得到:/usr/lib64/vtk/libvtkCommonDataModel.so.1:référenceindéfinievers«std::__throw_out_of_range_fmt(charconst*,...)@GLIBCXX_3.4.20»/lib64/libicuuc

c++ - 如何获得 4.2 版的 g++/gcc for windows?

如何获得适用于Windows的g++/gcc的最新版本,即4.2+?Mingw的标准g++是3.4.5,它有3年历史,于2005年11月发布。Mingw有一个4.2版本,但这只是在Alpha阶段。我找不到适用于Windows的g++的稳定最新版本,我肯定遗漏了一些东西。 最佳答案 TwilightDragonMedia跟踪并定期发布可用于MinGW环境的GCC版本。当前版本基于GCC4.3.2。包可以下载here.在对4.3.2-TDM1版本进行了两个多月的广泛测试后,我开始在生产中使用它。我遇到的唯一问题是C++中的跨DLL异常,

c++ - GCC C++11 条件变量等待内部机制

我正在寻找我们遇到的一个错误,一些困惑的线程/条件变量类被更新为使用C++11线程。在搜寻过程中,我在GCC代码库中遇到了以下内容:templatevoidwait(_Lock&__lock){unique_lock__my_lock(_M_mutex);_Unlock__unlock(__lock);//_M_mutexmustbeunlockedbeforere-locking__locksomove//ownershipof_M_mutexlocktoanobjectwithshorterlifetime.unique_lock__my_lock2(std::move(__my_