blob: 1c6631088f0be79002efa95271439b9a235d057f [file] [log] [blame]
/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
#include "test_sve_acle.h"
/*
** index_u16_w0_w1:
** index z0\.h, w0, w1
** ret
*/
TEST_S (index_u16_w0_w1, svuint16_t, uint16_t,
z0 = svindex_u16 (x0, x1))
/*
** index_u16_w0_2:
** index z0\.h, w0, #2
** ret
*/
TEST_S (index_u16_w0_2, svuint16_t, uint16_t,
z0 = svindex_u16 (x0, 2))
/*
** index_u16_50_2:
** mov (w[0-9]+), 50
** index z0\.h, \1, #2
** ret
*/
TEST_S (index_u16_50_2, svuint16_t, uint16_t,
z0 = svindex_u16 (50, 2))
/*
** index_u16_0_m17:
** mov (w[0-9]+), -17
** index z0\.h, #0, \1
** ret
*/
TEST_S (index_u16_0_m17, svuint16_t, uint16_t,
z0 = svindex_u16 (0, -17))
/*
** index_u16_0_m16:
** index z0\.h, #0, #-16
** ret
*/
TEST_S (index_u16_0_m16, svuint16_t, uint16_t,
z0 = svindex_u16 (0, -16))
/*
** index_u16_0_1:
** index z0\.h, #0, #1
** ret
*/
TEST_S (index_u16_0_1, svuint16_t, uint16_t,
z0 = svindex_u16 (0, 1))
/*
** index_u16_0_15:
** index z0\.h, #0, #15
** ret
*/
TEST_S (index_u16_0_15, svuint16_t, uint16_t,
z0 = svindex_u16 (0, 15))
/*
** index_u16_0_16:
** mov (w[0-9]+), 16
** index z0\.h, #0, \1
** ret
*/
TEST_S (index_u16_0_16, svuint16_t, uint16_t,
z0 = svindex_u16 (0, 16))
/*
** index_u16_m17_1:
** mov (w[0-9]+), -17
** index z0\.h, \1, #1
** ret
*/
TEST_S (index_u16_m17_1, svuint16_t, uint16_t,
z0 = svindex_u16 (-17, 1))
/*
** index_u16_m16_1:
** index z0\.h, #-16, #1
** ret
*/
TEST_S (index_u16_m16_1, svuint16_t, uint16_t,
z0 = svindex_u16 (-16, 1))
/*
** index_u16_m1_1:
** index z0\.h, #-1, #1
** ret
*/
TEST_S (index_u16_m1_1, svuint16_t, uint16_t,
z0 = svindex_u16 (-1, 1))
/*
** index_u16_1_1:
** index z0\.h, #1, #1
** ret
*/
TEST_S (index_u16_1_1, svuint16_t, uint16_t,
z0 = svindex_u16 (1, 1))
/*
** index_u16_15_1:
** index z0\.h, #15, #1
** ret
*/
TEST_S (index_u16_15_1, svuint16_t, uint16_t,
z0 = svindex_u16 (15, 1))
/*
** index_u16_16_1:
** mov (w[0-9]+), 16
** index z0\.h, \1, #1
** ret
*/
TEST_S (index_u16_16_1, svuint16_t, uint16_t,
z0 = svindex_u16 (16, 1))
/*
** index_u16_m17_x0:
** mov (w[0-9]+), -17
** index z0\.h, \1, w0
** ret
*/
TEST_S (index_u16_m17_x0, svuint16_t, uint16_t,
z0 = svindex_u16 (-17, x0))
/*
** index_u16_m16_x0:
** index z0\.h, #-16, w0
** ret
*/
TEST_S (index_u16_m16_x0, svuint16_t, uint16_t,
z0 = svindex_u16 (-16, x0))
/*
** index_u16_m1_x0:
** index z0\.h, #-1, w0
** ret
*/
TEST_S (index_u16_m1_x0, svuint16_t, uint16_t,
z0 = svindex_u16 (-1, x0))
/*
** index_u16_0_x0:
** index z0\.h, #0, w0
** ret
*/
TEST_S (index_u16_0_x0, svuint16_t, uint16_t,
z0 = svindex_u16 (0, x0))
/*
** index_u16_1_x0:
** index z0\.h, #1, w0
** ret
*/
TEST_S (index_u16_1_x0, svuint16_t, uint16_t,
z0 = svindex_u16 (1, x0))
/*
** index_u16_15_x0:
** index z0\.h, #15, w0
** ret
*/
TEST_S (index_u16_15_x0, svuint16_t, uint16_t,
z0 = svindex_u16 (15, x0))
/*
** index_u16_16_x0:
** mov (w[0-9]+), 16
** index z0\.h, \1, w0
** ret
*/
TEST_S (index_u16_16_x0, svuint16_t, uint16_t,
z0 = svindex_u16 (16, x0))
/*
** index_u16_x0_m17:
** mov (w[0-9]+), -17
** index z0\.h, w0, \1
** ret
*/
TEST_S (index_u16_x0_m17, svuint16_t, uint16_t,
z0 = svindex_u16 (x0, -17))
/*
** index_u16_x0_m16:
** index z0\.h, w0, #-16
** ret
*/
TEST_S (index_u16_x0_m16, svuint16_t, uint16_t,
z0 = svindex_u16 (x0, -16))
/*
** index_u16_x0_1:
** index z0\.h, w0, #1
** ret
*/
TEST_S (index_u16_x0_1, svuint16_t, uint16_t,
z0 = svindex_u16 (x0, 1))
/*
** index_u16_x0_15:
** index z0\.h, w0, #15
** ret
*/
TEST_S (index_u16_x0_15, svuint16_t, uint16_t,
z0 = svindex_u16 (x0, 15))
/*
** index_u16_x0_16:
** mov (w[0-9]+), 16
** index z0\.h, w0, \1
** ret
*/
TEST_S (index_u16_x0_16, svuint16_t, uint16_t,
z0 = svindex_u16 (x0, 16))