Hi Guys,

  Sorry for the delay between these updates.  My new job is keeping
  me very busy...  Anyway here are the highlights of the changes in
  the GNU toolchain over the last two months:


  The compiler and assembler now have support for the ARC EM/HS and
  ARC600/700 architectures and the Power9 variant of the PowerPC
  architecture.  


  The GCC mainline sources are now in Stage 3 (bug fixes only) which
  means that a branch may be happening soon.


  The Binutils sources have branched, getting ready for a 2.26 release
  soon.


  GDB's record instruction-history command accepts a new modifier: /s.
  This behaves exactly like the /m modifier and prints mixed source +
  disassembly into the history.


  GDB now supports displaced stepping on AArch64 GNU/Linux.


  GCC's named address space feature has been extended to add address
  spaces for the x86 architecture.  Here variables may be declared as
  being relative to the %fs or %gs segments using the __seg_fs and
  __seg_gs attributes.  Alternatively if one of these segments is used
  for thread local storage then the __seg_tls attribute can be used
  access the correct segment.


  GCC's function attribute feature has been extended to support
  another attribute:
  
    target_clones (<options>)

  This is used to specify that a function is to be cloned into
  multiple versions compiled with different target options than
  specified on the command line.  The supported options and
  restrictions are the same as for target attribute.

  For instance on an x86, you could compile a function with
  target_clones("sse4.1,avx").   It will create 2 function clones,
  one compiled with -msse4.1 and another with -mavx.  At the function
  call it will create resolver ifunc, that will dynamically call a
  clone suitable for current architecture.


  A new type attribute has been added to specify the endianness of the
  fields in a struct, union or array:

    scalar_storage_order ("<endianness>")
    
  This attribute sets the storage order, aka endianness, of the scalar
  fields of the type to either "big-endian" or "little-endian".  The
  attribute has no effects on fields which are themselves a union, a
  struct or an array whose component is a union or a struct, and it is
  possible to have fields with a different scalar storage order than
  the enclosing type.

  Additional restrictions are enforced for types with the reverse
  scalar storage order with regard to the scalar storage order of the
  target: 

    * Taking the address of a scalar field of a union or a struct with
      reverse scalar storage order is not permitted and will yield an
      error.
    
    * Taking the address of an array field, whose component is scalar,
      of a union or a struct with reverse scalar storage order is
      permitted but will yield a warning, unless the option
      -Wno-scalar-storage-order is specified.

    * Taking the address of a union or a struct with reverse scalar
    storage order is permitted. 

  These restrictions exist because the storage order attribute is lost
  when the address of a scalar or the address of an array with scalar
  component is taken, so storing indirectly through this address will
  generally not work.  The second case is nevertheless allowed to be
  able to perform a block copy from or to the array.


  A new warning option: -Wduplicated-cond will produce messages
  whenever a condition is duplicated in an if-else-if chain.  For
  example:
  
    if (p->q != NULL) { ... }
    else if (p->q != NULL) { ... }


  A new option: -fkeep-static-functions will make sure that gcc will
  generate code for static functions that are never used.


  The block reordering optimization in gcc can now be tuned via the
  option: -freorder-blocks-algorithm=<simple|stc>.  The default for
  optimization levels below -O2 (or at -Os) is the "simple" algorithm 
  which does not increase code size.  The new "stc" algorithm stands
  for "software trace cache" and it tries to put all often executed
  code together, minimizing the number of branches executed by
  making extra copies of code.


  The ARM backend supports a new option: -mlow-precision-recip-sqrt
  which uses two steps instead of three for double-precision
  reciprocal square root calculations.  (It also uses one step instead
  of two steps for single-precision calculations).  This reduces the
  latency and precision of the operation.


  The x86 and x86_64 backends support a new option: -mms-bitfields
  This enables a bit-field layout compatible with the native Microsoft
  Windows compiler.   This option is enabled by default for Windows
  targets.
  

  The x86 and x86_64 backends also support the new option:
  
    -mmitigate-rop

  This tries to avoid generating code sequences that contain
  unintended return opcodes, to mitigate against certain forms of
  attack.  At the moment, this option is limited in what it can do and
  should not be relied on to provide serious protection.


  The assembler and linker now support a configure time option to
  enable the automatic compression of debug sections.  This is off by
  default, but after the next release of the binutils, it will be
  switched on by default for some targets.


  The linker supports a new ARM specific command line option:
  --fix-stm32l4xx-629360.  This enables a link-time workaround for a
  bug in the bus matrix / memory controller for some of the STM32
  Cortex-M4 based products (STM32L4xx).


  The objcopy program now has the ability to insert new symbols into
  an object file or executable.  It is controlled by the option:
  
    --add-symbol <name>=[<section>:]<value>[,<flags>]
    
  This adds a new symbol called <name>.  If the <section> is given,
  the symbol will be associated with and relative to that section,
  otherwise it will be an absolute symbol.  Symbol flags can be
  specified as well although not all flags will be meaningful for all
  object file formats.  The special flag 'before=<othersym>' will
  insert the new symbol in front of the specified <othersym>,
  otherwise the symbol(s) will be added at the end of the symbol table
  in the order they appear. 


  The MSP430 port of gas accepts a new command line option to control
  workarounds for various silicon errata:
  
    -msilicon-errata=<name>[,<name>...]

  This option enables the specified workarounds, but does not produce
  any informative output for the user when it does so.  The related
  option:

    -msilicon-errata-warn=<name>[,<name>...]

  can be used to produce warning messages whenever a situation where a 
  silicon errata might be valid is encountered by the assembler.


  The x86/x86_64 linkers now support a command line option to specify
  the byte to be used as padding when transforming an indirect call to
  a locally defined function 'foo' into a call via its GOT slot:

   -z call-nop=prefix-addr    generates: "0x67 call foo"
   -z call-nop=prefix-nop     generates: "0x90 call foo"
   -z call-nop=suffix-nop     generates: "call foo 0x90"
   -z call-nop=prefix-<byte>  generates: "<byte> call foo"
   -z call-nop=suffix-<byte>  generates: "call foo <byte>"


