blob: f399e55ce8b82386f0ff9cb1d51540d30be0e34a [file] [log] [blame]
/* { dg-do compile } */
/* { dg-options "-O2" } */
int
ldr_uxtw (int *arr, unsigned int i)
{
/* { dg-final { scan-assembler "ldr\tw\[0-9\]+,.*uxtw #?2]" } } */
return arr[i];
}
int
ldr_uxtw0 (char *arr, unsigned int i)
{
/* { dg-final { scan-assembler "ldr\tw\[0-9\]+,.*uxtw]" } } */
return arr[i];
}
int
ldr_sxtw (int *arr, int i)
{
/* { dg-final { scan-assembler "ldr\tw\[0-9\]+,.*sxtw #?2]" } } */
return arr[i];
}
int
ldr_sxtw0 (char *arr, int i)
{
/* { dg-final { scan-assembler "ldr\tw\[0-9\]+,.*sxtw]" } } */
return arr[i];
}
unsigned long long
adddi_uxtw (unsigned long long a, unsigned int i)
{
/* { dg-final { scan-assembler "add\tx\[0-9\]+,.*uxtw #?3" } } */
return a + ((unsigned long long)i << 3);
}
unsigned long long
adddi_uxtw0 (unsigned long long a, unsigned int i)
{
/* { dg-final { scan-assembler "add\tx\[0-9\]+,.*uxtw\n" } } */
return a + i;
}
long long
adddi_sxtw (long long a, int i)
{
/* { dg-final { scan-assembler "add\tx\[0-9\]+,.*sxtw #?3" } } */
return a + ((long long)i << 3);
}
long long
adddi_sxtw0 (long long a, int i)
{
/* { dg-final { scan-assembler "add\tx\[0-9\]+,.*sxtw\n" } } */
return a + i;
}
unsigned long long
subdi_uxtw (unsigned long long a, unsigned int i)
{
/* { dg-final { scan-assembler "sub\tx\[0-9\]+,.*uxtw #?3" } } */
return a - ((unsigned long long)i << 3);
}
unsigned long long
subdi_uxtw0 (unsigned long long a, unsigned int i)
{
/* { dg-final { scan-assembler "sub\tx\[0-9\]+,.*uxtw\n" } } */
return a - i;
}
long long
subdi_sxtw (long long a, int i)
{
/* { dg-final { scan-assembler "sub\tx\[0-9\]+,.*sxtw #?3" } } */
return a - ((long long)i << 3);
}
long long
subdi_sxtw0 (long long a, int i)
{
/* { dg-final { scan-assembler "sub\tx\[0-9\]+,.*sxtw\n" } } */
return a - (long long)i;
}
unsigned long long
subdi_uxth (unsigned long long a, unsigned short i)
{
/* { dg-final { scan-assembler "sub\tx\[0-9\]+,.*uxth #?1" } } */
return a - ((unsigned long long)i << 1);
}
unsigned long long
subdi_uxth0 (unsigned long long a, unsigned short i)
{
/* { dg-final { scan-assembler "sub\tx\[0-9\]+,.*uxth\n" } } */
return a - i;
}
long long
subdi_sxth (long long a, short i)
{
/* { dg-final { scan-assembler "sub\tx\[0-9\]+,.*sxth #?1" } } */
return a - ((long long)i << 1);
}
long long
subdi_sxth0 (long long a, short i)
{
/* { dg-final { scan-assembler "sub\tx\[0-9\]+,.*sxth\n" } } */
return a - (long long)i;
}
unsigned int
subsi_uxth (unsigned int a, unsigned short i)
{
/* { dg-final { scan-assembler "sub\tw\[0-9\]+,.*uxth #?1" } } */
return a - ((unsigned int)i << 1);
}
unsigned int
subsi_uxth0 (unsigned int a, unsigned short i)
{
/* { dg-final { scan-assembler "sub\tw\[0-9\]+,.*uxth\n" } } */
return a - i;
}
int
subsi_sxth (int a, short i)
{
/* { dg-final { scan-assembler "sub\tw\[0-9\]+,.*sxth #?1" } } */
return a - ((int)i << 1);
}
int
subsi_sxth0 (int a, short i)
{
/* { dg-final { scan-assembler "sub\tw\[0-9\]+,.*sxth\n" } } */
return a - (int)i;
}
unsigned int
addsi_uxth (unsigned int a, unsigned short i)
{
/* { dg-final { scan-assembler "add\tw\[0-9\]+,.*uxth #?1" } } */
return a + ((unsigned int)i << 1);
}
unsigned int
addsi_uxth0 (unsigned int a, unsigned short i)
{
/* { dg-final { scan-assembler "add\tw\[0-9\]+,.*uxth\n" } } */
return a + i;
}
int
addsi_sxth (int a, short i)
{
/* { dg-final { scan-assembler "add\tw\[0-9\]+,.*sxth #?1" } } */
return a + ((int)i << 1);
}
int
addsi_sxth0 (int a, short i)
{
/* { dg-final { scan-assembler "add\tw\[0-9\]+,.*sxth\n" } } */
return a + (int)i;
}