blob: 48e225d3f1e7286a68351de1d7ba4a051d5185e6 [file] [log] [blame]
/* { dg-do compile } */
/* { dg-options "-march=rv64gc_zba -mabi=lp64" } */
/* { dg-skip-if "" { *-*-* } { "-O0" "-Og" } } */
long long sub1(unsigned long long a, unsigned long long b)
{
b = (b << 32) >> 31;
unsigned int x = a + b;
return x;
}
long long sub2(unsigned long long a, unsigned long long b)
{
return (unsigned int)(a + (b << 1));
}
long long sub3(unsigned long long a, unsigned long long b)
{
return (a + (b << 1)) & ~0u;
}
/* { dg-final { scan-assembler-times {\msh1add} 3 } } */
/* { dg-final { scan-assembler-times "zext.w\t" 3 } } */