什么是G ++中-Og级别启用的优化?

时间:2016-08-10 15:09:15

标签: g++ g++-5

官方GCC文档没有给出-Og级别的C ++启用的优化列表,只说明选定的选项不会损害可调试性。

我需要知道优化列表,执行二进制搜索哪一个导致 ARM Cortex-M7 内联模板类构造函数调用中的错误(arm-none-eabi)平台。我想只禁用阻止我们的代码正常工作的那个。是否有某个地方的清单或要求GCC本身的选项?

另外,这将有助于我检查我是否真的在编译器中看到错误,或者在该地方应用的优化显示了其他问题。在前一种情况下,我需要通过最小的工作示例来确定它,这不是简单的情况。 -O0的代码工作正常。

1 个答案:

答案 0 :(得分:2)

您可以随时查看优化级别的功能:g++ -c -Q -Og --help=optimizers | grep enabled。从手册页:

  

如果在-Q之前的命令行中显示--help=选项   选项,然后更改--help=显示的描述性文本。   不是描述显示的选项,而是给出指示   选项是启用,禁用还是设置为特定值   (假设编译器知道这一点   使用--help=选项。)

这在GCC 6.1.1上输出x86_64:

  -faggressive-loop-optimizations   [enabled]
  -fasynchronous-unwind-tables      [enabled]
  -fauto-inc-dec                    [enabled]
  -fcombine-stack-adjustments       [enabled]
  -fcompare-elim                    [enabled]
  -fcprop-registers                 [enabled]
  -fdce                             [enabled]
  -fdefer-pop                       [enabled]
  -fdelete-null-pointer-checks      [enabled]
  -fdse                             [enabled]
  -fearly-inlining                  [enabled]
  -fforward-propagate               [enabled]
  -ffunction-cse                    [enabled]
  -fgcse-lm                         [enabled]
  -fguess-branch-probability        [enabled]
  -finline                          [enabled]
  -finline-atomics                  [enabled]
  -fipa-profile                     [enabled]
  -fipa-pure-const                  [enabled]
  -fipa-reference                   [enabled]
  -fira-hoist-pressure              [enabled]
  -fira-share-save-slots            [enabled]
  -fira-share-spill-slots           [enabled]
  -fivopts                          [enabled]
  -fjump-tables                     [enabled]
  -flifetime-dse                    [enabled]
  -fmath-errno                      [enabled]
  -fpeephole                        [enabled]
  -fplt                             [enabled]
  -fprefetch-loop-arrays            [enabled]
  -frename-registers                [enabled]
  -freorder-blocks                  [enabled]
  -frtti                            [enabled]
  -fsched-critical-path-heuristic   [enabled]
  -fsched-dep-count-heuristic       [enabled]
  -fsched-group-heuristic           [enabled]
  -fsched-interblock                [enabled]
  -fsched-last-insn-heuristic       [enabled]
  -fsched-rank-heuristic            [enabled]
  -fsched-spec                      [enabled]
  -fsched-spec-insn-heuristic       [enabled]
  -fsched-stalled-insns-dep         [enabled]
  -fschedule-fusion                 [enabled]
  -fshort-enums                     [enabled]
  -fshrink-wrap                     [enabled]
  -fsigned-zeros                    [enabled]
  -fsplit-ivs-in-unroller           [enabled]
  -fsplit-wide-types                [enabled]
  -fssa-backprop                    [enabled]
  -fstdarg-opt                      [enabled]
  -fstrict-volatile-bitfields       [enabled]
  -fno-threadsafe-statics           [enabled]
  -ftrapping-math                   [enabled]
  -ftree-builtin-call-dce           [enabled]
  -ftree-ccp                        [enabled]
  -ftree-ch                         [enabled]
  -ftree-coalesce-vars              [enabled]
  -ftree-copy-prop                  [enabled]
  -ftree-cselim                     [enabled]
  -ftree-dce                        [enabled]
  -ftree-dominator-opts             [enabled]
  -ftree-dse                        [enabled]
  -ftree-forwprop                   [enabled]
  -ftree-fre                        [enabled]
  -ftree-loop-if-convert            [enabled]
  -ftree-loop-im                    [enabled]
  -ftree-loop-ivcanon               [enabled]
  -ftree-loop-optimize              [enabled]
  -ftree-phiprop                    [enabled]
  -ftree-reassoc                    [enabled]
  -ftree-scev-cprop                 [enabled]
  -ftree-sink                       [enabled]
  -ftree-slsr                       [enabled]
  -ftree-ter                        [enabled]
  -fvar-tracking                    [enabled]
  -fvar-tracking-assignments        [enabled]
  -fweb                             [enabled]