https://gcc.gnu.org/bugzilla/show_bug.cgi?id=64950

            Bug ID: 64950
           Summary: postpone expanding va_arg till pass_stdarg
           Product: gcc
           Version: 5.0
            Status: UNCONFIRMED
          Severity: enhancement
          Priority: P3
         Component: tree-optimization
          Assignee: unassigned at gcc dot gnu.org
          Reporter: vries at gcc dot gnu.org

pass_stdarg optimizes cfun->va_list_gpr/fpr_size by detecting va_args.

However, va_args are expanded at gimple level, so pass_stdarg detects them by
matching what the expansion of va_arg looks like after running through the
passes between gimplification and pass_stdarg.

This is known to be fragile (see f.i. PR 41089). It makes more sense to do the
pass_stdarg optimization while va_arg is still intact. And we want to run
optimization passes before pass_stdarg to be able to eliminate some unwanted
va_args. So, it makes sense to postpone expansion of va_arg untill pass_stdarg.

Michael Matz posted a prototype patch (
https://gcc.gnu.org/ml/gcc/2015-01/msg00304.html ). Latest version availabe at
vries/expand-va-arg-at-pass-stdarg. Testing status of latest version available
at https://gcc.gnu.org/ml/gcc/2015-02/msg00020.html .

Reply via email to