public inbox for gcc-bugs@sourceware.org
help / color / mirror / Atom feed
* [Bug tree-optimization/47237] New: builtin_apply_args broken WRT local API changes.
@ 2011-01-09 18:28 hubicka at gcc dot gnu.org
  2011-01-11 13:03 ` [Bug tree-optimization/47237] [4.3/4.4/4.5/4.6 Regression] " rguenth at gcc dot gnu.org
                   ` (10 more replies)
  0 siblings, 11 replies; 12+ messages in thread
From: hubicka at gcc dot gnu.org @ 2011-01-09 18:28 UTC (permalink / raw)
  To: gcc-bugs

http://gcc.gnu.org/bugzilla/show_bug.cgi?id=47237

           Summary: builtin_apply_args broken WRT local API changes.
           Product: gcc
           Version: 4.6.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: tree-optimization
        AssignedTo: unassigned@gcc.gnu.org
        ReportedBy: hubicka@gcc.gnu.org


#define INTEGER_ARG  5

extern void abort(void);

static void foo(int arg)
{
  if (arg != INTEGER_ARG)
    abort();
}

static void bar(int arg)
{
  foo(arg);
  __builtin_apply(foo, __builtin_apply_args(), 16);
}

int main(void)
{
  bar(INTEGER_ARG);

  return 0;
}
fails at 32bit.  The problem is that we call bar with register calling
conventions, while foo's calling conventions are default.
We must prevent any call conventions changes on functions calling
builtlin_apply.

This is not only case where builtin_apply_args breaks, since we will happily
clone the functions, too.

I guess in addition to inlinable and cloning flag, we need flag whether
function calling convention can change. In what conditions this is false in
addition to apply_args?

This bug probably exists since GCC 3.4. I tested 4.3 and 4.5 to fail.


^ permalink raw reply	[flat|nested] 12+ messages in thread

end of thread, other threads:[~2012-07-02 10:24 UTC | newest]

Thread overview: 12+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2011-01-09 18:28 [Bug tree-optimization/47237] New: builtin_apply_args broken WRT local API changes hubicka at gcc dot gnu.org
2011-01-11 13:03 ` [Bug tree-optimization/47237] [4.3/4.4/4.5/4.6 Regression] " rguenth at gcc dot gnu.org
2011-01-26 10:23 ` [Bug tree-optimization/47237] [4.3/4.4/4.5/4.6 Regression] builtin_apply_args broken WRT local ABI changes hubicka at gcc dot gnu.org
2011-01-26 14:29 ` hubicka at gcc dot gnu.org
2011-01-26 14:45 ` hjl.tools at gmail dot com
2011-01-27  7:03 ` [Bug tree-optimization/47237] [4.3/4.4/4.5 " hjl.tools at gmail dot com
2011-02-02 18:00 ` dnovillo at gcc dot gnu.org
2011-02-02 18:01 ` dnovillo at gcc dot gnu.org
2011-06-27 14:38 ` rguenth at gcc dot gnu.org
2012-03-13 15:12 ` [Bug tree-optimization/47237] [4.5 " jakub at gcc dot gnu.org
2012-03-24 23:41 ` hubicka at gcc dot gnu.org
2012-07-02 10:24 ` rguenth at gcc dot gnu.org

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).