Lastly, here are the monthly DG test results for the various toolchains
that I am able to simulate on my local machine:

                          GCC/DG unexpected failures
                        ------------------------------
                        Aug'15  Sep'15  Oct'15  Nov'15
aarch64-elf                -       -       -     549
arm-eabi                   4       4      40      42
bfin-elf                  11      12      47      50
frv-elf                  541      24      60      63
h8300-elf                 71      71     110     120
iq2000-elf               684     687     728     736
m32r-elf                   -       9      45      48
mcore-elf                519     517     557     565
mipsisa32-elf             25      24      67      69
mipsisa64-elf             26      25      68      70
mn10300-elf              468      12      47      50
msp430-elf               100     559     101     133
powerpc-eabispe           15      15      51      54
rl78-elf                  99      99     139     148
rx-elf                    42      41      77      87
sh-elf                     6       6      42      45
v850e-elf                 31      31      67      70
x86_64-pc-linux-gnu        2       2      39      38

                          G++/DG unexpected failures
                        ------------------------------
                        Aug'15  Sep'15  Oct'15  Nov'15
aarch64-elf                -       -       -    2110      
arm-eabi                  35      35     146     153
bfin-elf                  23      23     134     134
frv-elf                    -     124     226     230
h8300-elf                294     297     414     519
iq2000-elf              3296    3336    3154     449
m32r-elf                   -     102     213      48
mcore-elf               2221    2222    3160    2341
mipsisa32-elf            926     923    2099    1039
mipsisa64-elf            926     926    1037    1042
mn10300-elf                -      74     188     187
msp430-elf              1050    2449    1164    1178
powerpc-eabispe          135     150     136     136
rl78-elf                   -     884     884    1191
rx-elf                    50      50     158     173
sh-elf                    35      35     146     149
v850e-elf                  -      94     247     247
x86_64-pc-linux-gnu       17      17     125      38

Reply via email to