/* { dg-do run } */ /* { dg-options "-save-temps -O2" } */ #include /* Hide value propagation from the optimizers. */ static int id (int i) { asm ("": "+r" (i)); return i; } static int mulhigh (unsigned a, unsigned b) { return (unsigned long long) a * b >> 32; } int main (void) { if (mulhigh (id (0x12345678), id (0x90abcdef)) != 0xa49a83e) abort (); return 0; } /* { dg-final { scan-assembler "mpyhu\[ \t\]" { target { arc700 } } } } */ /* { dg-final { scan-assembler "mpy.u\[ \t\]" { target { { ! { arc700 } } && arcmpy } } } } */