2 /* { dg-do compile } */
3 /* { dg-options "-march=armv8-a+crypto" } */
8 test_vsha1cq_u32 (uint32x4_t hash_abcd
, uint32_t hash_e
, uint32x4_t wk
)
10 return vsha1cq_u32 (hash_abcd
, hash_e
, wk
);
13 /* { dg-final { scan-assembler-times "sha1c\\tq" 1 } } */
16 test_vsha1mq_u32 (uint32x4_t hash_abcd
, uint32_t hash_e
, uint32x4_t wk
)
18 return vsha1mq_u32 (hash_abcd
, hash_e
, wk
);
21 /* { dg-final { scan-assembler-times "sha1m\\tq" 1 } } */
24 test_vsha1pq_u32 (uint32x4_t hash_abcd
, uint32_t hash_e
, uint32x4_t wk
)
26 return vsha1pq_u32 (hash_abcd
, hash_e
, wk
);
29 /* { dg-final { scan-assembler-times "sha1p\\tq" 1 } } */
32 test_vsha1h_u32 (uint32_t hash_e
)
34 return vsha1h_u32 (hash_e
);
37 /* { dg-final { scan-assembler-times "sha1h\\ts" 1 } } */
40 test_vsha1su0q_u32 (uint32x4_t w0_3
, uint32x4_t w4_7
, uint32x4_t w8_11
)
42 return vsha1su0q_u32 (w0_3
, w4_7
, w8_11
);
45 /* { dg-final { scan-assembler-times "sha1su0\\tv" 1 } } */
48 test_vsha1su1q_u32 (uint32x4_t tw0_3
, uint32x4_t w12_15
)
50 return vsha1su1q_u32 (tw0_3
, w12_15
);
53 /* { dg-final { scan-assembler-times "sha1su1\\tv" 1 } } */