Konstantin Vladimirov schrieb:
Hi,

This problem is backend independent, so I build reproduction in x86
backend. Consider code:

int func(int x);

int test(int x, int *data)
{
  int retval;
  register int *buffer asm ("eax");

  buffer = data;
  retval = func(x);
  __asm__ __volatile__ (".internal_label _t." "4096"
                        ".%0.%1.%2:;nop"::"ri" (buffer), "ri" (4137), "ri" (4));
  return retval;
}

here nop will be replaced for something, that essentially uses %eax,
but it is not actually required for minimal reproduction.

being compiled with gcc (SUSE Linux) 4.5.0 20100604 [gcc-4_5-branch
revision 160292]

with following options:

gcc -m32 -O2 -S -fomit-frame-pointer reprox86.c

yields assembler:

  .type test, @function
test:
  subl  $28, %esp
  movl  32(%esp), %eax
  movl  %eax, (%esp)
  call  func                           // <--- here eax is clobbered
  .internal_label _t.4096.%eax.$4137.$4:;nop 0
  addl  $28, %esp
  ret

That looks quite odd. I have a question -- why compiler doesn't save &
restore buffer (i.e. %eax) value around function call, when we
specifically pointed to %eax usage in the inline assembler
instruction?

Thanks for responses in advance.

There was quite long discussion on the topic last August starting at
http://gcc.gnu.org/ml/gcc/2011-08/msg00023.html
with resonable conclusions like
http://gcc.gnu.org/ml/gcc/2011-08/msg00067.html

I don't know what the current state of implementation is or if anyone is working on it or planned/plans to improve the matter.

Johann

Reply via email to