Viewing file: shift_1.c (4.61 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* { dg-do assemble { target aarch64_asm_sve_ok } } */ /* { dg-options "-O2 -ftree-vectorize --save-temps" } */
#include <stdint.h>
#define DO_REG_OPS(TYPE) \ void ashiftr_##TYPE (TYPE *dst, TYPE src, int count) \ { \ for (int i = 0; i < count; ++i) \ dst[i] = dst[i] >> src; \ } \ void lshiftr_##TYPE (u##TYPE *dst, u##TYPE src, int count) \ { \ for (int i = 0; i < count; ++i) \ dst[i] = dst[i] >> src; \ } \ void lshiftl_##TYPE (u##TYPE *dst, u##TYPE src, int count) \ { \ for (int i = 0; i < count; ++i) \ dst[i] = dst[i] << src; \ } \ void vashiftr_##TYPE (TYPE *dst, TYPE *src, int count) \ { \ for (int i = 0; i < count; ++i) \ dst[i] = dst[i] >> src[i]; \ } \ void vlshiftr_##TYPE (u##TYPE *dst, u##TYPE *src, int count) \ { \ for (int i = 0; i < count; ++i) \ dst[i] = dst[i] >> src[i]; \ } \ void vlshiftl_##TYPE (u##TYPE *dst, u##TYPE *src, int count) \ { \ for (int i = 0; i < count; ++i) \ dst[i] = dst[i] << src[i]; \ }
#define DO_IMMEDIATE_OPS(VALUE, TYPE, NAME) \ void vashiftr_imm_##NAME##_##TYPE (TYPE *dst, int count) \ { \ for (int i = 0; i < count; ++i) \ dst[i] = dst[i] >> VALUE; \ } \ void vlshiftr_imm_##NAME##_##TYPE (u##TYPE *dst, int count) \ { \ for (int i = 0; i < count; ++i) \ dst[i] = dst[i] >> VALUE; \ } \ void vlshiftl_imm_##NAME##_##TYPE (u##TYPE *dst, int count) \ { \ for (int i = 0; i < count; ++i) \ dst[i] = dst[i] << VALUE; \ }
DO_REG_OPS (int32_t); DO_REG_OPS (int64_t);
DO_IMMEDIATE_OPS (0, int8_t, 0); DO_IMMEDIATE_OPS (5, int8_t, 5); DO_IMMEDIATE_OPS (7, int8_t, 7);
DO_IMMEDIATE_OPS (0, int16_t, 0); DO_IMMEDIATE_OPS (5, int16_t, 5); DO_IMMEDIATE_OPS (15, int16_t, 15);
DO_IMMEDIATE_OPS (0, int32_t, 0); DO_IMMEDIATE_OPS (5, int32_t, 5); DO_IMMEDIATE_OPS (31, int32_t, 31);
DO_IMMEDIATE_OPS (0, int64_t, 0); DO_IMMEDIATE_OPS (5, int64_t, 5); DO_IMMEDIATE_OPS (63, int64_t, 63);
/* { dg-final { scan-assembler-times {\tasr\tz[0-9]+\.s, p[0-7]/m, z[0-9]+\.s, z[0-9]+\.s\n} 2 } } */ /* { dg-final { scan-assembler-times {\tlsr\tz[0-9]+\.s, p[0-7]/m, z[0-9]+\.s, z[0-9]+\.s\n} 2 } } */ /* { dg-final { scan-assembler-times {\tlsl\tz[0-9]+\.s, p[0-7]/m, z[0-9]+\.s, z[0-9]+\.s\n} 2 } } */
/* { dg-final { scan-assembler-times {\tasrr?\tz[0-9]+\.d, p[0-7]/m, z[0-9]+\.d, z[0-9]+\.d\n} 2 } } */ /* { dg-final { scan-assembler-times {\tlsrr?\tz[0-9]+\.d, p[0-7]/m, z[0-9]+\.d, z[0-9]+\.d\n} 2 } } */ /* { dg-final { scan-assembler-times {\tlslr?\tz[0-9]+\.d, p[0-7]/m, z[0-9]+\.d, z[0-9]+\.d\n} 2 } } */
/* { dg-final { scan-assembler-times {\tasr\tz[0-9]+\.b, z[0-9]+\.b, #5\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsr\tz[0-9]+\.b, z[0-9]+\.b, #5\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsl\tz[0-9]+\.b, z[0-9]+\.b, #5\n} 1 } } */ /* { dg-final { scan-assembler-times {\tasr\tz[0-9]+\.b, z[0-9]+\.b, #7\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsr\tz[0-9]+\.b, z[0-9]+\.b, #7\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsl\tz[0-9]+\.b, z[0-9]+\.b, #7\n} 1 } } */
/* { dg-final { scan-assembler-times {\tasr\tz[0-9]+\.h, z[0-9]+\.h, #5\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsr\tz[0-9]+\.h, z[0-9]+\.h, #5\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsl\tz[0-9]+\.h, z[0-9]+\.h, #5\n} 1 } } */ /* { dg-final { scan-assembler-times {\tasr\tz[0-9]+\.h, z[0-9]+\.h, #15\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsr\tz[0-9]+\.h, z[0-9]+\.h, #15\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsl\tz[0-9]+\.h, z[0-9]+\.h, #15\n} 1 } } */
/* { dg-final { scan-assembler-times {\tasr\tz[0-9]+\.s, z[0-9]+\.s, #5\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsr\tz[0-9]+\.s, z[0-9]+\.s, #5\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsl\tz[0-9]+\.s, z[0-9]+\.s, #5\n} 1 } } */ /* { dg-final { scan-assembler-times {\tasr\tz[0-9]+\.s, z[0-9]+\.s, #31\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsr\tz[0-9]+\.s, z[0-9]+\.s, #31\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsl\tz[0-9]+\.s, z[0-9]+\.s, #31\n} 1 } } */
/* { dg-final { scan-assembler-times {\tasr\tz[0-9]+\.d, z[0-9]+\.d, #5\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsr\tz[0-9]+\.d, z[0-9]+\.d, #5\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsl\tz[0-9]+\.d, z[0-9]+\.d, #5\n} 1 } } */ /* { dg-final { scan-assembler-times {\tasr\tz[0-9]+\.d, z[0-9]+\.d, #63\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsr\tz[0-9]+\.d, z[0-9]+\.d, #63\n} 1 } } */ /* { dg-final { scan-assembler-times {\tlsl\tz[0-9]+\.d, z[0-9]+\.d, #63\n} 1 } } */
|