草庐IT

llvm-gcc

全部标签

c++ - 如何从 gcc 的预编译头文件中获益最多?

我有一个包含许多目标的C++项目,其中包括大量boost头文件和其他行密集型头文件。大多数目标都包含相同的header。因此,我认为这可能是使用预编译头文件(pch)的理想选择。所以我创建了一个包含最多头文件的头文件并对其进行了预编译。这将编译单元的代码行从350k减少到120k(我将-save-temps标志传递给gcc以进行检查)。我检查它是否与-H参数一起使用,并且pch前面有一个感叹号。预编译头有550MB。不过,编译时间只从23秒减少到20秒。预编译header是否会带来这种小改进?如果不是,我做错了什么?预编译header的编译速度最快的是什么?编辑:这是gcc命令:/us

c++ - 如何根据 LLVM 中 LoadInst 的结果解析 AllocaInst?

从概念上讲,我想做的事情非常简单。我正在使用AllocatechniquedescribedintheKaleidoscopeexample与mem2reg配对以减少手动创建Phi节点的需要。我已经实现了我的自定义语言的几个方面,但是我遇到了以通用方式实现后递增/递减的问题。我的AST节点PostIncrDecrNode包含一个标记来表示++或--和一个表达式AST节点,该节点被代码生成以返回一个llvm::Value*很像Kaleidoscope的例子。我已经注意到我可能需要返回llvm::Value*以外的东西,因为我的语言是非常类型安全的,我需要知道诸如整数类型的符号性之类的东西

c++ - 模板的 typedef 包括 char[][] - 适用于 VS2008 但不适用于 gcc

我有一些正在使用的库代码。它在VisualStudio(2008)下编译和工作,但不是GCC(v4.8.4.)在标题中我们有:externconstcharmenu_styles[MENU_COUNT][MAX_LEN];typedefSysEnumMenuStyleEnum;SysEnum在哪里(在另一个文件中定义):templateclassSysEnumgcc遇到错误:error:‘menu_styles’cannotappearinaconstant-expression我完全同意。(此外,它是constchar*转换为char*)。我希望VS2008只是用constchar*

c++ - 编译器 (gcc) 可以保证 c++ 循环吗?

我必须进行以下AVX操作:__m256perm,func;__m256in=_mm256_load_ps(inPtr+x);__m256acc=_mm256_setzero_ps();perm=_mm256_shuffle_ps(in,in,_MM_SHUFFLE(3,2,1,0));func=_mm256_load_ps(fPtr+0);acc=_mm256_add_ps(acc,_mm256_mul_ps(perm,func));perm=_mm256_shuffle_ps(in,in,_MM_SHUFFLE(2,3,0,1));func=_mm256_load_ps(fPtr+1

c++ - 未使用值警告 : C vs C++ using gcc

是否有可能使gcc像g++那样处理C++的未使用值警告?对于像C中的p&&++*p;这样的指令,有一个警告,但对于C++则没有。设置-wno-unused-value并不是真正的解决方案,因为它还会删除有用的警告(如下面的第2行)。示例:$(gcc--version|head-1;ls-lqwe.*;catqwe.x;echo$sep;gcc-c-O2-Wallqwe.c;echo$sep;g++-c-O2-Wallqwe.cc)2>&1|sed's/^//'gcc(Debian4.9.2-10)4.9.2lrwxrwxrwx1tmltml5Jul2310:12qwe.c->qwe.x

c++ - 为什么 clang/llvm 不对此进行优化?

使用clang3.9编译此代码时:constexprboolis_small(longlongv){returnv它生成的程序集等同于intf(inta){returna;},因为它确定is_small(a)将始终为真,因为a是一个int,这(在我的平台)总是小于0x4000000000000000。当我将is_small更改为:constexprboolis_small(longlongv){returnv>=-0x4000000000000000;}正如预期的那样,发生了完全相同的情况。但是,当我更改is_small以检查这两个条件时:constexprboolis_small(l

c++ - LLVM 在运行时获取声明函数的参数值

我正在编写一个LLVMpass,它需要获取传递给声明函数的值并将其打印出来。请注意声明的函数在LLVMIR中被调用。我已经编写了一个模块传递来迭代程序中的所有指令。获取指令中被调用函数参数的片段如下:for(auto&B:F){for(auto&I:B){if(auto*InvokeI=dyn_cast(&I)){if(InvokeI->getCalledFunction()->getName().str()=="function_name"){errs()getOperand(0))getOperand(1))getOperand(2))但是,如果被调用函数的LLVMIR看起来像这样

c++ - 如何获取LLVM全局变量常量值?

我正在尝试从全局变量中获取浮点值并将其设置为指令的操作数。这是我想做的:@a=privateconstantfloat0x3FB99999A0000000...%1=loadfloat,float*@a--->removed%3=fmulfast%1,%2--->%3=fmulfastfloat0x3FB99999A0000000,%2下面是我到目前为止尝试过的:for(autogv_iter=llvm_module.global_begin();gv_iter!=llvm_module.global_end();gv_iter++){llvm::GlobalVariable*gv=&

c++ - 用于 openmp 4.5 卸载到 (gpu) 设备的 nvptx gcc (9.0.0/trunk) 找不到 libgomp.spec

一段时间以来,我一直在尝试安装OpenMP4.5卸载到NvidiaGPU版本的gcc,但到目前为止没有成功,尽管我越来越接近了。这次我关注了thisscript,我做了两个更改:首先,我指定了gcc的主干版本而不是7.2,其次,根据github存储库,nvptx-newlib现在包含在nvptx-tools中,所以我删除了那部分脚本。为便于引用,原脚本为#!/bin/sh##BuildGCCwithsupportforoffloadingtoNVIDIAGPUs.#work_dir=$HOME/offload/wrkinstall_dir=$HOME/offload/install#L

【Linux】环境基础开发工具的使用之gcc详解(二)

前言:上一篇文章中我们讲解了Linux下的vim和yum的工具的使用,今天我们将在上一次的基础上进一步的讲解开放工具的时候。💖博主CSDN主页:卫卫卫的个人主页💞👉专栏分类:Linux的深度刨析👈💯代码仓库:卫卫周大胖的学习日记💫💪关注博主和博主一起学习!一起努力!目录标题Linux基础开发工具的使用Linux编译器-gcc/g++使用gcc与g++安装gcc程序产生的过程gcc的用法逐过程讲解预处理阶段编译阶段汇编阶段链接阶段动态库与静态库Linux基础开发工具的使用Linux编译器-gcc/g++使用GCC概念:GCC(GNUCompilerCollection)是一套开源的编程语言编译器